/* ==========================================================================
   SupportHost — WHMCS Nexus Child Theme (supporthost-v2)
   Custom CSS
   
   Design System:
   - Font: DM Sans (body/headings) + JetBrains Mono (numbers/data)
   - Colors: zinc scale, green #2dc799, green-dark #1e8566
   - Style: matching supporthost.com — clean, modern, accessible
   
   Table of Contents:
   --------------------------------------------------------------------------
   1. Fonts (@font-face)
   2. Variables
   3. SupportHost custom variables
   4. Body
   5. Header
   6. Footer
   7. Forms
   8. Sidebar
   9. Login / Auth pages
   10. Tables & pagination
   11. Specific pages
   12. Mobile menu
   13. cart
   ========================================================================== */












/* ==========================================================================
   1. FONTS
   ========================================================================== */

@font-face {
  font-family: "DM Sans";
  src: url("../fonts/dm-sans/DMSans-VariableFont_opsz,wght.woff2") format("woff2");
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "JetBrains Mono";
  src: url("../fonts/jetbrains-mono/JetBrainsMono-VariableFont_wght.woff2") format("woff2");
  font-weight: 100 800;
  font-style: normal;
  font-display: swap;
}















/* ==========================================================================
   2. VARIABLES
   ========================================================================== */

:root {
  /* ── Text ── */
  --text: #09090b;
  --text-inverted: #fff;
  --text-muted: #a1a1aa;
  --text-lifted: #71717a;
  --text-accented: #52525b;

  /* ── Borders ── */
  --border-muted: #e4e4e7;
  --border: #d4d4d8;
  --border-lifted: #a1a1aa;
  --border-accented: #52525b;

  /* ── Backgrounds ── */
  --bg: #fff;
  --bg-muted: #fafafa;
  --bg-lifted: #f4f4f5;
  --bg-accented: #e4e4e7;
  --bg-inverted: #09090b;

  /* ── Grayscale ── */
  --grayscale: #18181b;
  --grayscale-lifted: #27272a;
  --grayscale-accented: #3f3f46;

  /* ── Neutral ── */
  --neutral: #71717a;
  --neutral-lifted: #52525b;
  --neutral-accented: #3f3f46;

  /* ── Secondary ── */
  --secondary: #71717a;

  /* ── Success → green SupportHost ── */
  --success: #2dc799;
  --success-accented: #1e8566;

  /* ── Info ── */
  --info: #3b82f6;
  --info-accented: #1d4ed8;

  /* ── Notice → purple SupportHost ── */
  --notice: #6754e2;
  --notice-lifted: #5b45d1;

  /* ── Warning → orange SupportHost ── */
  --warning: #fca249;
  --warning-accented: #d97706;

  /* ── Error ── */
  --error: #ef4444;
  --error-lifted: #dc2626;

  /* ── Additional colors ── */
  --yellow-200: #fff085;
  --yellow-300: #ffdf20;
  --teal-300: #6ee7b7;
  --teal-400: #2dc799;
  --emerald-300: #2dc799;
  --pink-400: #fb64b6;

  /* ── Rounding ── */
  --rounding-sm: 4px;
  --rounding-md: 8px;
  --rounding-lg: 20px;

  /* ── Other ── */
  --letter-spacing: 0em;
  --disabled-opacity: 25%;
}















/* ==========================================================================
   3. SUPPORTHOST CUSTOM VARIABLES (for our custom rules)
   ========================================================================== */

:root {
  /* Colors */
  --sh-green: #2dc799;
  --sh-green-dark: #1e8566;
  --sh-green-light: #ecfdf5;
  --sh-purple: #6754e2;
  --sh-purple-light: #e8e1fc;
  --sh-orange: #fca249;
  --sh-orange-light: #FEEEDE;
  --sh-blue: #3b82f6;
  --sh-blue-light: #eff6ff;
  --sh-black: #09090b;

  /* Gradients */
  --sh-grad-green: linear-gradient(135deg, #1e8566, #2dc799);
  --sh-grad-dark-green: linear-gradient(135deg, #0f1f1a, #1a2e28);
  --sh-grad-dark-hero: linear-gradient(160deg, #09090b 0%, #0d2920 40%, #112e24 60%, #09090b 100%);

  /* Fonts */
  --sh-font: "DM Sans", sans-serif;
  --sh-mono: "JetBrains Mono", monospace;
}















/* ==========================================================================
   4. BODY / CONTAINER / SPACING
   ========================================================================== */

body {
  font-family: var(--sh-font);
  height: auto;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body, section#main-body, .master-breadcrumb, .master-breadcrumb .breadcrumb {
  background-color: var(--bg);
}

.container {
  max-width: 1280px;
}

@media (max-width: 1199.98px) {
  .navbar-expand-xl > .container {
    padding-right: 15px;
    padding-left: 15px;
  }
}

#main-body {
  padding: 28px 0 40px;
}
















/* ==========================================================================
   5. HEADER
   ========================================================================== */

/* -- Logo ---------------------------------------------------------------- */

.logo-img {
  width: 180px;
  height: auto;
}

@media (max-width: 991px) {
  .logo-img {
    width: 120px;
  }
}

/* -- Topbar (logged in) -------------------------------------------------- */

#header .topbar {
  background-image: var(--sh-grad-dark-hero);
  border-bottom: 1px solid rgba(45, 199, 153, 0.08);
  font-family: var(--sh-font);
  font-size: 12px;
  padding: 6px 0;
}

#header .topbar .container .d-flex {
  align-items: center;
}

#header .topbar .btn {
  color: rgba(255, 255, 255, 0.85);
  font-size: 12px;
  font-weight: 400;
  padding: 4px 10px;
}

#header .topbar .btn:hover {
  color: #fff;
}

#header .topbar .input-group-text {
  background: transparent;
  border: none;
  color: rgba(255, 255, 255, 0.85);
  font-size: 12px;
  padding: 4px 8px 4px 0;
}

#header .topbar .fad::after, #header .topbar .fad::before {
  color: rgba(255, 255, 255, 0.85);
}
#header .topbar .fad::after {
  opacity: var(--fa-secondary-opacity, 0.7);
}

#header .topbar .btn-group .btn:hover .fad::after, #header .topbar .btn-group .btn:hover .fad::before {
    color: var(--sh-green) !important;
}

header.header .topbar .active-client .btn.btn-active-client span {
  border-bottom: none;
}

#header .topbar .btn-group .btn.btn-active-client {
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
  font-size: 12px;
  text-decoration: none;
}

#header .topbar .btn-group .btn.btn-active-client:hover {
  text-decoration: none;
  color: #fff;
}

#header .topbar .btn-group .btn {
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
}

#header .topbar .btn-group .btn:hover {
  color: var(--sh-green);
}

#header .topbar .btn-group {
  align-items: center;
}

/* -- Header bar ---------------------------------------------------------- */

#header .navbar.navbar-light {
  background: var(--bg);
  border-bottom: 1px solid var(--border-muted);
  padding: 5px 0;
}

#header .navbar .container {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 14px;
  padding-bottom: 14px;
  align-items: center;
  flex-wrap: nowrap;
}

#header .navbar-brand {
  margin-right: 32px;
}

/* -- Nav bar ------------------------------------------------------------- */

#nav {
    gap: 5px;
}

header.header .navbar-nav {
    margin-bottom: 8px;
}

/* -- Nav links ----------------------------------------------------------- */

#header .navbar-nav .nav-link,
#header #mainNavbar .navbar-nav > li > a {
  font-family: var(--sh-font);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-accented);
  padding: 7px 10px;
  border-radius: 6px;
  transition: color 0.15s, background-color 0.15s;
  white-space: nowrap;
  text-decoration: none;
}

#header .navbar-nav .nav-link:hover,
#header #mainNavbar .navbar-nav > li > a:hover {
  color: var(--text);
  background-color: var(--bg-lifted);
}

#header .navbar-nav .nav-item.active > .nav-link,
#header .navbar-nav .nav-link.active {
  color: var(--sh-green-dark);
  font-weight: 600;
}

/* -- Hide nav icons ------------------------------------------------------ */

#header #mainNavbar .navbar-nav > li > a > i {
  display: none;
}

/* -- "Hello, name!" (secondary nav) --------------------------------------- */

#header #mainNavbar .navbar-nav.ml-auto > li > a {
  color: var(--text);
  font-weight: 500;
}

#header #mainNavbar .navbar-nav.ml-auto > li > a > i {
  display: inline-block;
  color: var(--sh-green-dark);
  margin-right: 4px;
}

/* -- Toolbar (cart + language) ------------------------------------------- */

#header .toolbar {
  margin-left: 10px;
}

#header .toolbar .cart-btn {
  position: relative;
  color: var(--text-lifted);
  padding: 6px;
}

#header .toolbar .cart-btn:hover {
  color: var(--text);
}

#header .toolbar .cart-btn > i {
  display: inline-block !important;
  font-size: 16px;
}

#header .toolbar .cart-btn .badge {
  background: var(--sh-green-dark);
  color: var(--text-inverted);
  font-size: 9px;
  font-weight: 700;
  position: absolute;
  min-width: 16px;
  height: 16px;
  line-height: 16px;
  padding: 0 4px;
  border-radius: 99px;
  top: -2px;
  right: -4px;
}

header.header .toolbar .nav-link {
  border: none;
}

/* -- Dropdown menus ------------------------------------------------------ */

#header #mainNavbar .dropdown-menu {
  font-family: var(--sh-font);
  background: var(--bg);
  border: 1px solid var(--border-muted);
  border-radius: var(--rounding-md);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  padding: 6px;
  min-width: 200px;
  margin-top: 4px;
}

#header #mainNavbar .dropdown-menu .dropdown-item {
  padding: 2px 0;
}

header.header .dropdown-item:active {
    background-color: transparent;
}

#header #mainNavbar .dropdown-menu .dropdown-item a {
  display: block;
  padding: 7px 12px !important;
  font-size: 13px;
  font-weight: 400;
  color: var(--text-accented);
  border-radius: 5px;
  text-decoration: none;
  transition: color 0.12s, background-color 0.12s;
}

#header #mainNavbar .dropdown-menu .dropdown-item a:hover {
  color: var(--text);
  background-color: var(--bg-lifted);
}

#header #mainNavbar .dropdown-menu .dropdown-item a i {
  display: none;
}

#header #mainNavbar .dropdown-menu .dropdown-divider {
  border-color: var(--border-muted);
  margin: 4px 8px;
}

/* -- Language picker ------------------------------------------------------ */

#header .language-picker {
  display: flex;
  align-items: center;
  padding: 5px 7px;
  border-radius: 5px;
  transition: transform 0.12s;
  margin-left: 8px;
}

#header .language-picker:hover {
  transform: scale(1.1);
}

#header .language-picker img {
  width: 20px;
  height: auto;
}

/* -- Language picker ------------------------------------------------------ */

.master-breadcrumb .breadcrumb {
  margin: 10px 0 0;
  font-size: 13px;
}

















/* ==========================================================================
   6. FOOTER
   ========================================================================== */

#footer.footer {
  background: var(--bg-inverted);
  border-top: 1px solid rgba(45, 199, 153, 0.06);
  padding: 24px 0;
  margin-top: auto;
}


#footer .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}

#footer .nav {
  gap: 4px;
}

#footer .nav .nav-link {
  font-family: var(--sh-font);
  font-size: 13px;
  color: #a1a1aa;
  padding: 4px 4px;
  transition: color 0.12s;
}

#footer .nav .nav-link:hover {
  color: var(--text-inverted);
}

#footer .copyright {
  font-family: var(--sh-font);
  font-size: 11px;
  color: #71717a;
  width: 100%;
  text-align: center;
  padding-top: 14px;
  margin-top: 6px;
  border-top: 1px solid #27272a;
}

/* -- Currency picker ----------------------------------------------------- */

.sh-footer-right {
  display: flex;
}

#footer .currency {
  display: flex;
  align-items: center;
  gap: 2px;
}

#footer .currency p {
  margin: 0;
}

#footer .currency .currency-picker {
  font-family: var(--sh-font);
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.3);
  padding: 4px 8px;
  border-radius: 4px;
  text-decoration: none;
  transition: color 0.12s, background-color 0.12s;
  display: block;
}

#footer .currency .currency-picker.active,
#footer .currency p.active .currency-picker {
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
}

#footer .currency .currency-picker:hover {
  color: #fff;
}

#footer .currency a.currency-picker {
  color: rgba(255, 255, 255, 0.3);
}

#footer .currency a.currency-picker:hover {
  color: #fff;
}

/* -- Social icons -------------------------------------------------------- */

#footer .sh-footer-socials {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-left: 8px;
}

#footer .sh-footer-socials a {
  color: var(--sh-green);
  display: flex;
  transition: all 0.3s;
}

#footer .sh-footer-socials a:hover {
  transform: scale(1.1);
}

#footer .sh-footer-socials svg {
  width: 24px;
  height: 24px;
}














/* ==========================================================================
   7. FORMS
   ========================================================================== */

/* -- Form controls (input, select, textarea) ----------------------------- */

.form-control {
  font-family: var(--sh-font);
  font-size: 13px;
  border: 1px solid var(--border-muted);
  border-radius: var(--rounding-md);
  padding: 10px 14px;
  color: var(--text);
  height: auto;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-control:focus {
  border-color: var(--sh-green);
  box-shadow: 0 0 0 3px rgba(45, 199, 153, 0.1);
  outline: none;
}

/* -- Chrome autofill override -------------------------------------------- */

.form-control:-webkit-autofill,
.form-control:-webkit-autofill:hover,
.form-control:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #fff inset !important;
  -webkit-text-fill-color: var(--text) !important;
}

/* -- Select -------------------------------------------------------------- */

select.form-control {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%2371717a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

/* -- Labels -------------------------------------------------------------- */

.form-group label,
.form-control-label,
.col-form-label,
p.form-text {
  font-family: var(--sh-font);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-accented);
  margin-bottom: 5px;
}

/* -- Input group --------------------------------------------------------- */

.input-group .input-group-text {
  background: var(--bg-lifted);
  border: 1px solid var(--border-muted);
  border-right: none;
  border-radius: var(--rounding-md) 0 0 var(--rounding-md);
  color: var(--text-muted);
  font-size: 13px;
}

.input-group .form-control {
  border-radius: 0 var(--rounding-md) var(--rounding-md) 0;
}

.input-group > :first-child {
  border-radius: var(--rounding-md) 0 0 var(--rounding-md);
}

.input-group .input-group-append .btn {
  border: 1px solid var(--border-muted);
  border-left: none;
  border-radius: 0 var(--rounding-md) var(--rounding-md) 0;
  padding-top: 10px;
  padding-bottom: 10px;
}

/* -- Radio buttons ------------------------------------------------------- */

.form-check-input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid var(--border);
  border-radius: 50%;
  background: var(--bg);
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  margin-top: -2px;
  transition: border-color 0.12s;
}

.form-check-input[type="radio"]:checked {
  border-color: var(--sh-green);
  background: var(--sh-green);
}

.form-check-input[type="radio"]:checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 7px;
  height: 7px;
  background: #fff;
  border-radius: 50%;
}

/* -- Checkboxes ---------------------------------------------------------- */

.form-check-input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 2px solid var(--border);
  border-radius: 4px;
  background: var(--bg);
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  margin-top: -2px;
  transition: all 0.12s;
}

.form-check-input[type="checkbox"]:checked {
  border-color: var(--sh-green);
  background: var(--sh-green);
}

.form-check-input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 5px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* -- Form check label ---------------------------------------------------- */

.form-check label {
  font-family: var(--sh-font);
  font-size: 13px;
  color: var(--text-accented);
}

/* -- Custom file input --------------------------------------------------- */

.custom-file-label {
  font-family: var(--sh-font);
  font-size: 13px;
  border: 1px solid var(--border-muted);
  border-radius: var(--rounding-md);
  padding: 10px 14px;
  color: var(--text-lifted);
  height: 42px;
}
.custom-file-label::after {
    height: auto;
    padding: 0.75rem .75rem;
}

/* -- Alerts -------------------------------------------------------------- */

.alert {
  font-family: var(--sh-font);
  font-size: 13px;
  border-radius: var(--rounding-md);
}












/* ==========================================================================
   8. BUTTONS
   ========================================================================== */

/* -- Base ---------------------------------------------------------------- */

.btn {
  font-family: var(--sh-font);
  font-weight: 600;
  border-radius: var(--rounding-md);
  transition: all 0.2s;
  font-size: 13px;
  padding: 10px 20px;
}

.btn-sm {
  font-size: 12px;
  padding: 5px 12px;
  font-weight: 500;
  border-radius: 6px;
}

.btn-xs {
  font-size: 11px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 5px;
}

/* -- Primary ------------------------------------------------------------- */

.btn-primary:not(.btn-sm) {
  background: var(--sh-grad-green);
  border: none;
  color: #fff;
}

.btn-primary:not(.btn-sm):hover,
.btn-primary:not(.btn-sm):focus {
  background: var(--sh-grad-green);
  color: #fff;
  opacity: 0.85;
}

.md-editor .btn-primary:hover {
  opacity: 0.85;
}

/* -- Default / Secondary ------------------------------------------------- */

.btn-default {
  background: var(--bg);
  color: var(--text);
  border: 1.5px solid var(--border-muted);
}

.btn-default:hover {
  border-color: var(--text);
  color: var(--text);
  background: var(--bg);
}

/* -- Info / Secondary ------------------------------------------------- */

.btn-info {
  background: var(--sh-blue-light);
  border: 1.5px solid var(--sh-blue);
  color: var(--sh-blue);
}

.btn-info:hover {
  background: var(--sh-blue);
  border-color: var(--sh-blue);
  color: #fff;
}

/* -- Success (used in domain register) ----------------------------------- */

.btn-success {
  background: var(--sh-green);
  border-color: var(--sh-green);
  color: #fff;
}

.btn-success:hover {
  background: var(--sh-green-dark);
  border-color: var(--sh-green-dark);
  color: #fff;
}

/* -- Inside input-group: no shadow, no scale ----------------------------- */

.input-group .btn {
  box-shadow: none;
}

.input-group .btn:not(.btn-return-to-admin):hover {
  transform: none;
  box-shadow: none;
}

/* -- Inside service buttons: compact ------------------------------------- */

.div-service-buttons .btn-sm {
  font-size: 11px;
  padding: 5px 10px;
}

/* -- Inside service buttons: compact ------------------------------------- */

.btn-group-sm .btn {
  font-weight: 400;
}

/* -- Select2 ------------------------------------- */

.select2-container--default .select2-selection--single {
    background-color: #fff !important;
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    height: 36px !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #626262 !important;
    line-height: 32px !important;
    font-size: 13px;
    font-weight: 400;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 34px !important;
}















/* ==========================================================================
   8. SIDEBAR
   ========================================================================== */

.sidebar .card-sidebar {
  margin-bottom: 16px !important;
}

.sidebar .card-header {
  padding: 12px 16px;
  color: var(--text);
  border-bottom: 1px solid var(--border);
}

.sidebar .card-header h3 {
  font-size: 14px;
  font-weight: 600;
}

.sidebar .card-body {
  font-size: 13px;
  color: var(--text-accented);
  line-height: 1.7;
}

.sidebar .card-body strong, .sidebar .card-body b {
  font-weight: 600;
  color: var(--text);
}

body .sidebar .btn-success, body .sidebar .btn-default {
    background: var(--bg);
    color: var(--text);
    border-color: var(--border);
    border-radius: var(--rounding-md);
    padding: 8px;
}

body .sidebar .btn-success:hover, body .sidebar .btn-default:hover {
    background: var(--bg);
    border-color: var(--text);
}

.sidebar .list-group-item {
    padding: 12px 16px;
    font-size: 13px;
    color: var(--text-accented);
    line-height: 1.7;
    border-bottom: 1px solid #f4f4f5;
}















/* ==========================================================================
   LOGIN / AUTH PAGES
   ========================================================================== */

/* -- Dark background ----------------------------------------------------- */

body.page-auth {
  background: var(--sh-grad-dark-hero);
  min-height: 100vh;
}

body.page-auth #main-body {
  padding-top: 40px;
  padding-bottom: 40px;
}

body.page-auth section#main-body, body.page-auth .master-breadcrumb, body.page-auth .master-breadcrumb .breadcrumb, body.page-auth #footer.footer, body.page-auth header.header, body.page-auth #header .navbar.navbar-light {
  background-color: transparent !important;
}

/* -- Header on auth pages: simpler -------------------------------------- */

body.page-auth #header .navbar.navbar-light {
  border-bottom: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

@media (min-width: 1199.98px) {
  body.page-auth #header #mainNavbar .navbar-nav > li > a, body.page-auth #header .toolbar .cart-btn {
    color: rgba(255, 255, 255, 0.85) !important;
  }
  
  body.page-auth #header #mainNavbar .navbar-nav > li > a:hover, body.page-auth #header .toolbar .cart-btn:hover {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.06);
  }
}

body.page-auth #header .navbar-brand .logo-img {
  filter: brightness(0) invert(1);
}

/* -- Hide breadcrumb on auth pages --------------------------------------- */

body.page-auth .master-breadcrumb {
  display: none;
}

/* -- Auth card ----------------------------------------------------------- */

body.page-auth .primary-content .card {
  border: none;
  border-radius: 14px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.04);
  max-width: 420px;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

body.page-auth .primary-content .card-body {
  padding: 36px 32px 28px;
}

/* -- Auth title ---------------------------------------------------------- */

body.page-auth .primary-content .card-body h3,
body.page-auth .primary-content .card-body .h3,
body.page-auth .primary-content .card-body h6 {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text);
  margin-bottom: 2px;
}

body.page-auth .primary-content .card-body p {
  font-size: 13px;
  color: var(--text-lifted);
  margin-bottom: 22px;
}

/* -- Auth form inputs ---------------------------------------------------- */

body.page-auth .primary-content .form-control {
  font-size: 13px;
  padding: 10px 12px;
  border: 1.5px solid var(--border-muted);
  border-radius: 8px;
}

body.page-auth .primary-content .form-control:focus {
  border-color: var(--sh-green);
  box-shadow: 0 0 0 3px rgba(45, 199, 153, 0.1);
}

body.page-auth .card .input-group-prepend {
  display: none;
}

body.page-auth .input-group .input-group-append .btn {
  border: none;
}

body.page-auth .btn-default.focus, body.page-auth .btn-default:focus {
  background-color: transparent;
}

body.page-auth .card a.btn-default {
  width: 100%;
  margin-top: 15px;
  color: var(--text);
}

body.page-auth .card .btn-default:hover {
  text-decoration: none;
}

body.page-auth .card .card-body label, body.page-auth .card .card-body a {
  font-size: 13px;
}

body.page-auth .login-form .input-group-append {
    margin-left: 0;
}

body .login-form #inputPassword:focus {
    border-right: 1.5px solid var(--sh-green);
}

/* -- Auth button: full width with shadow --------------------------------- */

body.page-auth .primary-content .btn-primary {
  width: 100%;
  padding: 12px;
  font-size: 14px;
  box-shadow: 0 4px 18px rgba(45, 199, 153, 0.22);
}

body.page-auth .primary-content .btn-primary:hover {
  box-shadow: 0 8px 32px rgba(45, 199, 153, 0.32);
  transform: translateY(-1px);
}

/* -- Auth layout: button and remember me --------------------------------- */

body.page-auth .primary-content .float-left,
body.page-auth .primary-content .text-right {
  float: none !important;
  text-align: center !important;
  width: 100%;
}

body.page-auth .primary-content .float-left .btn-primary {
  margin-bottom: 12px;
}

body.page-auth .primary-content .text-right label {
  font-weight: 400;
  color: var(--text-lifted);
  font-size: 12px;
}

/* -- Auth links ---------------------------------------------------------- */

body.page-auth .primary-content a {
  color: var(--sh-green-dark);
  font-weight: 500;
}

body.page-auth .primary-content a:hover {
  text-decoration: underline;
}

/* -- Auth card footer ---------------------------------------------------- */

body.page-auth .primary-content .card-footer {
  background: var(--bg-muted);
  border-top: 1px solid var(--bg-lifted);
  padding: 14px 32px;
  text-align: center;
  font-size: 12px;
  color: var(--text-lifted);
}

body.page-auth .primary-content .card-footer a {
  color: var(--sh-green-dark);
  font-weight: 600;
}

/* -- Auth footer --------------------------------------------------------- */

body.page-auth #footer.footer {
  border-top: 1px solid rgba(255, 255, 255, 0.03);
}












/* ==========================================================================
   10. TABLES & PAGINATION
   ========================================================================== */

/* -- Table container ----------------------------------------------------- */

.table-container {
  background: var(--bg);
  border: 1px solid var(--border-muted);
  border-radius: var(--rounding-md);
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* -- DataTables toolbar (info + search) ---------------------------------- */

.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info {
  font-family: var(--sh-font);
  font-size: 12px;
  color: var(--text-lifted);
  padding: 12px 18px;
}

.dataTables_wrapper .dataTables_filter input {
  font-family: var(--sh-font);
  font-size: 12px;
  border: 1px solid var(--border-muted);
  border-radius: 6px;
  padding: 6px 10px;
  outline: none;
  transition: border-color 0.15s;
  margin-left: 6px;
}

.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--sh-green);
  box-shadow: 0 0 0 3px rgba(45, 199, 153, 0.1);
}

body .dataTables_wrapper .dataTables_filter::after {
  display: none;
}

body .dataTables_wrapper .dataTables_filter label {
  position: relative;
}

body .dataTables_wrapper .dataTables_filter label::after {
    font-family: "Font Awesome 6 Pro";
    font-size: 14px;
    content: "\f002";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    pointer-events: none;
}

/* -- Table  -------------------------------------------------------------- */

body .dataTables_wrapper table.table-list, body .dataTables_wrapper table.table-list thead th:last-child, body .dataTables_wrapper table.table-list thead th:first-child {
  border-radius: 0;
}

.dataTables_wrapper table.table-list {
  border: none;
}

body .dataTables_wrapper table.table-list {
  border-bottom: 1px solid var(--border-muted);
}

/* -- Table header -------------------------------------------------------- */

.table-container table thead th {
  font-family: var(--sh-font);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-lifted);
  padding: 10px 18px;
  border-bottom: 1px solid var(--border-muted);
  background: var(--bg-lifted);
  white-space: nowrap;
  text-align: left !important;
}

/* -- Table rows ---------------------------------------------------------- */

.table-container table tbody tr {
  border-bottom: 1px solid var(--bg-lifted);
  transition: background 0.08s;
  cursor: pointer;
}

.table-container table tbody tr:hover {
  background: var(--bg-muted);
}

.table-container table tbody td {
  /* font-family: var(--sh-font); */
  font-size: 13px;
  padding: 12px 18px;
  vertical-align: middle;
  color: var(--text);
  text-align: left !important;
}

.table-container table tbody td strong {
  font-weight: 600;
}

#tableServicesList tbody td > a, #tableDomainsList tbody td > a {
  font-family: var(--sh-mono);
  color: var(--text-lifted);
  font-size: 12px;
}

.table-container table tbody td[data-order] {
  font-family: var(--sh-mono);
  font-weight: 600;
  font-size: 12px;
}

.table-container table tbody td[data-order] small {
  font-family: var(--sh-mono);
  font-weight: 400;
  font-size: 10px;
}

.table-container table tbody .tbl-date {
  color: var(--text-accented);
}

.ticket-subject.unread {
    font-weight: 600;
}

/* -- Status badges ------------------------------------------------------- */

.table-container .status {
  background: var(--neutral) !important;
  color: var(--bg) !important;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 99px;
}

.table-container .status-suspended, .table-container .status-unpaid {
  background: #fef2f2 !important;
  color: var(--error) !important;
}

.table-container .status-pending, .table-container .status-refunded, .table-container .status-custom {
  background: var(--sh-orange-light) !important;
  color: var(--sh-orange) !important;
}

.table-container .status-active, .table-container .status-paid, .table-container .status-accepted, .table-container .status-open {
  background: var(--sh-green-light) !important;
  color: var(--sh-green-dark) !important;
}

.table-container .status-cancelled, .table-container .status-terminated, .table-container .status-closed {
  background: var(--bg-lifted) !important;
  color: var(--text-lifted) !important;
}

/* -- Mostra voci (length) ------------------------------------------------ */

.dataTables_wrapper .dataTables_length {
  font-family: var(--sh-font);
  font-size: 12px;
  color: var(--text-lifted);
  padding: 12px 18px;
}

.dataTables_wrapper .dataTables_length select {
  font-family: var(--sh-font);
  font-size: 12px;
  border: 1px solid var(--border-muted);
  border-radius: 5px;
  padding: 4px 8px;
  margin: 0 4px;
}

/* -- Pagination ---------------------------------------------------------- */

.dataTables_wrapper .dataTables_paginate {
  padding: 12px 18px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
  font-family: var(--sh-font);
  font-size: 12px;
  font-weight: 500;
  transition: all 0.12s;
}

.dataTables_wrapper .dataTables_paginate .paginate_button a:hover {
  background: var(--bg-muted) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.active a {
  background: var(--sh-green-dark) !important;
  border-color: var(--sh-green-dark) !important;
  color: #fff !important;
  font-weight: 600;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled {
  opacity: 0.4;
}

.page-link:focus {
    box-shadow: none;
}

/* -- Other tables ---------------------------------------------------------- */

.table.table-striped {
  border: 1px solid var(--border-muted);
}













/* ==========================================================================
   11. SPECIFIC PAGES
   ========================================================================== */

.card.view-ticket .card-body {
  border-radius: 0;
}

.label-info {
  background: var(--sh-blue-light);
  border: 1.5px solid var(--sh-blue);
  color: var(--sh-blue);
}

/* -- Affiliate stat ----------------------------------------------------- */

.affiliate-stat {
  background: var(--bg) !important;
  border: 1px solid var(--border-muted) !important;
  border-radius: var(--rounding-md);
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: var(--text-accented) !important;
  font-family: var(--sh-font);
  font-size: 13px;
  font-weight: 500;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  transition: all 0.2s;
}

.affiliate-stat:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  border-color: var(--border) !important;
}

.affiliate-stat i {
  font-size: 24px;
  margin-bottom: 10px;
  opacity: 0.6;
}

.affiliate-stat span {
  font-family: var(--sh-mono);
  font-size: 32px;
  font-weight: 700;
  display: block;
  margin-bottom: 4px;
}

/* -- Colors per stat ----------------------------------------------------- */

.affiliate-stat.alert-warning {
  border-top: 3px solid var(--sh-orange) !important;
}

.affiliate-stat.alert-warning i,
.affiliate-stat.alert-warning span {
  color: #b45309;
}

.affiliate-stat.alert-info {
  border-top: 3px solid var(--sh-blue) !important;
}

.affiliate-stat.alert-info i,
.affiliate-stat.alert-info span {
  color: var(--sh-blue);
}

.affiliate-stat.alert-success {
  border-top: 3px solid var(--sh-green) !important;
}

.affiliate-stat.alert-success i,
.affiliate-stat.alert-success span {
  color: var(--sh-green-dark);
}

/* -- Box dashboard --------------------------------------------------------- */

.tiles .tile {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 18px 20px;
  background: var(--bg);
  border: 1px solid var(--border-muted);
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: all 0.2s;
  border-radius: var(--rounding-md) !important;
  margin: 0 10px;
}

.tiles .row .col-6:first-child .tile, .tiles .row .col-xl-3:first-child .tile {
  margin-left: 0;
}

.tiles .row>div:last-child .tile {
  border: 1px solid var(--border-muted);
  margin-right: 0;
}

.tiles .tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  border-color: var(--border);
}

/* Round corners only on outer edges */
.tiles .row .col-6:first-child .tile,
.tiles .row .col-xl-3:first-child .tile {
  border-radius: var(--rounding-md) 0 0 var(--rounding-md);
}

.tiles .row .col-6:last-child .tile,
.tiles .row .col-xl-3:last-child .tile {
  border-radius: 0 var(--rounding-md) var(--rounding-md) 0;
}

/* Icon */
.tiles .tile > i {
  font-size: 18px;
  opacity: 0.4;
  margin-bottom: 8px;
}

/* Number */
.tiles .tile .stat {
  font-family: var(--sh-mono);
  font-size: 36px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 3px;
}

/* Label */
.tiles .tile .title {
  font-family: var(--sh-font);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Highlight bar at bottom */
.tiles .tile .highlight {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
}

/* -- Colors per tile ----------------------------------------------------- */

/* Blue (Servizi) */
.tiles .tile .highlight.bg-color-blue {
  background: var(--sh-blue) !important;
}
.tiles .tile:has(.bg-color-blue) .stat,
.tiles .tile:has(.bg-color-blue) .title {
  color: var(--sh-blue);
}
.tiles .tile:has(.bg-color-blue) > i {
  color: var(--sh-blue);
}

/* Green (Domini) */
.tiles .tile .highlight.bg-color-green {
  background: var(--sh-green) !important;
}
.tiles .tile:has(.bg-color-green) .stat,
.tiles .tile:has(.bg-color-green) .title {
  color: var(--sh-green-dark);
}
.tiles .tile:has(.bg-color-green) > i {
  color: var(--sh-green-dark);
}

/* Red (Ticket) */
.tiles .tile .highlight.bg-color-red {
  background: var(--error) !important;
}
.tiles .tile:has(.bg-color-red) .stat,
.tiles .tile:has(.bg-color-red) .title {
  color: var(--error);
}
.tiles .tile:has(.bg-color-red) > i {
  color: var(--error);
}

/* Gold (Fatture) */
.tiles .tile .highlight.bg-color-gold {
  background: var(--sh-orange) !important;
}
.tiles .tile:has(.bg-color-gold) .stat,
.tiles .tile:has(.bg-color-gold) .title {
  color: #b45309;
}
.tiles .tile:has(.bg-color-gold) > i {
  color: #b45309;
}

/* -- Card accents (top border) ------------------------------------------- */

.client-home-cards .card {
  border-radius: var(--rounding-md);
  overflow: hidden;
  margin-bottom: 20px;
}

.client-home-cards .card-accent-gold {
  border-top: 3px solid var(--sh-orange);
}

.client-home-cards .card-accent-blue {
  border-top: 3px solid var(--sh-blue);
}

.client-home-cards .card-accent-purple {
  border-top: 3px solid var(--sh-purple);
}

.client-home-cards .card-accent-teal {
  border-top: 3px solid var(--sh-green);
}

.client-home-cards .card-accent-emerald {
  border-top: 3px solid var(--sh-green-dark);
}

.client-home-cards .card-accent-midnight-blue {
  border-top: 3px solid #1e40af;
}

.client-home-cards .card-accent-red {
  border-top: 3px solid var(--error);
}

/* -- Card header --------------------------------------------------------- */

.client-home-cards .card-header {
  background: var(--bg);
  border-bottom: 1px solid var(--border-muted);
  padding: 12px 18px;
}

.client-home-cards .card-header .card-title {
  font-family: var(--sh-font);
  font-size: 13px;
  font-weight: 500;
}

/* -- Card header buttons (pillole soft) ---------------------------------- */

.client-home-cards .card-header .btn {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 99px;
  border: none;
}

.client-home-cards .card-header .btn:hover {
  opacity: 0.8;
}

.client-home-cards .card-header .bg-color-gold {
  background: var(--sh-orange-light) !important;
  color: #b45309 !important;
}

.client-home-cards .card-header .bg-color-blue {
  background: var(--sh-blue-light) !important;
  color: var(--sh-blue) !important;
}

.client-home-cards .card-header .bg-color-purple {
  background: var(--sh-purple-light) !important;
  color: var(--sh-purple) !important;
}

.client-home-cards .card-header .bg-color-teal {
  background: var(--sh-green-light) !important;
  color: var(--sh-green-dark) !important;
}

.client-home-cards .card-header .bg-color-emerald {
  background: var(--sh-green-light) !important;
  color: var(--sh-green-dark) !important;
}

.client-home-cards .card-header .bg-color-midnight-blue {
  background: var(--sh-blue-light) !important;
  color: #1e40af !important;
}

/* -- Service list items -------------------------------------------------- */

.client-home-cards .list-group-item {
  border-color: var(--border-muted);
  font-family: var(--sh-font);
  padding: 10px 18px;
  transition: background 0.08s;
}

.client-home-cards .list-group-item:hover {
  background: var(--bg-muted);
}

/* -- Service name & domain ----------------------------------------------- */

.client-home-cards .div-service-name .font-weight-bold {
  font-size: 13px;
}

.client-home-cards .div-service-name .text-domain {
  font-family: var(--sh-mono);
  font-size: 11px;
  color: var(--text-lifted);
}

/* -- Status labels ------------------------------------------------------- */

.client-home-cards .label-success {
  background: var(--sh-green-light) !important;
  color: var(--sh-green-dark) !important;
  border-radius: 99px;
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
}

/* -- Card body text ------------------------------------------------------ */

.client-home-cards .card-body {
  font-family: var(--sh-font);
  font-size: 13px;
  color: var(--text-accented);
  padding: 14px 18px;
}

/* -- Card corrections ------------------------------------------------------ */

#ticketsPanel .client-home-cards .list-group {
  max-height: 270px;
}

.client-home-cards .font-weight-bold {
  font-weight: 600 !important;
}

.client-home-cards .btn-view-details {
  font-weight: 400 !important;
}

.client-home-cards button.btn.btn-sm.btn-default.dropdown-toggle {
  margin-left: -1px;
}

/* -- Registration page ------------------------------------------------------ */

.marketing-email-optin {
    display: none;
}
















/* ==========================================================================
   MOBILE MENU
   ========================================================================== */

@media (max-width: 1199.98px) {

  /* -- Mobile menu bars color -------------------------------------------- */

  body.page-auth #header .navbar-nav .nav-link .fas {
    color: rgba(255, 255, 255, 0.85) !important;
  }

  #header #mainNavbar .navbar-nav > li > a {
    color: var(--text);
  }

  /* -- Keep logo and toolbar on same row --------------------------------- */

  #header .navbar .container {
    flex-wrap: wrap;
  }

  #header .navbar-brand {
    flex: 0 0 auto;
  }

  #header .toolbar {
    order: 2;
    margin-left: auto;
  }

  /* -- Collapse takes full width below logo ------------------------------ */

  #header #mainNavbar {
    order: 3;
    flex-basis: 100%;
    padding: 8px 0;
    background: var(--bg);
    margin-top: 20px;
  }

  /* -- Nav links vertical ------------------------------------------------ */

  #header #mainNavbar .navbar-nav {
    flex-direction: column;
    gap: 5px;
  }

  #header #mainNavbar .navbar-nav > li > a {
    padding: 10px 0;
    border-radius: 0;
    font-size: 15px;
  }

  /* -- Dropdowns inline, no card style ----------------------------------- */

  #header #mainNavbar .dropdown-menu {
    position: static !important;
    float: none !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 0 4px 16px !important;
    margin: 0 !important;
    min-width: 0 !important;
    border-radius: 0 !important;
  }

  #header #mainNavbar .dropdown-menu .dropdown-item {
    padding: 0 !important;
  }

  #header #mainNavbar .dropdown-menu .dropdown-item a {
    padding: 8px 0 !important;
    border-radius: 0 !important;
    font-size: 14px;
    color: var(--text-lifted) !important;
  }

  #header #mainNavbar .dropdown-menu .dropdown-item a:hover {
    background: transparent !important;
    color: var(--text) !important;
  }

  #header #mainNavbar .dropdown-divider {
    margin: 4px 0 !important;
    border-color: var(--border-muted) !important;
  }

  #header .navbar-nav .nav-link:hover, #header #mainNavbar .navbar-nav > li > a:hover {
    background-color: transparent;
  }

  /* -- Hide duplicate logo inside navbar collapse ------------------------ */

  #header .navbar.main-navbar-wrapper.whmcs-menu ul#nav a.logo {
      display: none;
  }

  /* -- Hide user menu icon ----------------------------------------------- */

  #header #mainNavbar .navbar-nav.ml-auto > li > a > i {
    display: none;
  }
}















/* ==========================================================================
   CART
   ========================================================================== */
.cart-sidebar .card-sidebar .list-group {
  padding: 20px;
}

.cart-body .select2-container--default .select2-selection--single {
  height: 41.5px !important;
}

.cart-body .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 38px !important;
}

.cart-body .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 38px !important;
}

#domainregister .btn, #domaintransfer .btn, #domainowndomain .btn, #domainincart .btn, #domainsubdomain .btn {
  height: 40.5px;
}

body #order-standard_cart .cart-body {
  padding: 0 15px !important;
}

.select2-container {
  width: 100% !important;
}

.addon-promo-container-symantec a, .upsell-geotrust_truebizidev {
  display: none;
}

#btnDomainContinue {
  background: var(--sh-grad-green);
  margin: 0 auto;
}

#btnDomainContinue:hover {
  opacity: 0.65;
}

.btn-xs.dropdown-toggle .dropdown-menu .dropdown-item {
  font-size: 12px;
}

ul.dropdown-menu.continueShopping {
  padding: 15px 0;
}

.summary-container .dropdown {
  margin-top: 10px;
}

.dropdown-menu.continueShopping li a, .item-price .dropdown-menu a {
  font-size: 12px;
  padding: 3px 20px;
  white-space: nowrap;
}

.applyPromo .btn {
    font-weight: 500;
}

.dropdown-item {
    padding: 0;
}