/*
 * Mirrazone — thème pour template Nexus (WHMCS)
 * Aligné sur le design du site marketing mirrazone.fr
 */

:root {
  --violet-deep: #340a73;
  --violet:      #451093;
  --violet-mid:  #5d24b8;
  --violet-soft: #8b6ee8;
  --violet-tint: #ece6ff;
  --violet-glass: rgba(69,16,147,.82);
  --bg:          #faf8ff;
  --ink:         #15093d;
  --ink-soft:    #4a3a7a;
  --line:        #e3dcf4;
  --line-soft:   #efebfa;
  --paper:       #ffffff;
  --footer-bg:   #0f0530;
  --whatsapp:    #25d366;
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-pill: 999px;
  --shadow-sm: 0 1px 2px rgba(15,5,48,.04);
  --shadow-md: 0 8px 24px -10px rgba(52,10,115,.18);
  --shadow-lg: 0 24px 60px -20px rgba(52,10,115,.28);
  --shadow-pop: 0 30px 80px -24px rgba(52,10,115,.32);
  --ease-out: cubic-bezier(.2,.8,.2,1);
  /* hauteurs header (utilisées partout : padding body, sticky tops, scroll-margin) */
  --header-h:           136px; /* topbar 32 + navbar 104 */
  --header-h-no-topbar: 104px;
  --header-h-scrolled:   96px; /* topbar 32 + pill 64 */
  --header-h-md:        120px; /* mobile */
  --header-h-md-no-topbar: 88px;
}

/* ============ ACCESSIBILITY ============ */
.mz-skip-link {
  position: fixed;
  top: -100px;
  left: 12px;
  z-index: 10000;
  background: white;
  color: var(--violet);
  padding: 10px 16px;
  border-radius: var(--r-md);
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 8px 24px -10px rgba(52,10,115,.4);
  transition: top .15s var(--ease-out);
}
.mz-skip-link:focus {
  top: 12px;
  color: var(--violet);
  outline: 2px solid var(--violet);
  outline-offset: 2px;
}

:focus-visible {
  outline: 2px solid var(--violet);
  outline-offset: 2px;
  border-radius: 4px;
}
.header :focus-visible,
.footer :focus-visible {
  outline-color: white;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    animation-delay: 0ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .status-pulse,
  .mz-hero .eyebrow .dot,
  .quota-fill { animation: none !important; }
}

/* ============ BASE ============ */
* { box-sizing: border-box; }

html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
body {
  padding-top: var(--header-h);
  background:
    radial-gradient(ellipse 900px 600px at 85% -10%, rgba(139,110,232,.16), transparent 70%),
    radial-gradient(ellipse 700px 500px at -10% 30%, rgba(69,16,147,.08), transparent 60%),
    var(--bg);
  background-attachment: fixed;
  overflow-x: hidden;
  scroll-padding-top: var(--header-h);
}
body:not(:has(.header .topbar)) { padding-top: var(--header-h-no-topbar); scroll-padding-top: var(--header-h-no-topbar); }

::selection { background: var(--violet); color: white; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(69,16,147,.18);
  border-radius: 999px;
  border: 2px solid var(--bg);
}
::-webkit-scrollbar-thumb:hover { background: rgba(69,16,147,.32); }

a { color: var(--violet); transition: color .15s var(--ease-out); }
a:hover { color: var(--violet-deep); text-decoration: none; }

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.02em;
  font-weight: 600;
  color: var(--ink);
}

p, li, label, .form-text, .small, small { color: var(--ink); }
.text-muted { color: var(--ink-soft) !important; }

hr { border-color: var(--line); }

/* ============ HEADER / NAVBAR ============ */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1030;
  background: var(--violet);
  transition: top .3s var(--ease-out), background .3s var(--ease-out);
}
.header.scrolled {
  top: 14px;
  background: transparent;
  border-bottom-color: transparent;
}
/* container devient pill flottante quand scrolled — comme le site marketing */
.header .navbar.navbar-light .container,
.header.scrolled .navbar.navbar-light .container {
  transition: max-width .3s var(--ease-out),
              height .3s var(--ease-out),
              padding .3s var(--ease-out),
              background .3s var(--ease-out),
              backdrop-filter .3s var(--ease-out),
              border-radius .3s var(--ease-out),
              border-color .3s var(--ease-out),
              box-shadow .3s var(--ease-out);
}
.header.scrolled .navbar.navbar-light .container {
  max-width: 1240px;
  height: 68px;
  padding: 0 22px;
  background: var(--violet-glass);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  box-shadow: 0 12px 40px rgba(15,5,48,.28);
}

.header .topbar {
  background: rgba(0,0,0,.14);
  border-bottom: 1px solid rgba(255,255,255,.08);
  font-size: 13px;
  color: rgba(255,255,255,.85);
  padding: 6px 0;
  overflow: hidden;
  max-height: 60px;
  opacity: 1;
  transition: max-height .3s var(--ease-out), opacity .25s var(--ease-out), padding .3s var(--ease-out), border-color .3s var(--ease-out);
}
.header.scrolled .topbar {
  background: rgba(0,0,0,.22);
  border-color: transparent;
}
.header .topbar .d-flex { align-items: center; }
.header .topbar a { color: rgba(255,255,255,.85); transition: color .15s var(--ease-out); }
.header .topbar a:hover { color: white; }

/* groupe gauche topbar : retour + notifications */
.header .topbar .topbar-left {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* bouton retour vers mirrazone.fr — pill discret → blanc plein au hover, halo violet */
.header .topbar .topbar-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  color: white;
  font-weight: 600;
  letter-spacing: -0.01em;
  text-decoration: none;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 1px 0 rgba(255,255,255,.08) inset;
  transition: background .2s var(--ease-out), color .2s var(--ease-out), border-color .2s var(--ease-out), box-shadow .2s var(--ease-out), transform .15s var(--ease-out);
  white-space: nowrap;
}
.header .topbar .topbar-back:hover,
.header .topbar .topbar-back:focus-visible {
  background: white;
  color: var(--violet);
  border-color: white;
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 0 0 4px rgba(139,110,232,.22), 0 8px 22px rgba(52,10,115,.30);
}
.header .topbar .topbar-back:active {
  transform: translateY(0);
  box-shadow: 0 0 0 3px rgba(139,110,232,.18);
}
.header .topbar .topbar-back-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex: 0 0 auto;
  background: rgba(255,255,255,.18);
  transition: transform .25s var(--ease-out), background .2s var(--ease-out);
}
.header .topbar .topbar-back svg {
  width: 13px;
  height: 13px;
  display: block;
}
.header .topbar .topbar-back:hover .topbar-back-arrow {
  background: var(--violet-tint);
  transform: translateX(-3px);
}

@media (max-width: 575px) {
  .header .topbar .topbar-back-label { display: none; }
  .header .topbar .topbar-back { padding: 5px 8px; }
}

/* notification button (gauche) */
.header .topbar > .container > .d-flex > .mr-auto > .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 0;
  color: rgba(255,255,255,.85);
  padding: 6px 12px;
  font-size: 13px;
  border-radius: var(--r-pill);
  font-weight: 500;
  box-shadow: none;
}
.header .topbar > .container > .d-flex > .mr-auto > .btn svg {
  width: 16px;
  height: 16px;
}
.header .topbar > .container > .d-flex > .mr-auto > .btn:hover {
  color: white;
  background: rgba(255,255,255,.1);
}

/* "Connecté en tant que" — pill unifiée */
.header .topbar .active-client {
  display: inline-flex;
  align-items: center;
  gap: 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  padding: 0;
  overflow: hidden;
  font-size: 13px;
  flex-wrap: nowrap;
}
.header .topbar .active-client .input-group-prepend {
  margin: 0;
}
.header .topbar .active-client .input-group-text {
  background: transparent;
  border: 0;
  border-right: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.7);
  padding: 6px 12px;
  font-size: 12.5px;
  border-radius: 0;
  font-weight: 500;
  letter-spacing: .01em;
}
.header .topbar .active-client .btn-group {
  display: inline-flex;
  align-items: center;
  border-radius: 0;
}
.header .topbar .active-client .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: transparent;
  border: 0;
  color: white;
  padding: 6px 12px;
  min-width: 36px;
  min-height: 32px;
  border-radius: 0;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4;
  box-shadow: none;
}
.header .topbar .active-client .btn svg {
  width: 13px;
  height: 13px;
  opacity: .8;
}
.header .topbar .active-client .btn-active-client {
  padding: 6px 14px;
  font-weight: 500;
}
.header .topbar .active-client .btn:hover {
  background: rgba(255,255,255,.12);
  color: white;
  transform: none;
}
.header .topbar .active-client .btn + .btn {
  border-left: 1px solid rgba(255,255,255,.12);
}
.header .topbar .active-client .btn-active-client + .btn { border-left: 1px solid rgba(255,255,255,.12); }
.header .topbar .active-client .btn-return-to-admin {
  background: rgba(255,255,255,.06);
}

.header .navbar { padding: 0; }
.header .navbar.navbar-light .container {
  height: 104px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.navbar-brand,
.navbar-brand:hover {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  color: white !important;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 32px;
  letter-spacing: -0.03em;
  transition: gap .3s var(--ease-out), font-size .3s var(--ease-out);
}
.navbar-brand .logo-img,
.navbar-brand img {
  width: 76px;
  height: 76px;
  border-radius: 14px;
  display: block;
  transition: width .3s var(--ease-out), height .3s var(--ease-out), border-radius .3s var(--ease-out);
}
.header.scrolled .navbar-brand { gap: 12px; font-size: 22px; }
.header.scrolled .navbar-brand .logo-img,
.header.scrolled .navbar-brand img { width: 44px; height: 44px; border-radius: 9px; }

.navbar-nav.toolbar {
  gap: 8px;
  align-items: center;
  display: flex;
  flex-direction: row;
  list-style: none;
  padding: 0;
  margin: 0;
}
.navbar-nav.toolbar .nav-item { list-style: none; }

/* bouton icône rond avec badge corner */
.navbar-nav.toolbar .nav-link,
.navbar-nav.toolbar .btn.nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  color: white !important;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 50%;
  text-decoration: none;
  line-height: 1;
  transition: background .15s var(--ease-out), transform .15s var(--ease-out), border-color .15s var(--ease-out), color .15s var(--ease-out);
}
.navbar-nav.toolbar .nav-link i,
.navbar-nav.toolbar .btn.nav-link i {
  font-size: 16px;
  margin: 0;
}
.navbar-nav.toolbar .nav-link svg,
.navbar-nav.toolbar .btn.nav-link svg {
  width: 18px;
  height: 18px;
  display: block;
}
.navbar-nav.toolbar .nav-link:hover,
.navbar-nav.toolbar .btn.nav-link:hover {
  background: white;
  color: var(--violet) !important;
  border-color: white;
  transform: translateY(-1px);
}
.navbar-nav.toolbar .badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--violet-soft);
  color: white;
  font-weight: 700;
  font-size: 10.5px;
  border-radius: 9px;
  border: 2px solid var(--violet);
  margin: 0;
  transition: border-color .3s var(--ease-out), background .3s var(--ease-out);
  letter-spacing: -.02em;
}
.header.scrolled .navbar-nav.toolbar .badge { border-color: rgba(69,16,147,.95); }
.navbar-nav.toolbar .nav-link:hover .badge {
  border-color: var(--violet);
  background: var(--violet);
  color: white;
}

/* Navigation principale (sous le navbar) */
.mz-mainnav {
  background: rgba(255,255,255,.04);
  border-top: 1px solid rgba(255,255,255,.10);
  border-bottom: 1px solid rgba(255,255,255,.10);
  overflow: hidden;
  max-height: 50px;
  opacity: 1;
  transition: max-height .3s var(--ease-out), opacity .25s var(--ease-out), border-color .3s var(--ease-out);
}
.header.scrolled .mz-mainnav {
  background: rgba(255,255,255,.05);
  border-color: transparent;
}
.mz-mainnav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.mz-mainnav ul {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.mz-mainnav ul.mz-mainnav-right { margin-left: auto; }
.mz-mainnav li { list-style: none; }
.mz-mainnav a,
.mz-mainnav .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 48px;
  padding: 0 14px;
  color: rgba(255,255,255,.78);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  font-size: 14.5px;
  letter-spacing: -.005em;
  border-bottom: 2px solid transparent;
  transition: color .15s var(--ease-out), border-color .15s var(--ease-out), background .15s var(--ease-out);
  text-decoration: none;
}
.mz-mainnav a:hover,
.mz-mainnav .nav-link:hover {
  color: white;
  text-decoration: none;
}
.mz-mainnav a.active,
.mz-mainnav li.active > a,
.mz-mainnav .nav-link.active {
  color: white;
  border-bottom-color: white;
  background: rgba(255,255,255,.06);
}
.mz-mainnav .dropdown-menu {
  background: white;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 12px;
  box-shadow: 0 18px 40px -16px rgba(20,8,52,.25);
  padding: 6px;
  margin-top: 4px;
}
.mz-mainnav .dropdown-item {
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 14px;
  color: var(--violet-deep);
}
.mz-mainnav .dropdown-item:hover {
  background: var(--violet-tint);
  color: var(--violet);
}
@media (max-width: 991px) {
  .mz-mainnav .container {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    mask-image: linear-gradient(90deg, transparent 0, black 16px, black calc(100% - 16px), transparent 100%);
  }
  .mz-mainnav .container::-webkit-scrollbar { display: none; }
  .mz-mainnav ul { flex-wrap: nowrap; }
  .mz-mainnav a { white-space: nowrap; }
}

.header .form-inline .input-group.search {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--r-pill);
  overflow: hidden;
  transition: background .15s var(--ease-out), border-color .15s var(--ease-out);
  width: 320px;
  max-width: 100%;
  flex-wrap: nowrap;
}
@media (max-width: 991px) {
  .header .form-inline .input-group.search { width: 220px; }
}
.header .form-inline .input-group.search:focus-within {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.36);
}
.header .form-inline .input-group.search .form-control {
  background: transparent !important;
  border: 0;
  color: white;
  font-size: 13.5px;
  height: 40px;
  box-shadow: none !important;
  flex: 1 1 auto;
  min-width: 0;
}
.header .form-inline .input-group.search .form-control::placeholder { color: rgba(255,255,255,.6); }
.header .form-inline .input-group.search .input-group-prepend { margin: 0; }
.header .form-inline .input-group.search .btn {
  background: transparent !important;
  border: 0;
  color: rgba(255,255,255,.85);
  padding: 0 8px 0 14px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  box-shadow: none;
}
.header .form-inline .input-group.search .btn:hover { color: white; transform: none; }
.header .form-inline .input-group.search .btn svg { width: 16px; height: 16px; }

/* dropdown menu items quand ils sortent du header violet */
.header .dropdown-menu {
  background: white;
  color: var(--ink);
  border: 1px solid var(--line);
  margin-top: 12px;
}

/* ============ BREADCRUMB ============ */
.master-breadcrumb {
  background: transparent;
  border-bottom: 1px solid var(--line);
  padding: 14px 0;
}
.master-breadcrumb .breadcrumb {
  background: transparent;
  margin: 0;
  padding: 0;
  font-size: 13px;
  color: var(--ink-soft);
}
.master-breadcrumb .breadcrumb a { color: var(--ink-soft); }
.master-breadcrumb .breadcrumb a:hover { color: var(--violet); }
.master-breadcrumb .breadcrumb-item.active { color: var(--ink); font-weight: 500; }
.master-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  content: "/";
  color: var(--ink-soft);
  font-weight: 400;
  opacity: .8;
  margin: 0 6px;
}

/* ============ CONTENU ============ */
#main-body {
  padding: 56px 0 90px;
}

/* ============ BOUTONS ============ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: var(--r-pill);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 600;
  border: 1.5px solid transparent;
  transition: transform .15s var(--ease-out), background .15s var(--ease-out), color .15s var(--ease-out), box-shadow .2s var(--ease-out), border-color .15s var(--ease-out);
  letter-spacing: -0.005em;
}
.btn-lg, .btn-large { padding: 14px 22px; font-size: 15px; }
.btn-sm { padding: 7px 12px; font-size: 12.5px; }

.btn-primary,
.btn-primary:focus {
  background: var(--violet);
  color: white;
  border-color: var(--violet);
  box-shadow: 0 6px 18px -8px rgba(69,16,147,.5);
}
.btn-success,
.btn-success:focus { border-color: #16a34a; }
.btn-danger,
.btn-danger:focus { border-color: #dc2626; }
.btn-warning,
.btn-warning:focus { border-color: #f59e0b; }
.btn-info,
.btn-info:focus { border-color: var(--violet-mid); }
.btn-primary:hover,
.btn-primary:active,
.btn-primary:not(:disabled):not(.disabled):active {
  background: var(--violet-deep) !important;
  color: white !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 26px -10px rgba(52,10,115,.55);
}

.btn-outline-primary,
.btn-outline-primary:focus {
  background: transparent;
  color: var(--violet);
  border: 1.5px solid var(--violet);
  box-shadow: none;
}
.btn-outline-primary:hover {
  background: var(--violet);
  color: white;
  transform: translateY(-1px);
}

.btn-default,
.btn-secondary {
  background: white;
  color: var(--ink);
  border: 1.5px solid var(--line);
}
.btn-default:hover,
.btn-secondary:hover {
  background: var(--violet-tint);
  color: var(--violet);
  border-color: var(--violet-soft);
  transform: translateY(-1px);
}

.btn-success { background: #16a34a; color: white; box-shadow: 0 6px 18px -8px rgba(22,163,74,.4); }
.btn-success:hover { background: #15803d; transform: translateY(-1px); }

.btn-danger { background: #dc2626; color: white; box-shadow: 0 6px 18px -8px rgba(220,38,38,.4); }
.btn-danger:hover { background: #991b1b; transform: translateY(-1px); }

.btn-info { background: var(--violet-mid); color: white; box-shadow: 0 6px 18px -8px rgba(93,36,184,.4); }
.btn-info:hover { background: var(--violet); transform: translateY(-1px); }

.btn-warning { background: #f59e0b; color: #422006; box-shadow: 0 6px 18px -8px rgba(245,158,11,.4); }
.btn-warning:hover { background: #b45309; color: white; transform: translateY(-1px); }

.btn-link { color: var(--violet); padding: 0; box-shadow: none; }
.btn-link:hover { color: var(--violet-deep); text-decoration: none; }

.btn-block { display: flex; width: 100%; justify-content: center; }

/* WhatsApp CTA */
.btn-whatsapp,
.btn-whatsapp:focus {
  background: white;
  color: #128c4f;
  border: 1.5px solid #25d366;
  box-shadow: 0 6px 18px -8px rgba(37,211,102,.4);
}
.btn-whatsapp:hover,
.btn-whatsapp:active,
.btn-whatsapp:not(:disabled):not(.disabled):active {
  background: #25d366 !important;
  color: white !important;
  border-color: #25d366;
  transform: translateY(-1px);
}
.btn-whatsapp svg { flex: 0 0 auto; }

/* CTA navbar (bouton blanc dans la navbar violette) */
.header .btn.btn-primary {
  background: white;
  color: var(--violet);
  box-shadow: 0 4px 14px rgba(0,0,0,.15);
}
.header .btn.btn-primary:hover {
  background: var(--violet-tint) !important;
  color: var(--violet-deep) !important;
}

/* ============ CARTES ============ */
.card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease-out), border-color .25s var(--ease-out), box-shadow .25s var(--ease-out);
  position: relative;
}
.card:hover {
  border-color: var(--violet-soft);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
.card-header {
  background: white;
  border-bottom: 1px solid var(--line);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  letter-spacing: -0.01em;
  padding: 18px 24px;
  font-size: 16px;
}
.card-body { padding: 24px; }
.card-footer {
  background: rgba(236,230,255,.3);
  border-top: 1px solid var(--line);
  padding: 16px 24px;
}
.card-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.pricing-card-title {
  font-size: 26px;
  margin-bottom: 12px;
}

/* Override Bootstrap masonry (column-count) qui clippait les dernières cartes
   quand le nombre changeait (ex : "Transférer votre domaine" disparaissait
   quand un produit était ajouté au panier).
   Grille CSS stable : chaque carte garde sa cellule. */
.card-columns.home {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  column-count: unset;
  column-gap: unset;
  orphans: unset;
  widows: unset;
}
@media (max-width: 991px) {
  .card-columns.home { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .card-columns.home { grid-template-columns: 1fr; }
}
.card-columns.home .card {
  margin-bottom: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  break-inside: unset;
}
.card-columns.home .card .card-body {
  display: flex !important;
  flex-direction: column;
  flex: 1;
}
.card-columns.home .card .card-body .btn { margin-top: auto; }

/* card-accents (homepage) */
.action-icon-btns .col-6 a,
.action-icon-btns .col-md-4 a,
.action-icon-btns a[class*="card-accent-"] {
  display: block;
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px 22px;
  text-align: center;
  color: var(--ink);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
  transition: transform .2s var(--ease-out), border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
  position: relative;
}
.action-icon-btns a[class*="card-accent-"]:hover {
  transform: translateY(-2px);
  border-color: var(--violet-soft);
  box-shadow: 0 12px 28px -14px rgba(52,10,115,.18);
  color: var(--ink);
}
.action-icon-btns a[class*="card-accent-"]:hover .btn { transform: none; }
.action-icon-btns .ico-container {
  width: 52px;
  height: 52px;
  margin: 0 auto 14px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--violet-tint), #f5efff);
  color: var(--violet);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  border: 0;
  transition: background .25s var(--ease-out), color .25s var(--ease-out), transform .25s var(--ease-out);
}
.action-icon-btns .ico-container svg {
  width: 26px;
  height: 26px;
  display: block;
  stroke-width: 1.5;
}
.action-icon-btns a[class*="card-accent-"]:hover .ico-container {
  background: linear-gradient(135deg, var(--violet), var(--violet-mid));
  color: white;
  transform: scale(1.06);
  border-color: transparent;
}
.action-icon-btns figure { margin: 0 0 14px; }

/* Cards en row : grid responsive auto-fit pour layout fiable */
.action-icon-btns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin: 0;
}
.action-icon-btns > [class*="col-"] {
  padding: 0;
  flex: unset;
  max-width: unset;
}
@media (max-width: 600px) {
  .action-icon-btns { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .action-icon-btns > [class*="offset-"] { margin: 0 !important; }
}

/* card-accent variants — chaque carte a sa teinte d'icône distincte */
.action-icon-btns .card-accent-teal           .ico-container { background: linear-gradient(135deg, #ccfbf1, #f0fdfa); color: #0f766e; }
.action-icon-btns .card-accent-pomegranate    .ico-container { background: linear-gradient(135deg, #fee2e2, #fef2f2); color: #b91c1c; }
.action-icon-btns .card-accent-sun-flower     .ico-container { background: linear-gradient(135deg, #fef3c7, #fffbeb); color: #b45309; }
.action-icon-btns .card-accent-asbestos       .ico-container { background: linear-gradient(135deg, #e5e7eb, #f9fafb); color: #4b5563; }
.action-icon-btns .card-accent-green          .ico-container { background: linear-gradient(135deg, #dcfce7, #f0fdf4); color: #15803d; }
.action-icon-btns .card-accent-midnight-blue  .ico-container { background: linear-gradient(135deg, var(--violet-tint), #f5efff); color: var(--violet); }
.action-icon-btns a:hover.card-accent-teal           .ico-container { background: linear-gradient(135deg, #0f766e, #14b8a6); color: white; }
.action-icon-btns a:hover.card-accent-pomegranate    .ico-container { background: linear-gradient(135deg, #b91c1c, #dc2626); color: white; }
.action-icon-btns a:hover.card-accent-sun-flower     .ico-container { background: linear-gradient(135deg, #b45309, #f59e0b); color: white; }
.action-icon-btns a:hover.card-accent-asbestos       .ico-container { background: linear-gradient(135deg, #4b5563, #6b7280); color: white; }
.action-icon-btns a:hover.card-accent-green          .ico-container { background: linear-gradient(135deg, #15803d, #22c55e); color: white; }
.action-icon-btns a:hover.card-accent-midnight-blue  .ico-container { background: linear-gradient(135deg, var(--violet), var(--violet-mid)); color: white; }

/* ============ FORMULAIRES ============ */
.form-control,
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="tel"], input[type="search"],
input[type="url"], textarea, select {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 12px 14px;
  font-size: 14.5px;
  font-family: 'Inter', sans-serif;
  background: white;
  color: var(--ink);
  transition: border-color .15s var(--ease-out), box-shadow .15s var(--ease-out);
}
.form-control:focus,
input:focus, textarea:focus, select:focus {
  border-color: var(--violet);
  outline: none;
  box-shadow: 0 0 0 4px rgba(69,16,147,.12);
  position: relative;
  z-index: 2;
}
.form-control::placeholder { color: rgba(74,58,122,.55); }

label, .control-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 6px;
}
.form-group { margin-bottom: 18px; }

.input-group .input-group-text,
.input-group .input-group-prepend .btn,
.input-group .input-group-append .btn {
  border-radius: var(--r-md);
  border: 1px solid var(--line);
  background: white;
  color: var(--ink-soft);
}
.input-group > .form-control:not(:first-child) { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.input-group > .form-control:not(:last-child)  { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.input-group .input-group-prepend .btn { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.input-group .input-group-append .btn  { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.input-group .input-group-append .btn:not(:last-child) { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.input-group .input-group-prepend .btn:not(:first-child) { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.input-group .input-group-append .btn:last-child  { border-top-right-radius: var(--r-md); border-bottom-right-radius: var(--r-md); }
.input-group .input-group-prepend .btn:first-child { border-top-left-radius: var(--r-md); border-bottom-left-radius: var(--r-md); }
.input-group .input-group-append .btn + .btn { border-left: 1px solid rgba(255,255,255,.18); }
.input-group .input-group-append .btn-outline-primary + .btn-outline-primary,
.input-group .input-group-append .btn-primary + .btn-outline-primary,
.input-group .input-group-append .btn-outline-primary + .btn-primary { border-left: 0; }
.input-group:not(.input-group-lg):not(.input-group-sm) > .form-control,
.input-group:not(.input-group-lg):not(.input-group-sm) > .input-group-prepend > .btn:not(.btn-sm):not(.btn-lg),
.input-group:not(.input-group-lg):not(.input-group-sm) > .input-group-append > .btn:not(.btn-sm):not(.btn-lg) { height: 46px; }
.input-group-lg > .form-control,
.input-group-lg > .input-group-prepend > .btn,
.input-group-lg > .input-group-append > .btn { height: 54px; font-size: 15px; padding-top: 0; padding-bottom: 0; }
.input-group-sm > .form-control,
.input-group-sm > .input-group-prepend > .btn,
.input-group-sm > .input-group-append > .btn { height: 36px; font-size: 13px; padding-top: 0; padding-bottom: 0; }

.custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--violet);
  border-color: var(--violet);
}
.custom-control-input:focus ~ .custom-control-label::before {
  box-shadow: 0 0 0 4px rgba(69,16,147,.18);
}

/* ============ TABLES ============ */
.table {
  background: white;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.table thead th {
  background: linear-gradient(180deg, #faf7ff, #f4f0fc);
  border-bottom: 1px solid var(--line);
  border-top: 0;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: -0.005em;
  color: var(--ink);
  padding: 14px 18px;
  text-transform: none;
}
.table td {
  border-top: 1px solid var(--line-soft);
  padding: 14px 18px;
  vertical-align: middle;
  color: var(--ink);
  font-size: 14px;
}
.table-striped tbody tr:nth-of-type(odd) {
  background: rgba(236, 230, 255, 0.28);
}
.table-hover tbody tr {
  transition: background .15s var(--ease-out);
}
.table-hover tbody tr:hover { background: var(--violet-tint); }

/* ============ ALERTS / BADGES ============ */
.alert {
  border-radius: var(--r-md);
  border: 1px solid var(--line);
  padding: 14px 18px;
  font-size: 14px;
  box-shadow: var(--shadow-sm);
}
.alert-info {
  background: var(--violet-tint);
  border-color: rgba(69,16,147,.18);
  color: var(--violet-deep);
}
.alert-success {
  background: #dcfce7;
  border-color: #86efac;
  color: #15803d;
}
.alert-warning {
  background: #fef3c7;
  border-color: #fcd34d;
  color: #92400e;
}
.alert-danger {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #991b1b;
}

.badge {
  border-radius: var(--r-pill);
  font-weight: 500;
  padding: 4px 10px;
  font-size: 12px;
  letter-spacing: -0.005em;
}
.badge-primary { background: var(--violet); color: white; }
.badge-secondary { background: var(--violet-tint); color: var(--violet); }
.badge-success { background: #dcfce7; color: #15803d; }
.badge-warning { background: #fef3c7; color: #92400e; }
.badge-danger  { background: #fee2e2; color: #991b1b; }
.badge-info    { background: var(--violet-tint); color: var(--violet); }
.badge-dark, .badge-pill.badge-dark { background: var(--ink); color: white; }

/* ============ NAV TABS / PILLS ============ */
.nav-tabs {
  border-bottom: 1px solid var(--line);
}
.nav-tabs .nav-link {
  border: 0;
  border-bottom: 2px solid transparent;
  color: var(--ink-soft);
  font-weight: 500;
  padding: 12px 18px;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.01em;
  transition: color .15s var(--ease-out), border-color .15s var(--ease-out);
}
.nav-tabs .nav-link:hover { color: var(--violet); }
.nav-tabs .nav-link.active {
  color: var(--violet);
  background: transparent;
  border-bottom-color: var(--violet);
}

.nav-pills { gap: 6px; }
.nav-pills .nav-link {
  border-radius: var(--r-pill);
  color: var(--ink-soft);
  padding: 8px 16px;
  transition: background .15s var(--ease-out), color .15s var(--ease-out);
}
.nav-pills .nav-link:hover { color: var(--violet); background: var(--violet-tint); }
.nav-pills .nav-link.active {
  background: var(--violet);
  color: white;
  box-shadow: 0 4px 14px -4px rgba(69,16,147,.4);
}

/* ============ SIDEBAR ============ */
.sidebar {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
}
.sidebar .list-group {
  border: 0;
  border-radius: 0;
}
.sidebar .list-group-item {
  border: 0;
  border-bottom: 1px solid var(--line-soft);
  background: transparent;
  color: var(--ink);
  padding: 12px 12px;
  font-size: 14px;
  border-radius: 8px !important;
  margin-bottom: 0;
  transition: background .15s var(--ease-out), color .15s var(--ease-out), padding-left .15s var(--ease-out);
}
.sidebar .list-group-item:last-child { border-bottom: 0; }
.sidebar .list-group-item:hover {
  background: var(--violet-tint);
  color: var(--violet);
  padding-left: 16px;
}
.sidebar .list-group-item.active {
  background: var(--violet);
  color: white;
  box-shadow: 0 6px 16px -6px rgba(69,16,147,.45);
}
.sidebar h4, .sidebar h5 {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 500;
  margin-bottom: 12px;
}

/* ============ SEARCH DOMAIN BLOCK (homepage) ============ */
#order-standard_cart .domain-checker,
.domain-search-container,
#main-body .domain-checker {
  background:
    radial-gradient(ellipse 600px 300px at 80% 0%, rgba(139,110,232,.4), transparent 70%),
    linear-gradient(140deg, var(--violet) 0%, var(--violet-deep) 100%);
  color: white;
  border-radius: var(--r-xl);
  padding: 56px 44px;
  margin-bottom: 32px;
  box-shadow: var(--shadow-pop);
  position: relative;
  overflow: hidden;
}
.domain-search-container h2,
.domain-checker h2 { color: white; letter-spacing: -0.025em; }
.domain-search-container input[type="text"],
.domain-checker input[type="text"] {
  background: white;
  border: 0;
  border-radius: var(--r-md);
  height: 54px;
  padding: 0 18px;
  font-size: 15px;
  color: var(--ink);
}

/* Bloc domain search en home (Mirrazone, distinct du domain-checker du panier) */
.home-domain-search {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  margin: 24px 0;
  box-shadow: var(--shadow-md);
  overflow: hidden;
  position: relative;
}
.home-domain-search::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft), var(--violet));
}
.home-domain-search h2 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 600;
  letter-spacing: -.025em;
  line-height: 1.2;
  color: var(--ink);
  margin: 0 0 24px;
  text-align: center;
}
.home-domain-search h2 em {
  display: block;
  font-style: normal;
  font-weight: 400;
  color: var(--violet);
}
.home-domain-search .input-group {
  max-width: 720px;
  margin: 0 auto;
}
.home-domain-search .input-group .form-control {
  height: 54px;
  font-size: 15px;
  border: 1px solid var(--line);
  background: white;
}
.home-domain-search .input-group .form-control:focus {
  border-color: var(--violet);
  box-shadow: 0 0 0 4px rgba(69,16,147,.12);
}
.home-domain-search .input-group-append .btn {
  height: 54px;
  font-size: 14.5px;
  padding-left: 22px;
  padding-right: 22px;
}
.home-domain-search .input-group-append .btn-primary {
  background: var(--violet);
  color: white;
  border-color: var(--violet);
}
.home-domain-search .input-group-append .btn-outline-primary {
  background: white;
  color: var(--violet);
  border-color: var(--violet);
  border-left-color: rgba(69,16,147,.3);
}
.home-domain-search .input-group-append .btn-outline-primary:hover {
  background: var(--violet-tint);
  color: var(--violet-deep);
  border-color: var(--violet);
}
.home-domain-search .tld-logos {
  list-style: none;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px;
  padding: 0;
  margin: 28px 0 0;
}
.home-domain-search .tld-logos li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--violet-tint);
  border-radius: var(--r-pill);
  padding: 8px 14px;
  font-size: 13px;
  color: var(--violet-deep);
  font-weight: 500;
}
.home-domain-search .tld-logos img {
  width: 22px;
  height: auto;
  border-radius: 4px;
}
.home-domain-search .btn-link {
  color: var(--violet);
  font-weight: 500;
  font-size: 13px;
}
.home-domain-search .btn-link.float-right {
  display: inline-block;
  margin-top: 16px;
}
@media (max-width: 575px) {
  .home-domain-search { margin: 16px 0; }
  .home-domain-search h2 { font-size: 22px; margin-bottom: 18px; }
  .home-domain-search .btn-link.float-right { float: none !important; display: block; text-align: center; }
}

/* ============ DROPDOWNS ============ */
.dropdown-menu {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
  padding: 8px;
  font-size: 14px;
  margin-top: 8px;
  background: white;
}
.dropdown-item {
  border-radius: 8px;
  padding: 9px 12px;
  color: var(--ink);
  transition: background .12s var(--ease-out), color .12s var(--ease-out);
}
.dropdown-item:hover, .dropdown-item:focus {
  background: var(--violet-tint);
  color: var(--violet);
}
.dropdown-item.active {
  background: var(--violet);
  color: white;
}
.dropdown-divider { border-color: var(--line); }

/* ============ MODALS ============ */
.modal-content {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 30px 80px -20px rgba(52,10,115,.32);
  overflow: hidden;
}
.modal-header {
  border-bottom: 1px solid var(--line);
  padding: 22px 26px;
  background: linear-gradient(180deg, #faf7ff, white);
}
.modal-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.modal-body { padding: 26px; }
.modal-footer {
  border-top: 1px solid var(--line);
  padding: 18px 24px;
  background: rgba(236,230,255,.25);
}

/* ============ FOOTER ============ */
.footer.mz-footer {
  background:
    radial-gradient(ellipse 800px 400px at 90% 0%, rgba(69,16,147,.4), transparent 60%),
    var(--footer-bg);
  color: rgba(255,255,255,.7);
  padding: 56px 0 32px;
  margin-top: 56px;
}
.mz-foot-cols {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 32px;
  margin-bottom: 40px;
}
@media (max-width: 1100px) {
  .mz-foot-cols { grid-template-columns: repeat(4, 1fr); }
  .mz-foot-brand { grid-column: 1 / -1; max-width: 600px; }
}
.mz-foot-brand .brand {
  display: flex;
  align-items: center;
  gap: 16px;
  color: white;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 28px;
  letter-spacing: -0.03em;
  margin-bottom: 18px;
}
.mz-foot-brand .brand img { width: 44px; height: 44px; display: block; border-radius: 10px; }
.mz-foot-brand .tag {
  font-size: 14px;
  max-width: 280px;
  line-height: 1.5;
  color: rgba(255,255,255,.7);
  margin: 0;
}
.mz-foot-cols h4 {
  color: rgba(255,255,255,.95);
  font-size: 13px;
  letter-spacing: .04em;
  margin: 0 0 18px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
}
.mz-foot-cols ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 14px;
}
.mz-foot-cols ul a {
  color: rgba(255,255,255,.78);
  transition: color .15s var(--ease-out), padding-left .15s var(--ease-out);
}
.mz-foot-cols ul a:hover { color: white; padding-left: 4px; }

.mz-foot-line {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 13px;
  color: rgba(255,255,255,.55);
}
.mz-foot-tools {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  padding: 0;
}
.mz-foot-tools .list-inline-item { margin: 0; }
.mz-foot-tools .btn-outline-light {
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: white;
  font-size: 13px;
  transition: background .15s var(--ease-out);
}
.mz-foot-tools .btn-outline-light:hover {
  background: rgba(255,255,255,.15);
}
.mz-foot-tools a {
  color: rgba(255,255,255,.7);
  margin: 0;
  font-size: 16px;
  transition: color .15s var(--ease-out);
}
.mz-foot-tools a:hover { color: white; }

@media (max-width: 980px) {
  .mz-foot-cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .mz-foot-cols { grid-template-columns: 1fr; gap: 28px; }
  .mz-foot-line { flex-direction: column; align-items: flex-start; }
}

/* brand-text à côté du logo dans la navbar */
.navbar-brand .brand-text {
  display: inline-block;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  letter-spacing: -0.03em;
}
@media (max-width: 480px) {
  .navbar-brand .brand-text { display: none; }
}

/* ============ HOMEPAGE HERO (custom) ============ */
.mz-hero {
  position: relative;
  padding: 56px 0 80px;
  overflow: hidden;
  isolation: isolate;
}
.mz-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
  padding-top: 8px;
}
@media (max-width: 991px) {
  .mz-hero-grid { grid-template-columns: 1fr; padding-top: 0; }
}

/* status card (hero visual) */
.mz-hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
}
@media (min-width: 992px) {
  .mz-hero-visual { justify-content: flex-end; }
}
.mz-hero-visual::before {
  content: "";
  position: absolute;
  inset: -40px;
  background: radial-gradient(circle at 70% 30%, rgba(139,110,232,.32), transparent 60%);
  z-index: -1;
  filter: blur(8px);
}
.mz-status-card {
  width: 100%;
  max-width: 440px;
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 20px 22px;
  box-shadow: 0 24px 50px -22px rgba(52,10,115,.18);
  position: relative;
}
.mz-status-card::before {
  content: "";
  position: absolute;
  top: 0; left: 22px; right: 22px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(139,110,232,.5), transparent);
}
.status-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: 12px;
}
.status-pulse {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #2bbf6d;
  box-shadow: 0 0 0 4px rgba(43,191,109,.18);
  animation: mz-pulse 2.4s var(--ease-out) infinite;
}
.status-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: -.01em;
  flex: 1;
}
.status-meta {
  font-family: 'Inter', sans-serif;
  font-size: 11.5px;
  color: var(--ink-soft);
  letter-spacing: 0;
  font-weight: 500;
}
.status-rows {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.status-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 6px;
  border-radius: 10px;
  transition: background .15s var(--ease-out);
}
.status-row .row-label { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.status-row .row-status { flex: 0 0 auto; }
.status-row .row-icon { flex: 0 0 36px; }
.status-row:hover { background: rgba(236,230,255,.5); }
.status-row .row-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--violet-tint), #f5efff);
  color: var(--violet);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(139,110,232,.18);
}
.status-row .row-icon svg { width: 18px; height: 18px; }
.status-row .row-label {
  font-size: 13.5px;
  color: var(--ink);
  font-weight: 500;
}
.status-row .row-status {
  font-size: 11.5px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: var(--r-pill);
  letter-spacing: -.005em;
}
.status-row .row-status.up {
  background: #dcfce7;
  color: #15803d;
}
.status-row .row-status.warn {
  background: #fef3c7;
  color: #92400e;
}
.status-foot {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line-soft);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12.5px;
  color: var(--ink-soft);
  font-family: 'Inter', sans-serif;
}
.status-foot strong {
  color: var(--ink);
  font-weight: 600;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 13.5px;
}
.status-foot .metric-link {
  color: var(--violet);
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 12.5px;
  text-decoration: none;
  transition: transform .15s var(--ease-out);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.status-foot .metric-link:hover { color: var(--violet-deep); transform: translateX(2px); }

/* quota bar */
.status-quota {
  margin-top: 14px;
  padding-top: 0;
}
.quota-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}
.quota-label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink);
}
.quota-value {
  font-family: 'Inter', sans-serif;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-soft);
  letter-spacing: 0;
}
.quota-bar {
  height: 6px;
  background: var(--violet-tint);
  border-radius: var(--r-pill);
  overflow: hidden;
  position: relative;
}
@keyframes mz-quota-grow {
  from { width: 0; }
}
.quota-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft));
  border-radius: inherit;
  animation: mz-quota-grow 1s var(--ease-out) both;
}
.mz-hero::before {
  content: "";
  position: absolute;
  top: -80px;
  right: -120px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(139,110,232,.18), transparent 65%);
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
}
.mz-hero::after {
  content: "";
  position: absolute;
  bottom: -160px;
  left: -100px;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle, rgba(69,16,147,.10), transparent 65%);
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
}
.mz-hero > * { position: relative; z-index: 1; }
.mz-hero .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
}
.mz-hero .eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #2bbf6d; box-shadow: 0 0 0 3px rgba(43,191,109,.16);
}
@keyframes mz-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(43,191,109,.18); }
  50%      { box-shadow: 0 0 0 7px rgba(43,191,109,.06); }
}
.mz-hero h1 {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  font-weight: 600;
  text-wrap: balance;
  margin: 0 0 24px;
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: manual;
}
.mz-hero h1 em,
.mz-hero h1 .accent {
  color: var(--violet);
  font-style: normal;
  font-weight: 600;
  font-family: 'Space Grotesk', sans-serif;
}
.mz-hero h1 em:last-of-type,
.mz-hero h1 .accent:last-of-type {
  color: var(--violet);
  background: linear-gradient(135deg, var(--violet), var(--violet-soft));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@supports not (background-clip: text) {
  .mz-hero h1 em:last-of-type,
  .mz-hero h1 .accent:last-of-type { color: var(--violet); -webkit-text-fill-color: var(--violet); }
}
.mz-hero p.lead {
  margin: 0 0 32px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 620px;
}
.mz-hero .hero-cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.mz-hero .hero-cta .btn { white-space: nowrap; }
@media (max-width: 540px) {
  .mz-hero .hero-cta {
    flex-direction: column;
    align-items: stretch;
  }
  .mz-hero .hero-cta .btn {
    width: 100%;
    justify-content: center;
  }
}

.mz-section-head {
  margin-bottom: 28px;
  text-align: center;
}

/* Tile (KPI/résumé) — réutilisable */
.mz-tile {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.mz-tile::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft));
}
.mz-tile-label {
  font-family: 'Inter', sans-serif;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-soft);
  margin: 0;
}
.mz-tile-value {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 30px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin: 6px 0 0;
}
.mz-tile-value small {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: var(--ink-soft);
  letter-spacing: 0;
}
.mz-tile-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 28px;
}
.mz-tile--cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  grid-column: span 2;
  background: linear-gradient(135deg, var(--violet-tint) 0%, white 60%);
  border-color: rgba(139,110,232,.32);
}
@media (max-width: 720px) {
  .mz-tile--cta { grid-column: auto; }
}
.mz-tile-stack { min-width: 0; }
.mz-tile--cta .mz-tile-stack { flex: 1 1 auto; }

/* Steps (3 étapes — transferer) */
.mz-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 8px;
}
.mz-step {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.mz-step-icon {
  width: 52px;
  height: 52px;
  margin: 0 auto 14px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--violet-tint), #f5efff);
  color: var(--violet);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mz-step-icon svg { width: 26px; height: 26px; display: block; }
.mz-step-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 17px;
  color: var(--ink);
  letter-spacing: -.01em;
  margin: 0 0 8px;
}
.mz-step-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
}

/* Search bar (aide) */
.mz-search-wrap { max-width: 640px; margin: 0 auto 40px; }
.mz-search-wrap .input-group-lg .form-control { background: white; }
.mz-search-wrap .input-group-lg .btn { padding-left: 24px; padding-right: 24px; }

/* Form hint sous input */
.form-hint {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.4;
}

/* Toggle pseudo-switch (lecture seule) */
.mz-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-left: 36px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-soft);
  line-height: 1.2;
}
.mz-toggle::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 16px;
  border-radius: 999px;
  background: var(--line);
  transition: background .15s var(--ease-out);
}
.mz-toggle::after {
  content: "";
  position: absolute;
  left: 2px;
  top: 50%;
  margin-top: -6px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 1px 2px rgba(0,0,0,.18);
  transition: left .15s var(--ease-out);
}
.mz-toggle--on { color: var(--ink); }
.mz-toggle--on::before { background: var(--violet); }
.mz-toggle--on::after { left: 14px; }

.mz-meta {
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 400;
  margin-left: 4px;
}

/* Boutique cards */
.mz-shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  align-items: stretch;
}
.mz-shop-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 28px;
  box-shadow: var(--shadow-sm);
  transition: transform .2s var(--ease-out), border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.mz-shop-card:hover {
  transform: translateY(-2px);
  border-color: var(--violet-soft);
  box-shadow: 0 16px 36px -18px rgba(52,10,115,.2);
}
.mz-shop-card--featured {
  border-color: var(--violet);
  box-shadow: 0 16px 40px -18px rgba(52,10,115,.22);
  background: linear-gradient(160deg, white 0%, rgba(236,230,255,.45) 100%);
}
.mz-shop-tag {
  position: absolute;
  top: -10px;
  left: 24px;
  background: var(--violet);
  color: white;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  letter-spacing: .02em;
}
.mz-shop-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 10px;
}
.mz-shop-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 20px;
  flex: 1;
}
.mz-shop-price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
}
.mz-shop-price-from {
  font-size: 12px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 500;
}
.mz-shop-price-amount {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--violet);
  letter-spacing: -.02em;
  line-height: 1;
}
.mz-shop-price-cycle {
  font-size: 13px;
  color: var(--ink-soft);
}
.mz-shop-cta { align-self: stretch; justify-content: center; }
.mz-shop-cta--soft.btn-outline-primary {
  color: var(--violet-soft);
  border-color: var(--violet-soft);
}
.mz-shop-cta--soft.btn-outline-primary:hover,
.mz-shop-cta--soft.btn-outline-primary:focus {
  background: var(--violet-soft);
  border-color: var(--violet-soft);
  color: white;
}
.mz-section-head .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--violet);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px;
  background: var(--violet-tint);
  border-radius: var(--r-pill);
}
.mz-section-head h2 {
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.025em;
  margin: 0;
  display: block;
}
.mz-section-head h2 em,
.mz-section-head h2 .accent {
  display: block;
  font-style: normal;
  font-weight: 400;
  color: var(--violet);
}

/* ============ POPOVERS / TOOLTIPS ============ */
.popover {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
}
.popover-header {
  background: linear-gradient(180deg, #faf7ff, white);
  border-bottom: 1px solid var(--line);
  font-family: 'Space Grotesk', sans-serif;
}
.tooltip-inner {
  background: var(--ink);
  border-radius: var(--r-sm);
  font-size: 12px;
  font-family: 'Inter', sans-serif;
  padding: 8px 12px;
}
.tooltip .arrow::before { border-top-color: var(--ink) !important; border-bottom-color: var(--ink) !important; }

/* ============ PROGRESS / PAGINATION ============ */
.progress {
  background: var(--violet-tint);
  border-radius: var(--r-pill);
  height: 8px;
  overflow: hidden;
}
.progress-bar {
  background: linear-gradient(90deg, var(--violet), var(--violet-soft));
  border-radius: inherit;
}

.pagination .page-link {
  color: var(--ink);
  border: 1px solid var(--line);
  padding: 8px 14px;
  border-radius: 8px;
  margin: 0 3px;
  transition: background .15s var(--ease-out), color .15s var(--ease-out), border-color .15s var(--ease-out);
}
.pagination .page-item.active .page-link {
  background: var(--violet);
  border-color: var(--violet);
  color: white;
  box-shadow: 0 4px 12px -4px rgba(69,16,147,.4);
}
.pagination .page-link:hover {
  background: var(--violet-tint);
  color: var(--violet);
  border-color: var(--violet-soft);
}

/* ============ KNOWLEDGEBASE / ANNOUNCEMENTS LISTS ============ */
.list-group-item {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  margin-bottom: 8px;
  padding: 16px 18px;
  transition: border-color .15s var(--ease-out), transform .15s var(--ease-out), box-shadow .15s var(--ease-out);
}
.list-group-item:hover {
  border-color: var(--violet-soft);
  transform: translateX(2px);
  box-shadow: var(--shadow-md);
}

/* ============ CHECKBOX / RADIO Bootstrap 4 ============ */
.custom-checkbox .custom-control-label::before,
.custom-radio .custom-control-label::before {
  border-color: var(--line);
}

/* ============ ICONS / FA ============ */
.fal, .far, .fas, .fad {
  color: inherit;
}
.action-icon-btns .ico-container i { font-size: 22px; }

/* ============ MODAL LOCALISATION ============ */
.modal-localisation .item {
  display: block;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  text-align: center;
  color: var(--ink);
  font-weight: 500;
  margin-bottom: 8px;
  transition: background .15s var(--ease-out), color .15s var(--ease-out), border-color .15s var(--ease-out);
}
.modal-localisation .item:hover { background: var(--violet-tint); color: var(--violet); border-color: var(--violet-soft); }
.modal-localisation .item.active {
  background: var(--violet);
  color: white;
  border-color: var(--violet);
}

/* ============ CART / INVOICES ============ */
.invoice-list .badge,
.invoice-status .badge { font-size: 12px; }

/* ============ BACK TO TOP ============ */
.mz-back-to-top {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 1020;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--violet);
  color: white;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  cursor: pointer;
  transition: transform .15s var(--ease-out), background .15s var(--ease-out);
}
.mz-back-to-top:hover { background: var(--violet-deep); transform: translateY(-2px); }
.mz-back-to-top svg { width: 18px; height: 18px; }
.mz-back-to-top[hidden] { display: none; }
@media (max-width: 600px) {
  .mz-back-to-top { width: 40px; height: 40px; bottom: 16px; right: 16px; }
  .mz-back-to-top svg { width: 16px; height: 16px; }
}

/* ============ AUTH CARDS (login / register / pwreset) ============ */
.mz-auth-card {
  max-width: 480px;
  margin: 40px auto !important;
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
  position: relative;
}
.mz-auth-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft), var(--violet));
  z-index: 2;
  border-top-left-radius: var(--r-xl);
  border-top-right-radius: var(--r-xl);
}
.mz-auth-card .card-body { padding: 40px 36px !important; }
.mz-auth-card .mz-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--violet);
  letter-spacing: .12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: var(--violet-tint);
  border-radius: var(--r-pill);
}
.mz-auth-card h6.h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.mz-auth-card .input-group-merge {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: white;
  transition: border-color .15s var(--ease-out), box-shadow .15s var(--ease-out);
  overflow: hidden;
}
.mz-auth-card .input-group-merge:focus-within {
  border-color: var(--violet);
  box-shadow: 0 0 0 4px rgba(69,16,147,.12);
}
.mz-auth-card .input-group-merge .input-group-text {
  background: transparent;
  border: 0;
  color: var(--ink-soft);
  padding-left: 14px;
}
.mz-auth-card .input-group-merge .form-control {
  border: 0;
  box-shadow: none !important;
  background: transparent;
}
.mz-auth-card .input-group-merge .form-control:focus { box-shadow: none !important; }
.mz-auth-card .btn-reveal-pw,
.card.mw-540 .btn-reveal-pw {
  background: transparent;
  border: 0;
  color: var(--ink-soft);
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-width: 40px;
}
.mz-auth-card .btn-reveal-pw:hover,
.card.mw-540 .btn-reveal-pw:hover { color: var(--violet); background: transparent; transform: none; }
.mz-auth-card .btn-reveal-pw svg,
.card.mw-540 .btn-reveal-pw svg { display: block; }
.mz-auth-card .form-group, .card.mw-540 .form-group { margin-bottom: 20px; }
.mz-auth-card .captcha-container, .card.mw-540 .captcha-container {
  margin-bottom: 16px;
  padding: 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}

/* ============ STATUS BADGES (.status WHMCS) ============ */
.status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -.005em;
  border: 1px solid transparent;
  white-space: nowrap;
}
.status::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
/* Active / Paid / Open / Answered (vert) */
.status-active, .status-paid, .status-open, .status-answered, .status-completed {
  background: #dcfce7;
  color: #15803d;
  border-color: #86efac;
}
/* Pending / Draft / In Progress / On Hold (orange) */
.status-pending, .status-draft, .status-inprogress, .status-onhold,
.status-collections, .status-overdue {
  background: #fef3c7;
  color: #92400e;
  border-color: #fcd34d;
}
/* Cancelled / Terminated / Refunded / Expired / Closed (rouge / gris) */
.status-cancelled, .status-terminated, .status-refunded, .status-expired,
.status-fraud, .status-failed {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fca5a5;
}
.status-closed, .status-suspended {
  background: #f3f4f6;
  color: #4b5563;
  border-color: #d1d5db;
}
/* Customer-Reply / Awaiting Reply (violet) */
.status-customer-reply, .status-awaitingreply, .status-active-recurring {
  background: var(--violet-tint);
  color: var(--violet);
  border-color: rgba(139,110,232,.3);
}

/* ============ LEGACY .label (Bootstrap 3) → badge style ============ */
.label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  background: var(--violet-tint);
  color: var(--violet);
}
.label-default { background: #f3f4f6; color: #4b5563; }
.label-primary { background: var(--violet); color: white; }
.label-success { background: #dcfce7; color: #15803d; }
.label-warning { background: #fef3c7; color: #92400e; }
.label-danger  { background: #fee2e2; color: #991b1b; }
.label-info    { background: var(--violet-tint); color: var(--violet); }

/* ============ TABLE-LIST (factures / services / domaines / tickets) ============ */
.table-container {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: var(--shadow-sm);
}
.table-container > .table,
.table-container .table-list { min-width: 640px; }
.table-container > .table,
.table-list {
  margin: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}
.table-list thead th {
  background: linear-gradient(180deg, #faf7ff, #f4f0fc);
  border-top: 0;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -.005em;
  padding: 14px 18px;
  text-transform: none;
}
.table-list tbody tr { transition: background .12s var(--ease-out); }
.table-list tbody tr:hover { background: var(--violet-tint); }
.table-list tbody tr:has(a[href]:not([href="#"])):hover { cursor: pointer; }
.table-list tbody td {
  padding: 16px 18px;
  vertical-align: middle;
  font-size: 14px;
  border-top: 1px solid var(--line-soft);
  color: var(--ink);
}

/* Wrap automatique de toutes les tables WHMCS dans un scroll horizontal mobile */
.primary-content .table:not(.table-list):not(.table-container .table) {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}
.primary-content .table:not(.table-list):not(.table-container .table) > tbody,
.primary-content .table:not(.table-list):not(.table-container .table) > thead { white-space: nowrap; }

/* Tickets — sujet unread mis en avant */
.ticket-subject.unread,
tr.unread .ticket-subject {
  font-weight: 600;
  color: var(--ink);
}
.ticket-subject.unread::before,
tr.unread .ticket-subject::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--violet);
  margin-right: 8px;
  vertical-align: middle;
  box-shadow: 0 0 0 3px rgba(139,110,232,.18);
}
.ticket-number {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12.5px;
  color: var(--ink-soft);
  letter-spacing: -.01em;
}

/* ============ FORMULAIRES — labels et col-form ============ */
.col-form-label, .form-control-label {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}
.controls { display: flex; flex-direction: column; gap: 4px; }
.text-danger { color: #dc2626 !important; font-size: 13px; }

/* DataTables search/length */
.dataTables_filter input,
.dataTables_length select {
  border: 1px solid var(--line) !important;
  border-radius: var(--r-md) !important;
  padding: 8px 12px !important;
  font-size: 13.5px;
}
.dataTables_filter input:focus,
.dataTables_length select:focus {
  border-color: var(--violet) !important;
  box-shadow: 0 0 0 4px rgba(69,16,147,.12) !important;
}
.dataTables_info { font-size: 12.5px; color: var(--ink-soft); }
.dataTables_paginate .paginate_button {
  padding: 6px 12px !important;
  border-radius: 8px !important;
  border: 1px solid var(--line) !important;
  margin: 0 2px;
  background: white !important;
  color: var(--ink) !important;
  cursor: pointer;
}
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
  background: var(--violet) !important;
  color: white !important;
  border-color: var(--violet) !important;
}
.dataTables_paginate .paginate_button:hover {
  background: var(--violet-tint) !important;
  color: var(--violet) !important;
  border-color: var(--violet-soft) !important;
}

/* SSL info card (clientareaproducts) */
.ssl-info {
  background: var(--violet-tint);
  color: var(--violet);
  padding: 8px 12px;
  border-radius: var(--r-md);
  font-size: 12.5px;
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* Service / domain row meta */
.text-muted { color: var(--ink-soft) !important; }

/* ============ INVOICES SUMMARY TILES ============ */
.balance-summary,
.invoices-summary-tile,
.invoice-summary-tile {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}
.balance-summary::before,
.invoice-summary-tile::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft));
}

/* ============ TICKET — replies & attachments ============ */
.attachment-list {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.attachment-list li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--violet-tint);
  color: var(--violet);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 12.5px;
  font-weight: 500;
  border: 1px solid rgba(139,110,232,.2);
}
.attachment-list li a {
  color: var(--violet);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.attachment-list li a:hover { color: var(--violet-deep); }

.attachments .attachment-group {
  border: 1px dashed var(--line);
  border-radius: var(--r-md);
  padding: 14px;
  background: rgba(236,230,255,.25);
}

/* Reply card admin vs client */
.reply-card-admin,
[class*="reply"][class*="admin"] {
  border-left: 3px solid var(--violet);
}

/* Rating stars */
.rating-stars {
  color: #f59e0b;
  display: inline-flex;
  gap: 2px;
}

/* ============ INVOICES — statuts spéciaux inline ============ */
.cancelled {
  text-decoration: line-through;
  color: var(--ink-soft);
}
.collections {
  background: #fef3c7;
  color: #92400e;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  display: inline-block;
}

/* bg-* legacy (Bootstrap 3 invoices badges) */
.bg-default { background: #f3f4f6 !important; color: #4b5563 !important; }
.bg-success { background: #dcfce7 !important; color: #15803d !important; }
.bg-info    { background: var(--violet-tint) !important; color: var(--violet) !important; }
.bg-warning { background: #fef3c7 !important; color: #92400e !important; }
.bg-danger  { background: #fee2e2 !important; color: #991b1b !important; }

/* ============ AUTH (login + register + pwreset) auto-style ============ */
/* Cards d'auth identifiées par leur largeur 540 (Nexus) */
.card.mw-540 {
  max-width: 540px;
  margin: 40px auto !important;
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
  position: relative;
}
.card.mw-540::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft), var(--violet));
  z-index: 2;
  border-top-left-radius: var(--r-xl);
  border-top-right-radius: var(--r-xl);
}
.card.mw-540 .card-body { padding: 40px 36px !important; }
.card.mw-540 .input-group-merge {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: white;
  transition: border-color .15s var(--ease-out), box-shadow .15s var(--ease-out);
  overflow: hidden;
}
.card.mw-540 .input-group-merge:focus-within {
  border-color: var(--violet);
  box-shadow: 0 0 0 4px rgba(69,16,147,.12);
}
.card.mw-540 .input-group-merge .input-group-text {
  background: transparent;
  border: 0;
  color: var(--ink-soft);
  padding-left: 14px;
}
.card.mw-540 .input-group-merge .form-control {
  border: 0;
  box-shadow: none !important;
  background: transparent;
}

/* ============ NOTIFICATIONS POPOVER (header) ============ */
/* Bootstrap popover (injecté dans body, pas de classe spécifique) */
.popover {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
  background: white;
  padding: 0;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  max-width: 360px;
}
.popover-body { padding: 8px; }
.popover .arrow::before, .popover .arrow::after { display: none; }
#accountNotificationsContent {
  min-width: 300px;
}
.client-alerts {
  list-style: none;
  padding: 8px;
  margin: 0;
  max-height: 380px;
  overflow-y: auto;
}
.client-alerts li {
  border-radius: 10px;
  margin-bottom: 4px;
  transition: background .12s var(--ease-out);
}
.client-alerts li:last-child { margin-bottom: 0; }
.client-alerts li:hover { background: var(--violet-tint); }
.client-alerts li a {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  color: var(--ink);
  text-decoration: none;
  font-size: 13.5px;
}
.client-alerts li a i {
  flex: 0 0 auto;
  margin-top: 2px;
  color: var(--violet);
  font-size: 14px;
}
.client-alerts li a .message {
  flex: 1;
  line-height: 1.4;
}
.client-alerts li.none {
  text-align: center;
  color: var(--ink-soft);
  font-size: 13px;
  padding: 24px 12px;
}

/* ============ NETWORK ISSUES BANNER ============ */
.network-issues,
.networkissues {
  background: linear-gradient(90deg, #fef3c7, #fef9c3);
  border: 0;
  border-bottom: 1px solid #fcd34d;
  color: #92400e;
  padding: 12px 0;
  font-size: 13.5px;
  font-weight: 500;
  position: relative;
}
.network-issues::before,
.networkissues::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 8px;
  vertical-align: -3px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2392400e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.3 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/%3E%3Cpath d='M12 9v4M12 17h.01'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
.network-issues a, .networkissues a { color: #92400e; text-decoration: underline; font-weight: 600; }

/* ============ VALIDATE USER / VERIFY EMAIL banners ============ */
.user-verification-banner,
.email-verification-banner,
.validate-user-banner {
  background: var(--violet-tint);
  border: 1px solid rgba(139,110,232,.25);
  border-radius: var(--r-md);
  padding: 14px 18px;
  margin: 16px 0;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 14px;
}
.user-verification-banner .btn,
.email-verification-banner .btn,
.validate-user-banner .btn { margin-left: auto; }

/* ============ EMPTY STATES ============ */
.mz-empty-state,
.no-records-found,
.empty-state {
  text-align: center;
  padding: 56px 24px;
  background: white;
  border: 1px dashed var(--line);
  border-radius: var(--r-lg);
  color: var(--ink-soft);
}
.mz-empty-state h3,
.empty-state h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 8px;
  font-weight: 600;
}
.mz-empty-state p,
.empty-state p {
  font-size: 14px;
  max-width: 420px;
  margin: 0 auto 20px;
}

/* When tables show "no records" message inside */
.dataTables_empty {
  padding: 56px 24px !important;
  text-align: center;
  color: var(--ink-soft);
  font-size: 14px;
}

/* ============ LOADER MIRRAZONE (override fullpage-overlay) ============ */
#fullpage-overlay {
  background: rgba(15,5,48,.4);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
#fullpage-overlay .inner-wrapper {
  background: white;
  border-radius: var(--r-xl);
  padding: 28px 36px;
  box-shadow: var(--shadow-pop);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 14px;
  color: var(--ink);
}
#fullpage-overlay .inner-wrapper img {
  width: 22px;
  height: 22px;
  /* remplacé par un spinner CSS pur via ::before */
  visibility: hidden;
  position: relative;
}
#fullpage-overlay .inner-wrapper::before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2.5px solid var(--violet-tint);
  border-top-color: var(--violet);
  animation: mz-spin .8s linear infinite;
  margin-right: -22px;
}
@keyframes mz-spin { to { transform: rotate(360deg); } }
.fa-spinner.fa-spin,
.spinner-border { color: var(--violet); }

/* ============ PRINT (invoice PDF) ============ */
@media print {
  .header, .footer, .master-breadcrumb, .sidebar,
  .mz-back-to-top, .mz-skip-link,
  #fullpage-overlay, .modal { display: none !important; }
  body {
    padding: 0 !important;
    background: white !important;
    background-image: none !important;
  }
  #main-body { padding: 0 !important; }
  .card, .invoice {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
    page-break-inside: avoid;
  }
  a { color: var(--ink); text-decoration: none !important; }
  .table thead th { background: #f5f5f5 !important; color: black !important; }
  .btn { display: none !important; }
}

/* ============ KBD / SHORTCUTS ============ */
kbd, .kbd {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  background: var(--violet-tint);
  color: var(--violet);
  border: 1px solid rgba(139,110,232,.25);
  border-radius: 5px;
  box-shadow: 0 1px 0 rgba(139,110,232,.18);
  font-weight: 500;
}

/* ============ STANDARD CART (orderforms/standard_cart) ============
   ATTENTION: standard_cart/css/all.min.css est chargé APRÈS mirrazone-theme.css
   (via common.tpl dans le body du viewcart/checkout). Ses règles
   `#order-standard_cart .cart-sidebar { float: left; width: 25% }` ont
   donc la même spécificité (1,1,0) mais arrivent en dernier dans la cascade.
   On contre en doublant l'ID `#order-standard_cart#order-standard_cart`
   (spécificité 2,1,0) pour forcer le grid Mirrazone à gagner.
   ============================================================ */
#order-standard_cart {
  margin: 0 auto;
}
/* Outer row : sidebar catégories (260px) | corps principal (1fr) */
#order-standard_cart#order-standard_cart > .row {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 28px;
  margin: 0;
  align-items: start;
}
/* Row interne : liste articles (1fr) | résumé commande (320px sticky) */
#order-standard_cart#order-standard_cart .row:has(> .secondary-cart-body),
#order-standard_cart#order-standard_cart .row:has(> .secondary-cart-sidebar) {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 28px;
  margin: 0;
  align-items: start;
}
/* Sticky CSS-natif sur le résumé de commande (remplace le JS WHMCS) */
#order-standard_cart#order-standard_cart .secondary-cart-sidebar {
  position: sticky;
  top: calc(var(--header-h) + 8px);
  align-self: start;
}
@media (max-width: 1199px) {
  #order-standard_cart#order-standard_cart > .row { grid-template-columns: minmax(0, 1fr); gap: 0; }
  #order-standard_cart#order-standard_cart .row:has(> .secondary-cart-body),
  #order-standard_cart#order-standard_cart .row:has(> .secondary-cart-sidebar) {
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 20px;
  }
}
@media (max-width: 991px) {
  #order-standard_cart#order-standard_cart > .row { grid-template-columns: minmax(0, 1fr); }
  #order-standard_cart#order-standard_cart .row:has(> .secondary-cart-body),
  #order-standard_cart#order-standard_cart .row:has(> .secondary-cart-sidebar) { grid-template-columns: minmax(0, 1fr); gap: 16px; }
  #order-standard_cart#order-standard_cart .secondary-cart-sidebar { position: static; top: auto; }
}
/* Neutraliser les widths % du standard_cart MAIS PRÉSERVER les `float` originaux.
   Raison: scripts.min.js de WHMCS check `jQuery("#scrollingPanelContainer").css("float")`.
   Si float === "none", le JS active un sticky-scroll qui injecte un margin-top
   dynamique sur la .secondary-cart-sidebar. Dans une CSS Grid, ce margin-top
   parasite casse le layout dès que le panier contient un produit (contenu plus
   long → margin calculé plus grand → cellules grid compressées en colonnes étroites).
   En CSS Grid, `float` sur les enfants est ignoré visuellement, mais
   getComputedStyle().float retourne quand même la valeur déclarée → le JS croit
   qu'il y a un float et n'active PAS son sticky-scroll. La grille prend le relais. */
#order-standard_cart#order-standard_cart .cart-sidebar { float: left; }
#order-standard_cart#order-standard_cart .cart-body { float: right; }
#order-standard_cart#order-standard_cart .secondary-cart-body { float: left; }
#order-standard_cart#order-standard_cart .secondary-cart-sidebar { float: right; }
#order-standard_cart#order-standard_cart .cart-sidebar,
#order-standard_cart#order-standard_cart .cart-body,
#order-standard_cart#order-standard_cart .secondary-cart-body,
#order-standard_cart#order-standard_cart .secondary-cart-sidebar {
  width: auto;
  max-width: 100%;
  min-width: 0;
  padding-left: 0;
  padding-right: 0;
  display: block;
  margin-top: 0 !important;
}
#order-standard_cart#order-standard_cart .cart-body {
  min-width: 0;
  overflow-x: auto;
}
#order-standard_cart#order-standard_cart .secondary-cart-body { min-width: 0; }
/* Sidebar catégories : visible ≥1200px (sinon display:none Nexus prend le relais via media <1199 */
@media (min-width: 1200px) {
  #order-standard_cart#order-standard_cart .cart-sidebar { display: block; }
}
@media (max-width: 1199px) {
  #order-standard_cart#order-standard_cart .cart-sidebar { display: none; }
}

/* Fallback pour navigateurs sans :has() (Safari <15.4, Firefox <121) :
   forcer largeur 100% sur secondary-cart-body / sidebar.
   Le grid interne ne sera pas une vraie 2-cols mais le contenu reste lisible
   (s'empile verticalement, pas écrasé). */
@supports not selector(:has(*)) {
  #order-standard_cart#order-standard_cart .secondary-cart-body,
  #order-standard_cart#order-standard_cart .secondary-cart-sidebar {
    display: block;
    width: 100%;
    float: none;
    margin-bottom: 24px;
  }
  body { padding-top: 136px; }
}

/* Cartes des articles du panier — neutralise le bleu d'origine de style.css */
#order-standard_cart .view-cart-items-header {
  background: transparent;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--ink-soft);
  padding: 0 4px 12px;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  margin-bottom: 16px;
}
#order-standard_cart .view-cart-items {
  border-bottom: 0;
  margin-bottom: 0;
}
#order-standard_cart .view-cart-items .item,
#order-standard_cart .view-cart-items .item:nth-child(even) {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px 20px;
  margin-bottom: 14px;
  box-shadow: var(--shadow-sm);
  font-size: 14px;
}
#order-standard_cart .view-cart-items .item-title {
  display: block;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 17px;
  color: var(--ink);
  margin-bottom: 4px;
}
#order-standard_cart .view-cart-items .item-group {
  display: block;
  font-size: 12px;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase;
  letter-spacing: .04em;
}
#order-standard_cart .view-cart-items .item-domain {
  display: block;
  font-size: 13px;
  color: var(--violet);
  margin-top: 4px;
}
#order-standard_cart .view-cart-items .item-price {
  text-align: right;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  color: var(--ink);
}
#order-standard_cart .view-cart-items .item-price span {
  font-size: 17px;
  white-space: nowrap;
}
#order-standard_cart .view-cart-items .item-price .cycle {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ink-soft);
  font-weight: 400;
  margin-top: 2px;
}
#order-standard_cart .view-cart-items .btn-remove-from-cart {
  color: var(--ink-soft);
  padding: 4px 8px;
}
#order-standard_cart .view-cart-items .btn-remove-from-cart:hover {
  color: #dc2626;
}
#order-standard_cart .empty-cart {
  text-align: right;
  margin: 12px 0 24px;
}

/* page title */
#order-standard_cart .header-lined {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
#order-standard_cart .header-lined h1,
#order-standard_cart .header-lined .font-size-36 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  letter-spacing: -.025em;
  color: var(--ink);
  margin: 0 0 8px;
}
#order-standard_cart .header-lined p {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0;
}

/* sidebar categories */
.cart-sidebar .sidebar,
.cart-sidebar > .list-group {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 14px;
  box-shadow: var(--shadow-sm);
}
.cart-sidebar h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--violet);
  font-weight: 500;
  margin: 0 0 12px;
  padding: 0 8px;
}
.cart-sidebar .list-group-item,
.cart-sidebar a.list-group-item {
  border: 0;
  background: transparent;
  border-radius: 8px !important;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--ink);
  margin-bottom: 2px;
  transition: background .15s var(--ease-out), color .15s var(--ease-out);
}
.cart-sidebar .list-group-item:hover {
  background: var(--violet-tint);
  color: var(--violet);
}
.cart-sidebar .list-group-item.active {
  background: var(--violet);
  color: white;
  box-shadow: 0 4px 14px -4px rgba(69,16,147,.4);
}

/* product cards */
#order-standard_cart .product {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px 24px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease-out), border-color .25s var(--ease-out), box-shadow .25s var(--ease-out);
  height: calc(100% - 24px);
  display: flex;
  flex-direction: column;
}
#order-standard_cart .product:hover {
  transform: translateY(-3px);
  border-color: var(--violet-soft);
  box-shadow: var(--shadow-lg);
}
#order-standard_cart .product header {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -.02em;
  color: var(--ink);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}
#order-standard_cart .product .qty {
  font-size: 11px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--ink-soft);
  background: var(--violet-tint);
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
#order-standard_cart .product-desc p {
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.5;
  margin: 0 0 16px;
}
#order-standard_cart .product-features,
#order-standard_cart ul.product-features {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
#order-standard_cart .product-features li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--ink);
}
#order-standard_cart .product-features li::before {
  content: "";
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  background: var(--violet-tint);
  color: var(--violet);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23451093' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 5 5L20 7'/%3E%3C/svg%3E");
  background-size: 11px;
  background-repeat: no-repeat;
  background-position: center;
}

#order-standard_cart .product-pricing {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--line-soft);
}
#order-standard_cart .product-pricing .price {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -.025em;
  color: var(--violet);
  display: block;
  line-height: 1.1;
  margin-bottom: 4px;
}
#order-standard_cart .product-pricing .cycle,
#order-standard_cart .product-pricing small {
  font-size: 12.5px;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
}

/* ordersummary sidebar (right column on cart) */
.summary-container,
#orderSummary {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--shadow-md);
  position: sticky;
  top: calc(var(--header-h) + 8px);
}
@media (max-width: 991px) {
  .summary-container,
  #orderSummary { position: static; top: auto; }
}
.summary-container .product-name {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 17px;
  color: var(--ink);
  display: block;
  margin-bottom: 4px;
}
.summary-container .product-group {
  font-size: 12px;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase;
  letter-spacing: .04em;
  display: block;
  margin-bottom: 16px;
}
.summary-totals,
.bordered-totals {
  border-top: 1px solid var(--line);
  padding-top: 14px;
  margin-top: 14px;
  font-size: 14px;
}
.summary-totals .clearfix,
.bordered-totals .clearfix {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
}

/* compte / login déjà inscrit */
.already-registered {
  background: var(--violet-tint);
  border: 1px solid rgba(139,110,232,.25);
  border-radius: var(--r-md);
  padding: 16px 18px;
  margin-bottom: 24px;
  font-size: 14px;
}
.already-registered a { color: var(--violet); font-weight: 600; }

/* account select (multi-comptes) */
.account-select {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.account-select .account {
  background: white;
  border: 1.5px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color .15s var(--ease-out), background .15s var(--ease-out);
}
.account-select .account.selected,
.account-select .account.checked {
  border-color: var(--violet);
  background: var(--violet-tint);
}

/* champ promo / coupon */
.promo,
.applycode {
  background: rgba(236,230,255,.4);
  border: 1px dashed var(--violet-soft);
  border-radius: var(--r-md);
  padding: 14px;
  margin-bottom: 20px;
}

/* configure product (steps) */
.product-image-header h1 { font-size: clamp(28px, 3vw, 40px); margin: 0; }

/* ============ DOMAIN SEARCH (cart domain step) ============ */
.domain-checker {
  margin-bottom: 24px;
}
.cart-domain-search,
#orderForm .domain-search-results {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  margin-top: 16px;
}
.domain-options-search-result-text-success { color: #15803d; font-weight: 600; }
.domain-options-search-result-text-error { color: #dc2626; font-weight: 600; }

/* ============ CHECKOUT PAYMENT METHODS ============ */
.payment-methods {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.payment-methods label,
.payment-methods .payment-method {
  background: white;
  border: 1.5px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px;
  cursor: pointer;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: border-color .15s var(--ease-out), background .15s var(--ease-out);
  font-weight: 500;
  font-size: 13.5px;
}
.payment-methods input[type="radio"]:checked + label,
.payment-methods .payment-method.selected,
.payment-methods .payment-method:has(input:checked) {
  border-color: var(--violet);
  background: var(--violet-tint);
  color: var(--violet);
}

/* ============ CART COMPLETE (success page) ============ */
.checkout-complete,
.complete-order {
  text-align: center;
  padding: 48px 24px;
  background: white;
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-pop);
}
.checkout-complete h1 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 32px;
  letter-spacing: -.025em;
  color: var(--ink);
}

/* ============ PRODUCT-DETAILS HEADER ============ */
.product-details-header,
.product-image-header {
  background: linear-gradient(140deg, var(--violet) 0%, var(--violet-deep) 100%);
  color: white;
  border-radius: var(--r-xl);
  padding: 32px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-pop);
}
.product-details-header h1, .product-details-header h2,
.product-image-header h1, .product-image-header h2 { color: white; }

/* ============ TILES dashboard (clientareahome) — palette Mirrazone ============ */
.tiles .tile {
  display: block;
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px 22px 20px;
  text-align: left;
  position: relative;
  overflow: hidden;
  transition: transform .25s var(--ease-out), border-color .25s var(--ease-out), box-shadow .25s var(--ease-out);
  color: var(--ink);
  text-decoration: none;
  margin: 0 8px 16px;
}
.tiles .tile:hover {
  transform: translateY(-2px);
  border-color: var(--violet-soft);
  box-shadow: var(--shadow-lg);
  color: var(--violet);
  text-decoration: none;
}
.tiles .tile i,
.tiles .tile .fas,
.tiles .tile .far {
  font-size: 22px;
  color: var(--violet);
  margin-bottom: 14px;
  display: inline-block;
}
.tiles .tile .stat {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 32px;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1.1;
  margin: 6px 0 4px;
}
.tiles .tile .title {
  font-size: 13px;
  color: var(--ink-soft);
  font-weight: 500;
}
.tiles .tile .highlight,
.tiles .tile .bg-color-blue,
.tiles .tile .bg-color-green,
.tiles .tile .bg-color-orange,
.tiles .tile .bg-color-red,
.card > .highlight,
.card .bg-color-blue,
.card .bg-color-green,
.card .bg-color-orange,
.card .bg-color-red,
.card .bg-color-gold {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--violet), var(--violet-soft));
  z-index: 1;
}
.card.card-accent-blue,
.card.card-accent-green,
.card.card-accent-orange,
.card.card-accent-red,
.card.card-accent-gold,
.card[class*="card-accent-"] {
  position: relative;
  overflow: hidden;
  border-color: var(--line);
  transition: border-color .2s var(--ease-out), box-shadow .25s var(--ease-out), transform .25s var(--ease-out);
}
.card[class*="card-accent-"]:hover {
  border-color: var(--violet-soft);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
.btn[class*="bg-color-"] {
  background: var(--violet) !important;
  color: white !important;
  border-color: var(--violet) !important;
}
.btn[class*="bg-color-"]:hover {
  background: var(--violet-deep) !important;
  border-color: var(--violet-deep) !important;
}

/* ============ STATS ROW (homepage) ============ */
.mz-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 20px 0 0;
  border-top: 1px solid var(--line);
  margin-top: 36px;
}
.mz-stats .stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px 8px;
  margin: -4px -8px;
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--ink);
  transition: background .15s var(--ease-out);
}
.mz-stats .stat-value {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.mz-stats .stat-label {
  font-size: 12px;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: .04em;
}
.mz-stats .stat-link {
  color: var(--ink);
  text-decoration: none;
  border-radius: var(--r-md);
  padding: 4px 8px;
  margin: -4px -8px;
  transition: background .15s var(--ease-out), transform .15s var(--ease-out);
}
.mz-stats .stat-link:hover {
  background: rgba(37,211,102,.1);
  color: #128c4f;
  transform: translateY(-1px);
}
.mz-stats .stat-link:hover .stat-value { color: #128c4f; }
@media (max-width: 720px) {
  .mz-stats { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1199px) {
  .header .navbar.navbar-light .container { height: 88px; }
  .navbar-brand { font-size: 26px; }
  .navbar-brand img { width: 56px; height: 56px; }
  body { padding-top: var(--header-h-md); scroll-padding-top: var(--header-h-md); }
  body:not(:has(.header .topbar)) { padding-top: var(--header-h-md-no-topbar); scroll-padding-top: var(--header-h-md-no-topbar); }
}
@media (max-width: 767px) {
  :root { --header-h-md: 108px; --header-h-md-no-topbar: 76px; }
  .navbar-brand { font-size: 22px; gap: 12px; }
  .navbar-brand img { width: 44px; height: 44px; border-radius: 9px; }
  .header .navbar.navbar-light .container { height: 76px; }
  #main-body { padding: 32px 0 60px; }
  .mz-hero { padding: 36px 0 56px; }
  #order-standard_cart .domain-checker,
  .domain-search-container,
  #main-body .domain-checker { padding: 36px 24px; }
  /* topbar pill compacte */
  .header .topbar .active-client { max-width: 60vw; }
  .header .topbar .active-client .btn-active-client {
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
  }
  /* status card compact */
  .status-meta { display: none; }
  .mz-status-card { padding: 16px; max-width: 100%; box-sizing: border-box; }
  .status-rows { gap: 0; }
  .status-row { padding: 8px 0; gap: 10px; }
  .status-row .row-icon { flex: 0 0 30px; width: 30px; height: 30px; }
  .status-row .row-icon svg { width: 15px; height: 15px; }
  .status-row .row-label { font-size: 13px; }
  .status-row .row-status { font-size: 11px; padding: 2px 8px; }
  /* hero h1 plus serré */
  .mz-hero h1 { font-size: clamp(26px, 7.2vw, 34px) !important; text-wrap: pretty; }
  .mz-hero p.lead { font-size: 15px; }
  .mz-hero-grid { gap: 28px; }
  .mz-hero-visual::before { display: none; }
}

/* ============================================================
   NEXUS theme.min.css OVERRIDES
   Le thème Nexus définit notamment :
     .navbar { display: none }
     .header { background-color: #fff }
     .header .navbar a { color: #444 }
     .navbar-light .navbar-nav .nav-link { color: rgba(0,0,0,.5) }
     .header .toolbar .nav-link { border:1px solid #e5e5e5; color:var(--text-lifted) }
   Toutes ces règles cassaient le rendu côté WHMCS (menu blanc, liens
   gris invisibles sur fond violet). Le bloc ci-dessous re-force la
   palette Mirrazone avec une spécificité suffisante.
   ============================================================ */
.header.header { background: var(--violet); }
.header.header.scrolled { background: transparent; }
.header.header .navbar { display: flex; }
.header.header .navbar a,
.header.header .navbar-brand,
.header.header .navbar-brand:hover,
.header.header .navbar-brand:focus { color: white; }
.header.header .navbar-nav.toolbar .nav-link,
.header.header .navbar-light .navbar-nav .nav-link { color: white; border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.14); padding: 0; font-size: inherit; }
.header.header .navbar-nav.toolbar .nav-link:hover,
.header.header .navbar-light .navbar-nav .nav-link:hover { color: var(--violet); background: white; border-color: white; }
.header.header .mz-mainnav a,
.header.header .mz-mainnav .nav-link { color: rgba(255,255,255,.78); border: 0; border-bottom: 2px solid transparent; background: transparent; padding: 0 14px; font-size: 14.5px; }
.header.header .mz-mainnav a:hover,
.header.header .mz-mainnav .nav-link:hover { color: white; background: transparent; border-color: transparent; }
.header.header .mz-mainnav a.active,
.header.header .mz-mainnav li.active > a,
.header.header .mz-mainnav .nav-link.active { color: white; border-bottom-color: white; background: transparent; }

.header.header.scrolled .mz-mainnav a,
.header.header.scrolled .mz-mainnav .nav-link { color: var(--ink-soft); }
.header.header.scrolled .mz-mainnav a:hover,
.header.header.scrolled .mz-mainnav .nav-link:hover { color: var(--violet-deep); }
.header.header.scrolled .mz-mainnav a.active,
.header.header.scrolled .mz-mainnav li.active > a,
.header.header.scrolled .mz-mainnav .nav-link.active { color: var(--violet-deep); border-bottom-color: var(--violet); }

/* Le navbar.tpl Nexus pose .pr-4 sur les liens — neutraliser le padding-right
   qui décalerait l'underline actif. */
.header.header .mz-mainnav a.pr-4 { padding-right: 14px; }

/* Topbar dans WHMCS : Nexus pose --grayscale-accented (gris). On force
   la teinte violette transparente attendue. */
.header.header .topbar { background: rgba(0,0,0,.14); color: rgba(255,255,255,.85); }
.header.header .topbar .btn { color: rgba(255,255,255,.85); }
.header.header .topbar .btn.focus,
.header.header .topbar .btn:focus { box-shadow: none; outline-color: white; }
.header.header .topbar .active-client .btn { color: white; }
.header.header .topbar .active-client .btn.btn-active-client span { border-bottom: 0; }

/* Toolbar du Nexus : pour rappel le badge panier doit garder son halo */
.header.header .navbar-nav.toolbar .nav-link .badge {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--violet-soft);
  color: white;
  border: 2px solid var(--violet);
}

/* Anciennes barres horizontales (Nexus définit plein de
   .header h3 { margin-bottom:.75rem } etc.) — non touchées. */

/* Override Nexus: bouton "Transférer" homepage illisible
   (theme.css applique bg-inverted = navy sombre + texte sombre).
   On force la version outline violet pour rester lisible. */
body #frmDomainHomepage #btnTransfer,
body #frmDomainHomepage #btnTransfer2 {
  background: white;
  color: var(--violet);
  border-color: var(--violet);
}
body #frmDomainHomepage #btnTransfer:hover,
body #frmDomainHomepage #btnTransfer:focus,
body #frmDomainHomepage #btnTransfer:active,
body #frmDomainHomepage #btnTransfer2:hover,
body #frmDomainHomepage #btnTransfer2:focus,
body #frmDomainHomepage #btnTransfer2:active {
  background: var(--violet-tint);
  color: var(--violet-deep);
  border-color: var(--violet);
}
