/* ============================================================
   Netslim — Nexus child theme (Bootstrap 4.5.3 base)
   Brand:  antraciet #0F1419 · cremewit #FAFAF5 · rood #E63946
   Fonts:  Space Grotesk (headings) · Inter (body)
   Nexus compileert kleuren hard (BS4), dus we overschrijven
   de echte selectors — geen CSS-variabelen.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --ns-antraciet: #0F1419;
  --ns-antraciet-2: #1a222b;
  --ns-creme: #FAFAF5;
  --ns-rood: #E63946;
  --ns-rood-dark: #c92d39;
  --ns-rood-soft: rgba(230, 57, 70, .12);
  --ns-border: #e7e7e0;
  --ns-text: #1f262e;
  --ns-muted: #6b7480;
  --ns-radius: 14px;
  --ns-radius-sm: 10px;
  --ns-shadow: 0 1px 2px rgba(15,20,25,.04), 0 8px 24px rgba(15,20,25,.06);
  --ns-shadow-hover: 0 2px 4px rgba(15,20,25,.06), 0 16px 40px rgba(15,20,25,.10);
}

/* ---------- Basis ---------- */
body {
  font-family: 'Inter', system-ui, -apple-system, "Segoe UI", sans-serif;
  background-color: var(--ns-creme);
  color: var(--ns-text);
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4,h5,h6,
.h1,.h2,.h3,.h4,.h5,.h6,
.card-title,.navbar-brand {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--ns-antraciet);
}

a { color: var(--ns-rood); }
a:hover { color: var(--ns-rood-dark); }

/* ---------- Top navigatie / header (antraciet) ---------- */
#header, .navbar, .primary-nav, .header-lined, header.navbar {
  background-color: var(--ns-antraciet) !important;
  border: 0 !important;
}
#header a, .navbar a, .navbar .nav-link, .navbar-brand,
.navbar .navbar-text, #header .nav-link {
  color: rgba(255,255,255,.86) !important;
}
.navbar .nav-link:hover, #header a:hover { color: #fff !important; }
.navbar .nav-item.active > .nav-link,
.navbar .nav-link.active { color: #fff !important; }

/* Dropdown menus in de header */
.dropdown-menu {
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius-sm);
  box-shadow: var(--ns-shadow);
  padding: .4rem;
}
.dropdown-item { border-radius: 8px; padding: .5rem .75rem; }
.dropdown-item:hover, .dropdown-item:focus {
  background-color: var(--ns-rood-soft);
  color: var(--ns-rood-dark);
}
.dropdown-item.active, .dropdown-item:active {
  background-color: var(--ns-rood);
  color: #fff;
}

/* ---------- Cards ---------- */
.card {
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  box-shadow: var(--ns-shadow);
  background: #fff;
  margin-bottom: 1.5rem;
}
.card-header {
  background: #fff;
  border-bottom: 1px solid var(--ns-border);
  padding: 1rem 1.25rem;
  font-weight: 600;
  border-radius: var(--ns-radius) var(--ns-radius) 0 0 !important;
}
.card-body { padding: 1.25rem; }
.card-footer { background: #fff; border-top: 1px solid var(--ns-border); }

/* card accent strepen (dashboard panels) -> brand rood als default */
.card-accent-blue   { border-top: 3px solid var(--ns-rood); }
.card-accent-green  { border-top: 3px solid #2bb673; }
.card-accent-red    { border-top: 3px solid var(--ns-rood); }
.card-accent-gold   { border-top: 3px solid #e0a200; }

/* ---------- Knoppen ---------- */
.btn {
  border-radius: var(--ns-radius-sm);
  font-weight: 600;
  padding: .55rem 1.1rem;
  transition: transform .08s ease, box-shadow .15s ease, background-color .15s ease;
}
.btn:active { transform: translateY(1px); }

.btn-primary {
  background-color: var(--ns-rood);
  border-color: var(--ns-rood);
  color: #fff;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--ns-rood-dark);
  border-color: var(--ns-rood-dark);
  box-shadow: 0 6px 18px rgba(230,57,70,.28);
  color: #fff;
}
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
  background-color: var(--ns-rood-dark);
  border-color: var(--ns-rood-dark);
}
.btn-primary.disabled, .btn-primary:disabled {
  background-color: var(--ns-rood);
  border-color: var(--ns-rood);
  opacity: .55;
}
.btn-primary:focus, .btn-primary.focus {
  box-shadow: 0 0 0 .2rem var(--ns-rood-soft);
}

.btn-outline-primary {
  color: var(--ns-rood);
  border-color: var(--ns-rood);
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background-color: var(--ns-rood);
  border-color: var(--ns-rood);
  color: #fff;
}

.btn-default, .btn-secondary {
  background-color: #fff;
  border-color: var(--ns-border);
  color: var(--ns-text);
}
.btn-default:hover, .btn-secondary:hover {
  background-color: #f3f3ee;
  border-color: #d9d9d0;
  color: var(--ns-antraciet);
}

.btn-success { background-color:#2bb673; border-color:#2bb673; }
.btn-success:hover { background-color:#249b62; border-color:#249b62; }

/* ---------- Links/teksten met primary ---------- */
.text-primary { color: var(--ns-rood) !important; }
.bg-primary   { background-color: var(--ns-rood) !important; }
.border-primary { border-color: var(--ns-rood) !important; }
.badge-primary { background-color: var(--ns-rood); }
.badge { font-weight: 600; border-radius: 7px; padding: .35em .6em; }

/* ---------- Dashboard tiles (clientareahome) ---------- */
.tiles .tile {
  display: block;
  background: #fff;
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  box-shadow: var(--ns-shadow);
  padding: 1.25rem;
  margin: .5rem;
  text-align: left;
  color: var(--ns-text);
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, box-shadow .15s ease;
}
.tiles .tile:hover {
  transform: translateY(-3px);
  box-shadow: var(--ns-shadow-hover);
  text-decoration: none;
  color: var(--ns-antraciet);
}
.tiles .tile i {
  font-size: 1.5rem;
  color: var(--ns-rood);
  margin-bottom: .5rem;
  display: block;
}
.tiles .tile .stat {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--ns-antraciet);
}
.tiles .tile .title {
  color: var(--ns-muted);
  font-size: .85rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.tiles .tile .highlight {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 3px;
}
.tile .highlight.bg-color-blue  { background: var(--ns-rood); }
.tile .highlight.bg-color-green { background: #2bb673; }
.tile .highlight.bg-color-red   { background: var(--ns-rood); }
.tile .highlight.bg-color-gold  { background: #e0a200; }

/* ---------- Formulieren ---------- */
.form-control, .custom-select {
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius-sm);
  padding: .55rem .85rem;
  color: var(--ns-text);
}
.form-control:focus, .custom-select:focus {
  border-color: var(--ns-rood);
  box-shadow: 0 0 0 .2rem var(--ns-rood-soft);
}
.input-group-text {
  background: #f3f3ee;
  border: 1px solid var(--ns-border);
  color: var(--ns-muted);
}
label, .form-control-label, .col-form-label { font-weight: 500; color: var(--ns-text); }

/* ---------- Tabellen ---------- */
.table thead td, .table thead th {
  border-top: 0;
  border-bottom: 1px solid var(--ns-border);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--ns-muted);
  font-weight: 600;
}
.table td, .table th { border-color: #f0f0ea; vertical-align: middle; }
.table-hover tbody tr:hover { background-color: #faf6f6; }

/* ---------- Alerts / panels ---------- */
.alert { border: 0; border-radius: var(--ns-radius-sm); border-left: 4px solid; }
.alert-success { background:#e9f7f0; border-left-color:#2bb673; color:#1a6e47; }
.alert-danger  { background:var(--ns-rood-soft); border-left-color:var(--ns-rood); color:var(--ns-rood-dark); }
.alert-info    { background:#eef4fb; border-left-color:#3b82c4; color:#1f4d75; }
.alert-warning { background:#fdf6e7; border-left-color:#e0a200; color:#8a6400; }

/* ---------- Sidebar / lijst-navigatie (account, support) ---------- */
.list-group-item { border-color: var(--ns-border); }
.list-group-item.active {
  background-color: var(--ns-rood);
  border-color: var(--ns-rood);
}
.list-group-item-action:hover { background-color: var(--ns-rood-soft); }
.nav-tabs .nav-link.active { border-top: 2px solid var(--ns-rood); color: var(--ns-rood); }

/* ---------- Login / auth pagina ---------- */
.login-form .card, .card.mw-540 {
  border-radius: 18px;
  box-shadow: var(--ns-shadow-hover);
}

/* ---------- Footer ---------- */
#footer, footer {
  background-color: var(--ns-antraciet);
  color: rgba(255,255,255,.7);
}
#footer a, footer a { color: rgba(255,255,255,.85); }
#footer a:hover, footer a:hover { color: #fff; }

/* ---------- Diversen ---------- */
hr { border-top-color: var(--ns-border); }
.text-muted { color: var(--ns-muted) !important; }
.page-header, .page-title { color: var(--ns-antraciet); }

/* ============================================================
   NAVBAR — Netslim antraciet (Nexus header restyle via CSS)
   ============================================================ */
#header .topbar {
  background: #0a0e12;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
#header .topbar .btn,
#header .topbar .input-group-text,
#header .topbar .btn-active-client { color: rgba(255,255,255,.85) !important; }
#header .navbar.navbar-light,
#header .main-navbar-wrapper {
  background: var(--ns-antraciet) !important;
}
#header .navbar-brand .logo-img { height: 34px; width: auto; }
#header .navbar-light .navbar-nav .nav-link,
#header .main-navbar-wrapper .navbar-nav .nav-link {
  color: rgba(255,255,255,.82) !important;
  font-weight: 500;
  border-radius: 8px;
  padding: .5rem .85rem;
  transition: background-color .15s, color .15s;
}
#header .navbar-nav .nav-link:hover { color: #fff !important; background: rgba(255,255,255,.07); }
#header .navbar-nav .nav-item.active > .nav-link,
#header .navbar-nav .nav-link.active { color: #fff !important; background: rgba(230,57,70,.18); }
/* zoekbalk in navbar */
#header .search .form-control {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: #fff;
}
#header .search .form-control::placeholder { color: rgba(255,255,255,.5); }
#header .search .btn-default {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: rgba(255,255,255,.7);
}
/* cart knop */
#header .cart-btn { color: rgba(255,255,255,.82) !important; }
#header .cart-btn .badge-dark { background: var(--ns-rood); }
/* ---------- Navbar dropdowns: donker, pro, mega-stijl (Account / Store / More) ---------- */
#header .navbar-nav .dropdown-menu {
  background: #161d26 !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 14px;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.65);
  padding: .5rem;
  margin-top: .55rem;
  min-width: 260px;
}
#header .navbar-nav .dropdown-menu .dropdown-item,
#header .navbar-nav .dropdown-menu a,
#header .navbar-nav .dropdown-menu .nav-link {
  color: rgba(255,255,255,.84) !important;
  border-radius: 9px;
  padding: .6rem .85rem;
  font-weight: 500;
  white-space: nowrap;
  transition: background-color .15s ease, color .15s ease;
}
#header .navbar-nav .dropdown-menu .dropdown-item:hover,
#header .navbar-nav .dropdown-menu .dropdown-item:focus,
#header .navbar-nav .dropdown-menu a:hover,
#header .navbar-nav .dropdown-menu a:focus,
#header .navbar-nav .dropdown-menu .nav-link:hover {
  background: var(--ns-rood) !important;
  color: #fff !important;
}
#header .navbar-nav .dropdown-menu .dropdown-item i,
#header .navbar-nav .dropdown-menu a i { width: 1.1rem; text-align: center; margin-right: .55rem; opacity: .8; }
#header .navbar-nav .dropdown-menu .dropdown-header,
#header .navbar-nav .dropdown-menu .text-muted {
  color: rgba(255,255,255,.45) !important;
  text-transform: uppercase;
  font-size: .7rem;
  letter-spacing: .04em;
  padding: .5rem .85rem .25rem;
}
#header .navbar-nav .dropdown-menu .dropdown-divider { border-color: rgba(255,255,255,.08); }
/* Lange Store-dropdown -> mega 2-koloms paneel */
#header .navbar-nav .dropdown-menu:has(> .dropdown-item:nth-child(8)),
#header .navbar-nav .dropdown-menu:has(> a:nth-child(8)) {
  min-width: 480px;
  columns: 2;
  column-gap: .4rem;
}
#header .navbar-nav .dropdown-menu:has(> .dropdown-item:nth-child(8)) .dropdown-item,
#header .navbar-nav .dropdown-menu:has(> a:nth-child(8)) a { break-inside: avoid; }

/* ---------- Breadcrumb ---------- */
.master-breadcrumb {
  background: #fff;
  border-bottom: 1px solid var(--ns-border);
}
.master-breadcrumb .breadcrumb { background: transparent; margin: 0; padding: .75rem 0; }
.master-breadcrumb a { color: var(--ns-muted); }
.master-breadcrumb a:hover { color: var(--ns-rood); }
.master-breadcrumb .breadcrumb-item.active { color: var(--ns-antraciet); }

/* ---------- Sidebar (account / support) ---------- */
.sidebar .panel, .sidebar .list-group {
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  overflow: hidden;
  box-shadow: var(--ns-shadow);
}
.sidebar .list-group-item { border: 0; border-bottom: 1px solid #f0f0ea; padding: .7rem 1rem; }
.sidebar .list-group-item:last-child { border-bottom: 0; }
.sidebar .list-group-item.active { background: var(--ns-rood); border-color: var(--ns-rood); }
.sidebar .panel-title { font-family: 'Space Grotesk', sans-serif; }

/* ============================================================
   PORTAL HOME (homepage.tpl) — premium Netslim kaarten
   ============================================================ */
.ns-portal-home { padding: .5rem 0 2rem; }
.ns-section-head { margin: 2.25rem 0 1.1rem; }
.ns-eyebrow {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--ns-rood);
  font-weight: 600;
  margin: 0 0 .3rem;
}
.ns-h2 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.65rem;
  font-weight: 600;
  color: var(--ns-antraciet);
  margin: 0;
  letter-spacing: -.01em;
}

/* grote product/dienst kaarten */
.ns-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 1rem;
}
.ns-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  box-shadow: var(--ns-shadow);
  padding: 1.5rem;
  text-decoration: none !important;
  color: var(--ns-text);
  transition: transform .14s ease, box-shadow .16s ease, border-color .16s;
}
.ns-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--ns-shadow-hover);
  border-color: #dcdcd2;
}
.ns-card-icon {
  height: 48px; width: 48px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 12px;
  background: var(--ns-rood-soft);
  color: var(--ns-rood);
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.ns-card-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 1.15rem;
  color: var(--ns-antraciet);
  margin-bottom: .35rem;
}
.ns-card-body { font-size: .9rem; color: var(--ns-muted); line-height: 1.55; flex: 1; }
.ns-card-cta {
  margin-top: 1rem;
  font-weight: 600;
  font-size: .9rem;
  color: var(--ns-rood);
  display: inline-flex; align-items: center; gap: .4rem;
}
.ns-card:hover .ns-card-cta i { transform: translateX(3px); }
.ns-card-cta i { transition: transform .14s ease; }

/* snelkoppelingen */
.ns-quick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: .85rem;
}
.ns-quick {
  display: flex; align-items: center; gap: .9rem;
  background: #fff;
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius-sm);
  box-shadow: var(--ns-shadow);
  padding: 1rem 1.15rem;
  text-decoration: none !important;
  color: var(--ns-text);
  transition: transform .12s ease, box-shadow .15s ease;
}
.ns-quick:hover { transform: translateY(-2px); box-shadow: var(--ns-shadow-hover); color: var(--ns-antraciet); }
.ns-quick-icon {
  height: 40px; width: 40px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 10px;
  background: var(--ns-rood-soft);
  color: var(--ns-rood);
  font-size: 1.05rem;
}
.ns-quick-text { flex: 1; font-weight: 600; font-size: .95rem; }
.ns-quick-arrow { color: #c4c4bb; transition: transform .12s, color .12s; }
.ns-quick:hover .ns-quick-arrow { color: var(--ns-rood); transform: translateX(3px); }

/* ============================================================
   DASHBOARD STATS (clientareahome) — placeholder styling,
   wordt gekoppeld aan WHMCS-data zodra clientareahome.tpl af is
   ============================================================ */
.ns-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1rem;
  margin-bottom: .5rem;
}
.ns-stat {
  background: #fff;
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  box-shadow: var(--ns-shadow);
  padding: 1.25rem 1.35rem;
  position: relative;
  overflow: hidden;
}
.ns-stat::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--ns-rood);
}
.ns-stat-label {
  font-size: .76rem; text-transform: uppercase; letter-spacing: .05em;
  color: var(--ns-muted); font-weight: 600;
}
.ns-stat-value {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 2.1rem; font-weight: 700; line-height: 1.1;
  color: var(--ns-antraciet); margin-top: .3rem;
}
.ns-stat-icon {
  position: absolute; right: 1rem; top: 1rem;
  color: var(--ns-rood-soft); font-size: 1.8rem;
}
.ns-stat.is-alert::before { background: #e0a200; }
.ns-stat.is-alert .ns-stat-value { color: #b07e00; }

/* stat-kaart als klikbare link */
a.ns-stat {
  display: block;
  text-decoration: none !important;
  color: inherit;
  transition: transform .12s ease, box-shadow .15s ease;
}
a.ns-stat:hover {
  transform: translateY(-3px);
  box-shadow: var(--ns-shadow-hover);
}

/* ============================================================
   VIDEO HERO (portal home) — in lijn met marketing-homepage
   ============================================================ */
.ns-hero {
  position: relative;
  background: var(--ns-antraciet);
  overflow: hidden;
  min-height: 320px;
  display: flex;
  align-items: center;
}
.ns-hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .45;
}
.ns-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(15,20,25,.92) 0%, rgba(15,20,25,.65) 55%, rgba(15,20,25,.35) 100%);
}
.ns-hero-inner {
  position: relative;
  z-index: 2;
  padding: 3.5rem 1rem;
  max-width: 640px;
}
.ns-hero-eyebrow {
  font-family: 'Space Grotesk', sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .75rem;
  font-weight: 600;
  color: var(--ns-rood);
  margin: 0 0 .6rem;
}
.ns-hero-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 .75rem;
  letter-spacing: -.02em;
  line-height: 1.05;
}
.ns-hero-sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.8);
  margin: 0;
  line-height: 1.55;
}

/* ============================================================
   DOMEINZOEKER (domain-search.tpl) — prijzen netjes uitlijnen
   ============================================================ */
#order-standard_cart #domains-pricing,
.domain-search-pricing,
.domain-pricing,
#main-body .tld-pricing,
#main-body .domain-pricelist {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: center;
  justify-content: center;
  margin-top: 1rem;
}
#main-body .tld-pricing > *,
.domain-pricing > * {
  white-space: nowrap;
  margin: 0 .5rem;
}
/* generieke marge voor losse prijslabels in de homepage domeinzoeker */
.header-lined + * .domain-checker img,
#domainSearchForm + * span { margin-right: .4rem; }

/* domeinzoeker container op homepage */
#main-body ~ #domainSearchForm,
.homepage-domain-search,
#domain-search {
  background: #fff;
}

/* ============================================================
   DASHBOARD KOP (clientareahome)
   ============================================================ */
.ns-dash-head { margin: .5rem 0 1.5rem; }
.ns-dash-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--ns-antraciet);
  margin: 0 0 .35rem;
  letter-spacing: -.01em;
}
.ns-dash-sub { color: var(--ns-muted); margin: 0; font-size: 1rem; }

/* client-home panels netjes */
.client-home-cards .card { height: auto; }
.client-home-cards .card-header .card-title { font-size: 1.05rem; }
.client-home-cards .list-group-item-action:hover { background: var(--ns-rood-soft); }

/* ============================================================
   MARKETING FOOTER
   ============================================================ */
.ns-footer { background: var(--ns-antraciet) !important; padding: 4rem 0 2rem; margin-top: 3rem; }
.ns-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.6fr;
  gap: 2.5rem;
}
.ns-footer-logo { height: 32px; width: auto; margin-bottom: 1.25rem; }
.ns-footer-desc { font-size: .9rem; line-height: 1.6; color: rgba(255,255,255,.6); max-width: 20rem; }
.ns-footer-social { margin-top: 1rem; padding: 0; }
.ns-footer-social li { display: inline-block; margin-right: .5rem; }
.ns-footer-social a { color: rgba(255,255,255,.6); font-size: 1.1rem; }
.ns-footer-social a:hover { color: #fff; }
.ns-footer-col h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .9rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 1rem;
}
.ns-footer-col ul { list-style: none; padding: 0; margin: 0; }
.ns-footer-col li { margin-bottom: .65rem; font-size: .9rem; color: rgba(255,255,255,.6); }
.ns-footer-col a { color: rgba(255,255,255,.6); }
.ns-footer-col a:hover { color: var(--ns-rood); }
.ns-footer-contact li { display: flex; align-items: flex-start; gap: .55rem; }
.ns-footer-contact i { color: var(--ns-rood); margin-top: .2rem; width: 1rem; text-align: center; }
.ns-footer-bottom {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,.1);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.ns-footer-bottom .copyright { font-size: .8rem; color: rgba(255,255,255,.45); }
.ns-footer-bottom .nav-link { color: rgba(255,255,255,.6); font-size: .8rem; padding: 0 .75rem; }
.ns-footer-bottom .nav-link:hover { color: #fff; }
@media (max-width: 767px) {
  .ns-footer-grid { grid-template-columns: 1fr 1fr; gap: 1.75rem; }
  .ns-footer-brand { grid-column: 1 / -1; }
}

/* ============================================================
   MEGA MENU (client area navbar) — kopie marketing-stijl
   ============================================================ */
.main-navbar-wrapper { position: relative; }
.ns-mega-nav .ns-mega-item { position: static; }
.ns-mega-toggle { display: inline-flex; align-items: center; gap: .4rem; }
.ns-mega-caret { font-size: .7rem; transition: transform .2s ease; }
.ns-mega-item:hover .ns-mega-caret,
.ns-mega-item:focus-within .ns-mega-caret { transform: rotate(180deg); }

.ns-mega-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 1050;
  background: var(--ns-antraciet);
  border-top: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 24px 48px rgba(0,0,0,.35);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
}
.ns-mega-item:hover .ns-mega-panel,
.ns-mega-item:focus-within .ns-mega-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.ns-mega-inner {
  display: grid;
  grid-template-columns: 4fr 8fr;
  gap: 2rem;
  padding: 2.5rem 1rem;
}
.ns-mega-eyebrow {
  font-family: 'Space Grotesk', sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .72rem;
  font-weight: 600;
  color: var(--ns-rood);
  margin: 0 0 .75rem;
}
.ns-mega-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 .75rem;
  line-height: 1.15;
}
.ns-mega-body { font-size: .9rem; color: rgba(255,255,255,.7); line-height: 1.55; margin: 0 0 1.5rem; }
.ns-mega-cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--ns-rood);
  color: #fff !important;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: .9rem;
  padding: .6rem 1.25rem;
  border-radius: 999px;
  text-decoration: none !important;
  transition: opacity .15s ease;
}
.ns-mega-cta:hover { opacity: .9; }
.ns-mega-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .35rem; align-content: start; }
.ns-mega-link {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: .85rem;
  border-radius: 12px;
  text-decoration: none !important;
  transition: background .15s ease;
}
.ns-mega-link:hover { background: rgba(255,255,255,.05); }
.ns-mega-ico {
  flex: 0 0 auto;
  width: 40px; height: 40px;
  border-radius: 10px;
  background: rgba(255,255,255,.1);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  transition: background .15s ease, color .15s ease;
}
.ns-mega-link:hover .ns-mega-ico { background: var(--ns-rood); color: #fff; }
.ns-mega-text { display: flex; flex-direction: column; min-width: 0; }
.ns-mega-text strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .9rem; font-weight: 600; color: #fff;
}
.ns-mega-text small { font-size: .78rem; color: rgba(255,255,255,.6); margin-top: .15rem; line-height: 1.4; }

/* Mega menu op mobiel: panelen altijd zichtbaar binnen het hamburger-menu
   (geen hover nodig — op touch zou tikken op het hoofd-item meteen
   wegnavigeren waardoor de sublinks onbereikbaar werden). */
@media (max-width: 1199px) {
  .ns-mega-item { position: relative; }
  .ns-mega-panel {
    position: static;
    opacity: 1; visibility: visible; transform: none;
    box-shadow: none; border-top: 0; background: transparent;
    display: block;
  }
  .ns-mega-inner { grid-template-columns: 1fr; gap: 1rem; padding: .25rem 0 1rem; }
  .ns-mega-featured { display: none; }
  .ns-mega-grid { grid-template-columns: 1fr; gap: 0; }
  .ns-mega-link { padding: .65rem .5rem; }
  .ns-mega-caret { display: none; }
}

/* ============================================================
   DOMEINZOEKER (home-domain-search) — prijzen netjes
   ============================================================ */
.home-domain-search { padding: 2.5rem 0; }
.home-domain-search h2 {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  color: var(--ns-antraciet);
  margin-bottom: 1.5rem;
}
.home-domain-search .input-group-wrapper { max-width: 640px; margin: 0 auto; }
.tld-logos {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1.75rem;
  padding: 0;
  margin: 1.75rem auto 0;
  max-width: 720px;
}
.tld-logos li {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin: 0;
  font-size: .95rem;
  font-weight: 600;
  color: var(--ns-antraciet);
  white-space: nowrap;
}
.tld-logos li img { height: 22px; width: auto; }
.home-domain-search .btn-link { color: var(--ns-rood); font-weight: 600; }

/* Domeinzoeker-knop: rood blijven bij hover (fix wit-op-wit) */
.home-domain-search .btn,
#domainSearchForm .btn,
.domain-checker .btn,
.home-domain-search button[type="submit"],
#domain-search button[type="submit"] {
  background-color: var(--ns-rood) !important;
  border-color: var(--ns-rood) !important;
  color: #fff !important;
  font-weight: 600;
}
.home-domain-search .btn:hover,
.home-domain-search .btn:focus,
#domainSearchForm .btn:hover,
#domainSearchForm .btn:focus,
.domain-checker .btn:hover,
.home-domain-search button[type="submit"]:hover,
#domain-search button[type="submit"]:hover {
  background-color: var(--ns-rood-dark) !important;
  border-color: var(--ns-rood-dark) !important;
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(230,57,70,.28);
}

/* ============================================================
   WHATSAPP ZWEVENDE BUBBEL (klantgebied)
   ============================================================ */
.ns-wa-bubble {
  position: fixed;
  bottom: 1.35rem;
  right: 1.35rem;
  z-index: 1080;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  color: #fff !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  box-shadow: 0 12px 30px -6px rgba(0,0,0,.45);
  transition: transform .15s ease, box-shadow .15s ease;
}
.ns-wa-bubble:hover { transform: scale(1.06); color: #fff !important; box-shadow: 0 16px 36px -6px rgba(0,0,0,.5); }
.ns-wa-bubble:active { transform: scale(.95); }
.ns-wa-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid #25D366;
  animation: ns-wa-ping 2s cubic-bezier(0,0,.2,1) infinite;
}
@keyframes ns-wa-ping {
  0% { transform: scale(1); opacity: .7; }
  70%, 100% { transform: scale(1.6); opacity: 0; }
}

/* ============================================================
   ACTIEVE DIENSTEN-KAARTEN (active-products-services-item)
   ============================================================ */
.div-service-item {
  background: #fff;
  border: 1px solid var(--ns-border);
  border-radius: var(--ns-radius);
  padding: 1.1rem 1.25rem;
  margin-bottom: .85rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  cursor: pointer;
  transition: box-shadow .15s ease, border-color .15s ease, transform .12s ease;
}
.div-service-item:hover {
  box-shadow: var(--ns-shadow-hover);
  border-color: var(--ns-antraciet);
  transform: translateY(-2px);
}
.div-service-name { flex: 1 1 240px; }
.div-service-name .font-weight-bold {
  font-family: 'Space Grotesk', sans-serif;
  color: var(--ns-antraciet);
  display: block;
}
.div-service-name .text-domain { font-size: .85rem; color: var(--ns-muted); }
.div-service-buttons { display: flex; align-items: center; gap: .5rem; margin-left: auto; }

/* ============================================================
   SIDEBAR (card-sidebar) — verfijning
   ============================================================ */
.card-sidebar { border: 1px solid var(--ns-border); border-radius: var(--ns-radius); box-shadow: none; }
.card-sidebar .card-header {
  background: var(--ns-antraciet);
  border: 0;
}
.card-sidebar .card-header .card-title { color: #fff; font-family: 'Space Grotesk', sans-serif; font-size: 1rem; }
.card-sidebar .list-group-item-action.active {
  background: var(--ns-rood);
  border-color: var(--ns-rood);
  color: #fff;
}
.card-sidebar .list-group-item-action:hover:not(.active) { background: var(--ns-rood-soft); }
.sidebar-menu-item-wrapper { display: flex; align-items: center; gap: .65rem; }

/* ============================================================
   ALERTS (alert.tpl) — merkkleuren
   ============================================================ */
#main-body .alert { border: 0; border-radius: var(--ns-radius); border-left: 4px solid; }
#main-body .alert-info { background: var(--ns-rood-soft); border-left-color: var(--ns-rood); color: var(--ns-antraciet); }
#main-body .alert-success { border-left-color: #2e9e5b; }
#main-body .alert-danger { border-left-color: var(--ns-rood); }
#main-body .alert-warning { border-left-color: #e0a200; }
