/**
 * M2 brand layer — derived from FIIIIILS/LOGO (PNG sampling + palette review)
 * Colors: cyan accent #48c0d8, ink #0b1622 / #000018
 * Load order: after custom.css (see includes/head.tpl)
 */

html {
  --m2-cyan: #48c0d8;
  --m2-cyan-bright: #5ac8e6;
  --m2-cyan-deep: #3aa5bc;
  --m2-ink: #0b1622;
  --m2-ink-deep: #000018;
  --m2-dark: #05141f;
  --m2-radius: 8px;
  /* Map emyUI Nexus token “info” to brand cyan for components that use it */
  --info: var(--m2-cyan);
  --info-lifted: var(--m2-cyan-deep);
}

/* Light UI: text ink closer to logo navy */
body.primary-bg-color:not(.dark-mode-texts) {
  --color-texts: var(--m2-ink);
  --color-texts-opacity: rgba(11, 22, 34, 0.72);
}

/* Primary actions — cyan (logo accent) */
body.primary-bg-color .btn-primary,
body.primary-bg-color .btn-info,
body.not-login-page .clientarea .btn-primary {
  background-color: var(--m2-cyan) !important;
  border-color: var(--m2-cyan-deep) !important;
  color: #fff !important;
  border-radius: var(--m2-radius);
}

body.primary-bg-color .btn-primary:hover,
body.primary-bg-color .btn-primary:focus,
body.primary-bg-color .btn-info:hover,
body.not-login-page .clientarea .btn-primary:hover {
  background-color: var(--m2-cyan-bright) !important;
  border-color: var(--m2-cyan) !important;
  color: #fff !important;
}

body.primary-bg-color .badge-primary,
body.primary-bg-color .label-primary {
  background-color: var(--m2-cyan-deep) !important;
}

/* Cart / order flow primary buttons */
#order-standard_cart .btn-primary,
.shopping__cart__main__page__content .btn-primary {
  background-color: var(--m2-cyan) !important;
  border-color: var(--m2-cyan-deep) !important;
}

@media (prefers-reduced-motion: reduce) {
  .btn-primary,
  .btn-info {
    transition: none;
  }
}

/* ----- Logo size: emyUI `main.css` caps `.brand-logo>a>img` at 30px height ----- */
.site-header .brand-logo > a > img,
.site-header .brand-logo-signup > a > img,
.footer-section .brand-logo > a > img,
.brand-logo-signup > a > img,
body.this-is-login-page .brand-logo > a > img {
  height: auto !important;
  width: auto;
  max-width: min(96vw, 580px);
  object-fit: contain;
}

.site-header .brand-logo > a > img,
.site-header .brand-logo-signup > a > img {
  max-height: 44px;
}

@media (min-width: 768px) {
  .site-header .brand-logo > a > img,
  .site-header .brand-logo-signup > a > img {
    max-height: 54px;
  }
}

@media (min-width: 1200px) {
  .site-header .brand-logo > a > img,
  .site-header .brand-logo-signup > a > img {
    max-height: 60px;
  }
}

.footer-section .brand-logo > a > img {
  max-height: 56px;
}

@media (min-width: 768px) {
  .footer-section .brand-logo > a > img {
    max-height: 72px;
  }
}

@media (min-width: 1200px) {
  .footer-section .brand-logo > a > img {
    max-height: 84px;
  }
}

.brand-logo-signup > a > img {
  max-height: 64px;
}

@media (min-width: 768px) {
  .brand-logo-signup > a > img {
    max-height: 80px;
  }
}

/* Register (and other login-class pages) — logo block is not inside .site-header */
body.this-is-login-page .brand-logo > a > img {
  max-height: 64px;
}

@media (min-width: 768px) {
  body.this-is-login-page .brand-logo > a > img {
    max-height: 80px;
  }
}

/* ----- M2: header quick links (Shufy-inspired) ----- */
.m2-header-quicklinks {
  border-top: 1px solid rgba(11, 22, 34, 0.06);
  background: rgba(255, 255, 255, 0.35);
}

.dark-mode-texts .m2-header-quicklinks {
  background: rgba(255, 255, 255, 0.04);
  border-top-color: rgba(255, 255, 255, 0.08);
}

.m2-header-quicklinks__link {
  color: var(--m2-ink);
  text-decoration: none !important;
  font-weight: 500;
}

.m2-header-quicklinks__link:hover {
  color: var(--m2-cyan);
}

.dark-mode-texts .m2-header-quicklinks__link {
  color: rgba(255, 255, 255, 0.85);
}

.dark-mode-texts .m2-header-quicklinks__link:hover {
  color: var(--m2-cyan-bright);
}

.m2-header-quicklinks__sep {
  color: rgba(11, 22, 34, 0.35);
  padding: 0 0.35rem;
  user-select: none;
}

.dark-mode-texts .m2-header-quicklinks__sep {
  color: rgba(255, 255, 255, 0.35);
}

/* ----- M2: invoice payment sidebar ----- */
.m2-invoice-summary.card {
  border-top: 4px solid var(--m2-cyan);
  box-shadow: 0 8px 32px rgba(11, 22, 34, 0.06);
}

/* ----- M2: error pages (Shufy-like typography) ----- */
.m2-error-page__icon {
  color: var(--m2-cyan);
}

.m2-error-page__title {
  color: var(--m2-ink);
}

/* ----- M2: hide Sitejet / Site Builder UI for clients (integration can stay enabled in admin) ----- */
#sitejetDashboardPanel,
#sitejetPanel,
.m2-sitejet-panel-suppressed,
div[menuItemName="sitejetBuilder"],
/* WHMCS may emit different casing / attribute order; hide client-area Sitejet cards */
body.primary-bg-color .coodiv-clientarea-boxes[menuItemName*="sitejet" i],
body.primary-bg-color .coodiv-clientarea-boxes[menuitemname*="sitejet" i] {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: none !important;
  clip: rect(0, 0, 0, 0) !important;
  position: absolute !important;
  width: 1px !important;
}

body [data-identifier="sitejet"],
body a[href*="/clientarea/sitejet"] {
  display: none !important;
}

/* View invoice: matches theme main body (not standalone print layout) */
.m2-view-invoice .invoice-header {
  border-color: rgba(11, 22, 34, 0.08) !important;
}
.m2-view-invoice .invoice-status .badge {
  font-weight: 600;
}

/* ============================================================
   M2 ORDER FORM — brand color overrides + card polish
   Replaces all vendor greens (#8adea0, #68d585, #24d261…)
   with M2 cyan family. No changes to whmcs.theme.css.
   ============================================================ */

/* --- 1. Tab nav: active underline (was #8adea0 green) --- */
.order-form-menu-scroller .nav .nav-link.active {
  border-bottom: 4px solid var(--m2-cyan) !important;
  background: rgba(72, 192, 216, 0.06) !important;
  color: var(--m2-cyan-deep) !important;
  opacity: 1 !important;
}
.order-form-menu-scroller .nav .nav-link:hover {
  background: rgba(72, 192, 216, 0.04) !important;
}

/* --- 2. Feature list icons in plan cards (was #68d585 green) --- */
#products .features i {
  color: var(--m2-cyan) !important;
}

/* --- 3. Wizard step progress bar (was #24d261 green) --- */
.orderform-step-form-wizard-item.active::after {
  background: var(--m2-cyan) !important;
}
.orderform-step-form-wizard-group .orderform-step-form-wizard-item.active:nth-child(3) i {
  background: var(--m2-cyan-deep) !important;
}

/* --- 4. Domain add-ons group title badge (was #68d585 green) --- */
.domains-addons-products-title {
  background-color: var(--m2-cyan-deep) !important;
}

/* --- 5. Domain option activation checkmark (was #1fc258 green) --- */
.domain-productconfigiration-options-item .activation-icon {
  background: var(--m2-cyan) !important;
}

/* --- 6. product-info feature mini-icons (was #8bc34a green) --- */
#order-standard_cart .product-info p i {
  color: var(--m2-cyan) !important;
}

/* --- 7. "تصفح الفئات والخدمات" pre-title (was text-green) --- */
.text-green {
  color: var(--m2-cyan) !important;
}

/* ============================================================
   M2 PLAN CARDS — creative polish (لمسة إبداعية)
   Goal: depth + brand identity without breaking layout
   ============================================================ */

/* Card container: subtle shadow + rounded upgrade */
#products .products-item {
  border-radius: 20px !important;
  border: 1px solid rgba(72, 192, 216, 0.15) !important;
  border-right: 1px solid rgba(72, 192, 216, 0.15) !important;
  box-shadow: 0 4px 20px rgba(11, 22, 34, 0.06) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}
#products .products-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(72, 192, 216, 0.18) !important;
  border-color: var(--m2-cyan) !important;
}

/* Product name: ink color */
#products .products-item h5 {
  color: var(--m2-ink) !important;
  font-weight: 700 !important;
  letter-spacing: -0.4px;
}

/* Price: M2 ink-deep instead of generic blue */
#products .products-item .price.value,
#products .products-item span.value {
  color: var(--m2-ink-deep) !important;
  font-weight: 300 !important;
}

/* Cycle label (سنوي…) */
#products .products-item .clarifications {
  font-size: 12px !important;
  letter-spacing: 0;
}

/* Thin separator between price and features */
#products .products-item .features {
  border-top: 1px solid rgba(11, 22, 34, 0.06);
  margin-top: 14px !important;
  padding-top: 12px !important;
}

/* Feature text: slightly darker, tighter leading */
#products .features {
  color: #2d3748 !important;
  line-height: 26px !important;
}

/* "Plan features" label: de-emphasise */
#products .features > span {
  color: var(--m2-cyan-deep) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
  margin-bottom: 10px !important;
  display: block !important;
}

/* Order form nav bar: sharper corners + shadow */
.order-form-menu-scroller {
  box-shadow: 0 2px 16px rgba(11, 22, 34, 0.07) !important;
  border: 1px solid rgba(72, 192, 216, 0.12) !important;
}

/* --- 8. "أطلبه الآن" + cart CTA buttons (were btn-warning yellow) --- */
#products .btn-order-now,
#products .products-item .action .btn-warning,
#order-standard_cart .btn-order-now,
#order-standard_cart .btn-warning {
  background: linear-gradient(135deg, var(--m2-cyan-bright) 0%, var(--m2-cyan-deep) 100%) !important;
  border: 1px solid var(--m2-cyan-deep) !important;
  color: #05141f !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 16px rgba(72, 192, 216, 0.28) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}
#products .btn-order-now:hover,
#products .btn-order-now:focus,
#products .products-item .action .btn-warning:hover,
#order-standard_cart .btn-order-now:hover,
#order-standard_cart .btn-order-now:focus,
#order-standard_cart .btn-warning:hover,
#order-standard_cart .btn-warning:focus {
  background: linear-gradient(135deg, #6dd4ef 0%, var(--m2-cyan) 100%) !important;
  color: #05141f !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(72, 192, 216, 0.4) !important;
}

/* --- 9. Domain page feature-icon chips → unify to cyan (were blue/red/green) --- */
body.user-in-shoppingcart .features-box-icon {
  background-color: rgba(72, 192, 216, 0.12) !important;
  color: var(--m2-cyan-deep) !important;
}
body.user-in-shoppingcart .features-box-icon i {
  color: var(--m2-cyan-deep) !important;
}

/* --- 10. Domain price + count badges → cyan family (were yellow / blue) --- */
body.user-in-shoppingcart .badge-warning {
  background-color: var(--m2-cyan-deep) !important;
  color: #fff !important;
}
body.user-in-shoppingcart .badge-primary {
  background-color: var(--m2-cyan) !important;
  color: #05141f !important;
}

/* --- 11. Section eyebrow (was text-red) → brand cyan --- */
body.user-in-shoppingcart .pre-title.text-red {
  color: var(--m2-cyan) !important;
}

/* ============================================================
   M2 CLIENTAREA: Bootstrap .card panels inside main content
   (domain details, product details, etc.)
   ============================================================ */

.main-page-contents .card {
  border-color: rgba(72, 192, 216, 0.18) !important;
  border-radius: 14px !important;
  box-shadow: 0 2px 14px rgba(11, 22, 34, 0.06) !important;
  overflow: hidden;
  margin-bottom: 1.25rem;
  position: relative;
  transition: box-shadow 0.22s ease, border-color 0.22s ease;
}
.main-page-contents .card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--m2-cyan) 0%, var(--m2-cyan-deep) 100%);
  pointer-events: none;
  z-index: 1;
}
.main-page-contents .card:hover {
  border-color: rgba(72, 192, 216, 0.32) !important;
  box-shadow: 0 6px 24px rgba(72, 192, 216, 0.1) !important;
}
.main-page-contents .card-body {
  padding: 1.5rem 1.75rem !important;
}
.main-page-contents .card-title {
  color: var(--m2-ink) !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  letter-spacing: -0.3px;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(72, 192, 216, 0.12);
  margin-bottom: 1rem !important;
}

/* Field label (h5 inside card rows): subtle, uppercase */
.main-page-contents .card-body h5 {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.55px;
  color: var(--m2-cyan-deep) !important;
  margin-bottom: 0.2rem !important;
}

/* Field value: prominent */
.main-page-contents .card-body .row.mb-3 span,
.main-page-contents .card-body .row.mb-3 a {
  font-size: 0.9375rem !important;
  font-weight: 500;
  color: var(--m2-ink) !important;
}

/* Each field row: thin separator */
.main-page-contents .card-body .row.mb-3 {
  border-bottom: 1px solid rgba(72, 192, 216, 0.08);
  padding-bottom: 0.75rem !important;
}
.main-page-contents .card-body .row.mb-3:last-of-type {
  border-bottom: none;
}

/* Unpaid / overdue invoice alert: M2 amber styling */
.main-page-contents .alert-warning {
  background: #fffbeb !important;
  border-color: rgba(245, 158, 11, 0.3) !important;
  border-inline-start: 4px solid #f59e0b !important;
  border-radius: 10px !important;
  color: #78350f !important;
}
.main-page-contents .alert-danger {
  background: #fff1f2 !important;
  border-color: rgba(220, 38, 38, 0.25) !important;
  border-inline-start: 4px solid #dc2626 !important;
  border-radius: 10px !important;
  color: #7f1d1d !important;
}

/* Alert "pay invoice" button */
.main-page-contents .alert .btn-default,
.main-page-contents .alert .btn-xs {
  background: transparent !important;
  border: 1.5px solid currentColor !important;
  border-radius: 20px !important;
  padding: 3px 14px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: inherit !important;
}
.main-page-contents .alert .btn-default:hover {
  background: rgba(0,0,0,0.06) !important;
}

/* ============================================================
   M2 CLIENT-AREA PANELS (coodiv-clientarea-boxes)
   ============================================================ */

/* Panel container: top accent line + refined shadow */
.coodiv-clientarea-boxes {
  border-color: rgba(72, 192, 216, 0.18) !important;
  border-radius: 14px !important;
  box-shadow: 0 2px 14px rgba(11, 22, 34, 0.06) !important;
  overflow: hidden;
  transition: box-shadow 0.22s ease, border-color 0.22s ease;
  position: relative;
}
.coodiv-clientarea-boxes::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--m2-cyan) 0%, var(--m2-cyan-deep) 100%);
  border-radius: 14px 14px 0 0;
  pointer-events: none;
}
.coodiv-clientarea-boxes:hover {
  border-color: rgba(72, 192, 216, 0.35) !important;
  box-shadow: 0 6px 24px rgba(72, 192, 216, 0.12) !important;
}

/* Panel header */
.coodiv-clientarea-box-header {
  background: linear-gradient(180deg, rgba(72,192,216,0.05) 0%, rgba(255,255,255,0) 100%) !important;
  border-bottom-color: rgba(72, 192, 216, 0.15) !important;
  border-radius: 14px 14px 0 0 !important;
  padding-top: 18px !important;
  padding-bottom: 16px !important;
}
.coodiv-clientarea-box-header h3 {
  color: var(--m2-ink) !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px;
}
/* Badge count in header */
.coodiv-clientarea-box-header .badge {
  background-color: var(--m2-cyan) !important;
  color: #fff !important;
}
/* Action button in header */
.coodiv-clientarea-box-header .btn {
  border-radius: 20px !important;
}

/* List rows: left accent on hover + active */
.coodiv-clientarea-boxes .list-group .list-group-item {
  border-bottom-color: rgba(72, 192, 216, 0.1) !important;
  transition: background 0.18s ease, border-color 0.18s ease;
  padding-inline-start: 2rem !important;
}
.coodiv-clientarea-boxes .list-group .list-group-item:hover {
  background: rgba(72, 192, 216, 0.05) !important;
}
.coodiv-clientarea-boxes .list-group .list-group-item.active {
  background: rgba(72, 192, 216, 0.1) !important;
  color: var(--m2-ink) !important;
  border-left: 3px solid var(--m2-cyan) !important;
}
/* Label/badge inside rows */
.coodiv-clientarea-boxes .list-group .list-group-item .label {
  border-radius: 10px !important;
}

/* Body paragraph */
.coodiv-clientarea-boxes-body p {
  color: var(--m2-ink) !important;
  opacity: 0.85;
}

/* ============================================================
   M2 NAVBAR — replace vendor green with M2 cyan
   ============================================================ */

/* Nav link hover underline (was green gradient) */
.main-menu .nav-item .nav-link::before {
  background: var(--m2-cyan) !important;
  background: linear-gradient(90deg, var(--m2-cyan-deep) 0%, var(--m2-cyan-bright) 100%) !important;
}

/* Dropdown item hover color (was #68d585) */
.coodiv-menu-dropdown > .drop-menu-item:hover > a,
.mega-menu-dropdown-ul > .drop-menu-item:hover > a {
  color: var(--m2-cyan) !important;
}

/* Active link border (was #68d585) */
a.active-link-border {
  border-bottom-color: var(--m2-cyan) !important;
}

/* top-tabs active border (was #8adea0) */
.top-tabs-coodiv a.active {
  border-top-color: var(--m2-cyan) !important;
}

/* Reviews bar: logo bigger + vertically centred + no white bg */
.reviews-overview .website-logo {
  height: 40px !important;
  width: auto !important;
  vertical-align: middle !important;
  margin-right: 8px !important;
  margin-bottom: 0 !important;
  display: inline-block !important;
  mix-blend-mode: multiply;   /* removes white bg on light surfaces */
}

/* ============================================================
   M2 HEADER — brand polish (client-area chrome)
   ============================================================ */

/* Sub-page hero strip behind the header: replace off-brand purple/blue
   gradient with M2 deep-ink + cyan glow (matches m2.ist hero identity) */
.hero-area-coodiv.text-page-hero {
  background-color: var(--m2-ink-deep) !important;
  background-image:
    radial-gradient(120% 150% at 82% -10%, rgba(85, 200, 232, 0.22) 0%, rgba(85, 200, 232, 0) 46%),
    radial-gradient(90% 120% at 12% 0%, rgba(72, 192, 216, 0.1) 0%, rgba(72, 192, 216, 0) 50%),
    linear-gradient(225deg, #07283a 0%, #05141f 55%, #030c14 100%) !important;
}

/* Particles dots over the strip → subtle cyan stars */
.hero-area-coodiv.text-page-hero #particles-bg canvas {
  opacity: 0.5;
}

/* Header utility icons (cart / bell / search): cyan on hover */
.site-header .shoping-cart-btn-header:hover i,
.site-header .notifications-btn-header:hover i,
.site-header .search-btn-header:hover i,
.site-header .user-dropdown-header .nav-link:hover {
  color: var(--m2-cyan-bright) !important;
}

/* Cart item count bubble → brand cyan */
.site-header .shoping-cart-number {
  background-color: var(--m2-cyan) !important;
  border-color: var(--m2-cyan-deep) !important;
  color: #fff !important;
}

/* Notification "new" dot → brand cyan (was green) */
.site-header .notifications-bell.green {
  background-color: var(--m2-cyan-bright) !important;
}

/* Signup / login in header (guest) — M2 dual pills + mobile icon */
.site-header .header-btn-whmcs {
  gap: 6px;
}

.site-header .header-btn.m2-header-auth {
  display: none;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 8px;
  position: relative;
  min-width: 0;
  margin: 0 !important;
  padding: 0;
  border: none;
  background: transparent;
}

.site-header .header-btn.m2-header-auth a {
  display: inline-flex !important;
}

.site-header .m2-header-auth__login,
.site-header .signup-btn-header.m2-header-auth__login {
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 38px;
  padding: 0 14px !important;
  border: none !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #55C8E8, #0891b2) !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
  line-height: 1.2;
  text-decoration: none !important;
  box-shadow: 0 4px 14px rgba(8, 145, 178, 0.28);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  white-space: nowrap;
}

.site-header .m2-header-auth__login:hover,
.site-header .m2-header-auth__login:focus,
.site-header .signup-btn-header.m2-header-auth__login:hover {
  transform: translateY(-1px);
  color: #fff !important;
  background: linear-gradient(135deg, #5fd4f0, #0891b2) !important;
  box-shadow: 0 6px 18px rgba(8, 145, 178, 0.35);
}

.site-header .m2-header-auth__register,
.site-header .headerphone-number.m2-header-auth__register {
  position: static !important;
  left: auto !important;
  bottom: auto !important;
  top: auto !important;
  align-items: center;
  justify-content: center;
  width: auto !important;
  min-width: 0 !important;
  min-height: 38px !important;
  margin: 0 !important;
  padding: 0 14px !important;
  border: 1px solid rgba(85, 200, 232, 0.42) !important;
  border-radius: 999px !important;
  background: rgba(5, 20, 31, 0.22) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: rgba(255, 255, 255, 0.88) !important;
  text-align: center;
  text-decoration: none !important;
  white-space: nowrap;
  line-height: 1.2;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}

.site-header .m2-header-auth__register:hover,
.site-header .m2-header-auth__register:focus,
.site-header .headerphone-number.m2-header-auth__register:hover {
  color: #fff !important;
  border-color: rgba(85, 200, 232, 0.72) !important;
  background: rgba(85, 200, 232, 0.12) !important;
  transform: translateY(-1px);
}

.site-header .m2-header-auth-mobile {
  display: none;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(85, 200, 232, 0.35);
  background: rgba(5, 20, 31, 0.35);
  color: #fff !important;
  text-decoration: none !important;
  transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}

.site-header .m2-header-auth-mobile:hover {
  border-color: rgba(85, 200, 232, 0.65);
  background: rgba(85, 200, 232, 0.14);
  transform: translateY(-1px);
  color: #fff !important;
}

.site-header .m2-header-auth-mobile i {
  font-size: 18px;
  line-height: 1;
}

@media (min-width: 768px) {
  .site-header .header-btn.m2-header-auth {
    display: inline-flex !important;
  }

  .site-header .m2-header-auth-mobile,
  .site-header .signup-btn-header-mobile.m2-header-auth-mobile {
    display: none !important;
  }
}

@media (max-width: 767.98px) {
  .site-header .header-btn.m2-header-auth {
    display: none !important;
  }

  .site-header .m2-header-auth-mobile {
    display: inline-flex !important;
  }
}

/* Guest auth — scrolled / light header (fixed on scroll) */
.site-header.top-header-fixed .header-btn-whmcs,
.site-header.white-bg .header-btn-whmcs,
.site-header.light-mode-texts .header-btn-whmcs {
  align-items: center;
}

.site-header.top-header-fixed .header-btn.m2-header-auth,
.site-header.white-bg .header-btn.m2-header-auth,
.site-header.light-mode-texts .header-btn.m2-header-auth {
  display: none;
  flex-direction: row !important;
  align-items: center !important;
  background: transparent !important;
  border: none !important;
}

@media (min-width: 768px) {
  .site-header.top-header-fixed .header-btn.m2-header-auth,
  .site-header.white-bg .header-btn.m2-header-auth,
  .site-header.light-mode-texts .header-btn.m2-header-auth {
    display: inline-flex !important;
  }
}

.site-header.top-header-fixed .header-btn.m2-header-auth a,
.site-header.white-bg .header-btn.m2-header-auth a,
.site-header.light-mode-texts .header-btn.m2-header-auth a {
  display: inline-flex !important;
  min-width: 0 !important;
  min-height: 38px !important;
}

.site-header.top-header-fixed .m2-header-auth__login,
.site-header.white-bg .m2-header-auth__login,
.site-header.light-mode-texts .m2-header-auth__login {
  color: #fff !important;
}

.site-header.top-header-fixed .m2-header-auth__register,
.site-header.white-bg .m2-header-auth__register,
.site-header.light-mode-texts .m2-header-auth__register,
.site-header.top-header-fixed .headerphone-number.m2-header-auth__register,
.site-header.white-bg .headerphone-number.m2-header-auth__register,
.site-header.light-mode-texts .headerphone-number.m2-header-auth__register {
  color: var(--m2-dark) !important;
  background: rgba(85, 200, 232, 0.1) !important;
  border-color: rgba(85, 200, 232, 0.45) !important;
}

.site-header.top-header-fixed .m2-header-auth__register:hover,
.site-header.white-bg .m2-header-auth__register:hover,
.site-header.light-mode-texts .m2-header-auth__register:hover {
  color: var(--m2-dark) !important;
  background: rgba(85, 200, 232, 0.18) !important;
  border-color: rgba(85, 200, 232, 0.65) !important;
}

.site-header.top-header-fixed .m2-header-auth-mobile,
.site-header.white-bg .m2-header-auth-mobile,
.site-header.light-mode-texts .m2-header-auth-mobile {
  border-color: rgba(85, 200, 232, 0.45);
  background: rgba(85, 200, 232, 0.1);
  color: var(--m2-dark) !important;
}

.site-header.top-header-fixed .m2-header-auth-mobile:hover,
.site-header.white-bg .m2-header-auth-mobile:hover,
.site-header.light-mode-texts .m2-header-auth-mobile:hover {
  border-color: rgba(85, 200, 232, 0.65);
  background: rgba(85, 200, 232, 0.18);
  color: var(--m2-dark) !important;
}

.site-header.site-header--absolute.top-header-fixed {
  height: auto !important;
  min-height: 72px;
  padding-top: 8px;
  padding-bottom: 8px;
}

/* Legacy override — keep if old markup slips through */
.site-header .signup-btn-header.btn-red {
  background-color: var(--m2-cyan) !important;
  border-color: var(--m2-cyan-deep) !important;
}
.site-header .signup-btn-header.btn-red:hover {
  background-color: var(--m2-cyan-bright) !important;
}

/* ============================================================
   M2 FOOTER — brand alignment with m2.ist frontend
   ============================================================ */

/* ---------- Layout grid (ported from m2.ist frontend footer) ---------- */
.footer-section .m2-footer-grid {
  align-items: stretch;
}
.footer-section .m2-footer-grid > .d-flex {
  align-items: stretch;
}

/* Brand logo */
.footer-section .m2-footer-logo > a > img {
  height: 56px !important;
  max-height: 56px !important;
  width: auto;
}
.footer-section .m2-footer-logo > a > img.m2-footer-logo-img {
  height: 72px !important;
  max-height: 72px !important;
  max-width: 300px;
  object-fit: contain;
}

/* Contact chips */
.footer-section .m2-footer-contact {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-section .m2-footer-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(85, 200, 232, 0.28);
  background: rgba(5, 20, 31, 0.55);
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 12px;
  text-decoration: none !important;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.footer-section .m2-footer-chip:hover {
  color: #fff !important;
  border-color: rgba(85, 200, 232, 0.55);
  background: rgba(85, 200, 232, 0.12);
}
.footer-section .m2-footer-chip i { color: var(--m2-cyan-bright); font-size: 13px; }

/* About paragraph */
.footer-section .m2-footer-about {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1.9;
}
.footer-section .m2-footer-about strong { color: var(--m2-cyan-bright); font-weight: 600; }

.footer-section .m2-footer-social {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.footer-section .footer-social-accounts.m2-footer-social li .btn {
  width: 38px;
  height: 38px;
  line-height: 38px;
  margin: 0;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(85, 200, 232, 0.28);
  background: rgba(5, 20, 31, 0.55);
  color: rgba(255, 255, 255, 0.92);
  font-size: 15px;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.footer-section .footer-social-accounts.m2-footer-social li .btn:hover {
  background: rgba(85, 200, 232, 0.16);
  border-color: rgba(85, 200, 232, 0.55);
  color: var(--m2-cyan-bright);
  transform: translateY(-2px);
}

/* "منطقة العميل" highlighted link */
.footer-section .m2-footer-eco-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: #fff !important;
  text-decoration: none !important;
  padding: 10px 14px;
  margin-bottom: 14px;
  border-radius: 12px;
  border: 1px solid rgba(85, 200, 232, 0.28);
  background: rgba(85, 200, 232, 0.08);
  transition: border-color 0.2s ease, background 0.2s ease;
}
.footer-section .m2-footer-eco-all:hover {
  border-color: rgba(85, 200, 232, 0.55);
  background: rgba(85, 200, 232, 0.14);
}
.footer-section .m2-footer-eco-all i { color: var(--m2-cyan-bright); }

/* Two sub-columns of links with subheads */
.footer-section .m2-footer-eco-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 28px;
}
.footer-section .m2-footer-subhead {
  display: block;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: rgba(85, 200, 232, 0.85);
  margin: 14px 0 4px;
}
.footer-section .m2-footer-eco-col .m2-footer-subhead:first-child { margin-top: 0; }

/* Footer links: cyan on hover */
.footer-section .footer-list-link {
  color: rgba(255, 255, 255, 0.72) !important;
  transition: color 0.18s ease, padding-inline-start 0.18s ease;
}
.footer-section .footer-list li:hover .footer-list-link,
.footer-section .footer-list-link:hover {
  color: var(--m2-cyan-bright) !important;
  padding-inline-start: 4px;
}

/* Social account chips: cyan hover */
.footer-social-accounts a:hover {
  background-color: var(--m2-cyan) !important;
  border-color: var(--m2-cyan) !important;
  color: #fff !important;
}

/* CTA card */
.footer-section .m2-footer-cta-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  padding: 28px 24px;
  border-radius: 20px;
  border: 1px solid rgba(85, 200, 232, 0.22);
  background: rgba(5, 20, 31, 0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.22);
  min-height: 100%;
  direction: rtl;
  text-align: right;
}
.footer-section .m2-footer-cta-body { flex: 1 1 auto; margin-bottom: 24px; }
.footer-section .m2-footer-cta-card h4 { color: #fff; font-weight: 700; }
.footer-section .m2-footer-cta-card p { color: rgba(255, 255, 255, 0.62); line-height: 1.75; }
.footer-section .m2-footer-cta-card p strong { color: var(--m2-cyan-bright); font-weight: 600; }
.footer-section .m2-footer-cta-points li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: rgba(255, 255, 255, 0.58);
  line-height: 1.65;
  margin-bottom: 10px;
}
.footer-section .m2-footer-cta-points li:last-child { margin-bottom: 0; }
.footer-section .m2-footer-cta-points li i {
  color: var(--m2-cyan-bright);
  font-size: 11px;
  margin-top: 5px;
  flex-shrink: 0;
}

/* CTA button (m2-btn) */
.footer-section a.m2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 24px;
  border: 1px solid rgba(85, 200, 232, 0.45);
  border-radius: 12px;
  background: linear-gradient(135deg, #55c8e8 0%, #3da9cc 100%);
  color: #05141f !important;
  font-weight: 700;
  font-size: 13px;
  line-height: 1;
  margin-top: auto;
  box-shadow: 0 4px 16px rgba(85, 200, 232, 0.28);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  text-decoration: none !important;
}
.footer-section a.m2-btn:hover,
.footer-section a.m2-btn:focus {
  background: linear-gradient(135deg, #6dd4ef 0%, #55c8e8 100%);
  color: #05141f !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(85, 200, 232, 0.38);
}

@media (max-width: 575px) {
  .footer-section .m2-footer-eco-cols { grid-template-columns: 1fr; gap: 0; }
}

/* Bottom signature — ported from m2.ist frontend (custom.css .m2-signature) */
.footer-section .m2-footer-bottom {
  border-top: 1px solid rgba(85, 200, 232, 0.12) !important;
  margin-top: 8px;
}
.footer-section .m2-signature {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 14px;
  letter-spacing: 0.2px;
}
.footer-section .m2-signature__logo {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.footer-section .m2-signature__logo:hover {
  opacity: 0.85;
  transform: translateY(-1px);
}
.footer-section .m2-signature__logo img {
  height: 18px !important;
  max-height: 18px !important;
  width: auto;
  display: block;
  border-radius: 4px;
}
.footer-section .m2-signature__mark {
  display: inline-flex;
  width: 16px;
  height: 16px;
  color: var(--m2-cyan-bright);
  filter: drop-shadow(0 0 6px rgba(85, 200, 232, 0.55));
  animation: m2-sig-pulse 3.4s ease-in-out infinite;
}
.footer-section .m2-signature__mark svg {
  width: 100%;
  height: 100%;
  display: block;
}
@keyframes m2-sig-pulse {
  0%, 100% { transform: scale(1) rotate(0deg); opacity: 0.9; }
  50%      { transform: scale(1.12) rotate(45deg); opacity: 1; }
}
.footer-section .m2-signature__tag,
.footer-section .m2-signature__tag strong {
  color: #fff;
  font-size: 13px;
  font-weight: 700;
}
.footer-section .m2-signature__year {
  color: rgba(255, 255, 255, 0.85);
  font-size: 13px;
}
@media (prefers-reduced-motion: reduce) {
  .footer-section .m2-signature__mark { animation: none; }
}

/* Footer top wave + gradient: deepen toward brand ink */
.footer-gradient-default {
  background: linear-gradient(160deg, #07182a 0%, var(--m2-ink) 55%, var(--m2-ink-deep) 100%) !important;
  flex-shrink: 0;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

/* ---------- Sticky footer: no light band below dark footer (short pages) ---------- */
/* html only — dark safety net for overscroll / sub-pixel gaps; body stays theme light */
html:has(body.m2-ca-active),
html:has(body.not-login-page:not(.this-is-login-page):not(.m2-page-register)) {
  background-color: var(--m2-ink-deep);
}

body.m2-ca-active,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
}

body.m2-ca-active .site-wrapper,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) .site-wrapper {
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
}

body.m2-ca-active .site-wrapper > #main-body,
body.m2-ca-active .site-wrapper > section#main-body,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) .site-wrapper > #main-body,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) .site-wrapper > section#main-body {
  flex: 1 0 auto;
}

body.m2-ca-active .site-wrapper > .footer-gradient-default,
body.m2-ca-active > .footer-gradient-default,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) .site-wrapper > .footer-gradient-default,
body.primary-bg-color.not-login-page:not(.this-is-login-page):not(.m2-page-register) > .footer-gradient-default {
  flex-shrink: 0;
  margin-top: auto;
}

/* White decorative wave at footer bottom — hidden (can bleed light on some viewports) */
.footer-gradient-default > .bg-wave-box-end {
  display: none !important;
}
