@import url("https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600&display=swap");

/* *****************************************************
   Dunamis — WHMCS theme skin (Nexus base)
   "Light & trustworthy": one indigo accent, real imagery,
   type-forward. Loaded LAST so it overrides Nexus/Bootstrap.

   1) Re-maps Nexus design tokens to the Dunamis palette so
      EVERY inner page (cart, client area, invoices, domains…)
      inherits the look automatically.
   2) Adds dm-* components used by our custom header / footer /
      homepage markup. dm- prefix => zero collision with Bootstrap.
***************************************************** */

:root {
    --white: #fff;

    /* Neutral shades — cool indigo-tinted greys */
    --neutral-50: #f7f8fc;
    --neutral-100: #eef1fb;
    --neutral-200: #e4e8f4;
    --neutral-300: #d6dcef;
    --neutral-400: #9aa1bf;
    --neutral-500: #828aac;
    --neutral-600: #4a5278;
    --neutral-700: #2f3760;
    --neutral-800: #1b2350;
    --neutral-900: #0d1233;
    --neutral-950: #070a22;

    /* Primary palette — Dunamis indigo */
    --primary-50:  #eef1fb;
    --primary-100: #e9edff;
    --primary-200: #c9d2f7;
    --primary-300: #a3b1f0;
    --primary-400: #6b80e6;
    --primary-500: #3d5be0;
    --primary-600: #2540d9;   /* brand */
    --primary-700: #1c34b8;   /* brand hover */
    --primary-800: #18298f;
    --primary-900: #151e74;   /* brand deep */
    --primary-950: #0d1233;

    --primary: var(--primary-600);
    --primary-lifted: var(--primary-700);
    --primary-accented: var(--primary-800);

    /* Secondary */
    --secondary: var(--neutral-500);
    --secondary-lifted: var(--neutral-600);
    --secondary-accented: var(--neutral-700);

    /* Success */
    --success: #15b66b;
    --success-lifted: #109257;
    --success-accented: #0c7044;

    /* Info — brand blue */
    --info: #3d86f6;
    --info-lifted: #2f6fd6;
    --info-accented: #2459b0;

    /* Notice */
    --notice: #2540d9;
    --notice-lifted: #1c34b8;
    --notice-accented: #18298f;

    /* Warning */
    --warning: #f6a609;
    --warning-lifted: #d68d00;
    --warning-accented: #a86e00;

    /* Error */
    --error: #e7000b;
    --error-lifted: #c10007;
    --error-accented: #9f0712;

    /* Grayscale */
    --grayscale: var(--neutral-900);
    --grayscale-lifted: var(--neutral-800);
    --grayscale-accented: var(--neutral-700);

    /* Neutral */
    --neutral: var(--neutral-500);
    --neutral-lifted: var(--neutral-600);
    --neutral-accented: var(--neutral-700);

    /* Text */
    --text-inverted: var(--white);
    --text-muted: var(--neutral-400);
    --text-lifted: var(--neutral-500);
    --text-accented: var(--neutral-600);
    --text: var(--neutral-900);

    /* Border */
    --border-muted: var(--neutral-200);
    --border: var(--neutral-300);
    --border-lifted: var(--neutral-400);
    --border-accented: var(--neutral-600);

    /* Background */
    --bg: var(--white);
    --bg-muted: var(--neutral-50);
    --bg-lifted: var(--neutral-100);
    --bg-accented: var(--neutral-200);
    --bg-inverted: var(--primary-900);

    /* Additional colors */
    --yellow-200: #fff085;
    --yellow-300: #ffdf20;
    --teal-300: #46edd5;
    --teal-400: #00d5be;
    --emerald-300: #5ee9b5;
    --pink-400: #fb64b6;

    /* Font sizes */
    --text-xs: 0.625rem;
    --text-sm: 0.75rem;
    --text-md: 0.875rem;
    --text-lg: 1rem;

    /* Outline */
    --outline-sm: 1px;
    --outline-md: 2px;
    --outline-lg: 3px;

    /* Rounding — softer Dunamis radii */
    --rounding-sm: 10px;
    --rounding-md: 16px;
    --rounding-lg: 24px;

    --letter-spacing: 0em;
    --disabled-opacity: 25%;

    /* ---- Dunamis tokens used by dm-* components ---- */
    --d-page: #f7f8fc;
    --d-surface: #ffffff;
    --d-surface-alt: #eef1fb;
    --d-line: #e4e8f4;
    --d-line-2: #d6dcef;
    --d-ink: #0d1233;
    --d-ink-2: #4a5278;
    --d-muted: #828aac;
    --d-brand: #2540d9;
    --d-brand-hover: #1c34b8;
    --d-brand-deep: #151e74;
    --d-brand-soft: #e9edff;
    --d-brand-ring: rgba(37, 64, 217, 0.28);
    --d-gold: #f6a609;
    --d-blue: #3d86f6;
    --d-fs-xs: clamp(0.75rem, 0.72rem + 0.12vw, 0.8rem);
    --d-fs-sm: clamp(0.875rem, 0.84rem + 0.16vw, 0.95rem);
    --d-fs-base: clamp(1rem, 0.96rem + 0.22vw, 1.08rem);
    --d-fs-lg: clamp(1.15rem, 1.08rem + 0.4vw, 1.35rem);
    --d-fs-xl: clamp(1.5rem, 1.3rem + 0.9vw, 2rem);
    --d-fs-2xl: clamp(2rem, 1.55rem + 2vw, 3rem);
    --d-fs-3xl: clamp(2.6rem, 1.9rem + 3.2vw, 4.4rem);
    --d-s-4: 1.5rem;
    --d-s-5: clamp(2rem, 1.5rem + 2vw, 3rem);
    --d-s-6: clamp(3.5rem, 2.5rem + 4vw, 6rem);
    --d-r-sm: 10px;
    --d-r-md: 16px;
    --d-r-lg: 24px;
    --d-sh-sm: 0 1px 2px rgba(13, 18, 51, 0.06), 0 1px 3px rgba(13, 18, 51, 0.05);
    --d-sh-md: 0 14px 34px -16px rgba(13, 18, 51, 0.22);
    --d-sh-lg: 0 40px 80px -28px rgba(21, 30, 116, 0.32);
    --d-ease: cubic-bezier(0.16, 1, 0.3, 1);
    --d-dur: 200ms;
    --d-dur-fast: 150ms;
    --d-maxw: 1180px;
}

/* ============================================================
   Global typography (header.tpl loads Sora/Manrope via @import)
   ============================================================ */
body { font-family: "Manrope", system-ui, sans-serif; background: var(--d-page); color: var(--d-ink); -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 { font-family: "Sora", system-ui, sans-serif; letter-spacing: -0.02em; }

/* ============================================================
   dm-* primitives
   ============================================================ */
/* ============================================================
   INNER-PAGE POLISH — applies the Dunamis brand to every stock
   WHMCS / Nexus page (client area, cart, invoices, domains,
   tickets, kb, contact…). Explicit overrides guarantee the
   indigo lands regardless of which token a component uses.
   ============================================================ */
/* Primary actions */
.btn-primary, .btn-primary:not(:disabled):not(.disabled) { background: var(--d-brand); border-color: var(--d-brand); color: #fff; box-shadow: 0 8px 20px -12px var(--d-brand-ring); }
.btn-primary:hover, .btn-primary:focus, .btn-primary:active,
.btn-primary:not(:disabled):not(.disabled):active, .show > .btn-primary.dropdown-toggle { background: var(--d-brand-hover); border-color: var(--d-brand-hover); color: #fff; }
.btn-outline-primary { color: var(--d-brand); border-color: var(--d-brand); }
.btn-outline-primary:hover { background: var(--d-brand); border-color: var(--d-brand); color: #fff; }
.btn-link { color: var(--d-brand); }
.btn-link:hover { color: var(--d-brand-hover); }
.btn { border-radius: var(--d-r-sm); font-weight: 600; }
.btn-lg { border-radius: var(--d-r-sm); }
a { color: var(--d-brand); }
a:hover { color: var(--d-brand-hover); }
.text-primary { color: var(--d-brand) !important; }
.bg-primary { background-color: var(--d-brand) !important; }
.badge-primary { background-color: var(--d-brand); }
.badge-info { background-color: var(--d-blue); }

/* Cards / panels */
.card, .panel { border-radius: var(--d-r-md); border-color: var(--d-line); box-shadow: var(--d-sh-sm); }
.card-header, .panel-heading { border-top-left-radius: var(--d-r-md); border-top-right-radius: var(--d-r-md); background: var(--d-surface-alt); border-bottom-color: var(--d-line); font-family: "Sora", sans-serif; }
.panel-title, .card-title { font-family: "Sora", sans-serif; }
.well { border-radius: var(--d-r-md); background: var(--d-surface-alt); border-color: var(--d-line); }

/* Forms */
.form-control, .custom-select, .input-group-text { border-radius: var(--d-r-sm); border-color: var(--d-line-2); color: var(--d-ink); }
.input-group > .form-control { border-radius: 0; }
.form-control:focus, .custom-select:focus { border-color: var(--d-brand); box-shadow: 0 0 0 3px var(--d-brand-ring); }
.input-group-text { background: var(--d-surface-alt); }
.custom-control-input:checked ~ .custom-control-label::before { background: var(--d-brand); border-color: var(--d-brand); }
label, .form-control-label { font-weight: 600; }

/* Breadcrumb → branded page header band */
.master-breadcrumb { background: var(--d-surface-alt); border-bottom: 1px solid var(--d-line); padding-block: 0.9rem; }
.master-breadcrumb .breadcrumb { background: transparent; margin: 0; padding: 0; }
.master-breadcrumb a, .master-breadcrumb .breadcrumb-item.active { color: var(--d-ink-2); }
.master-breadcrumb a:hover { color: var(--d-brand); }
#main-body { padding-block: var(--d-s-6); }
#main-body h1, #main-body .page-header h1 { font-size: var(--d-fs-2xl); }

/* Sidebar (client area) */
.sidebar .list-group-item { border-color: var(--d-line); }
.sidebar .list-group-item.active, .sidebar .panel-sidebar .list-group-item.active { background: var(--d-brand); border-color: var(--d-brand); color: #fff; }
.sidebar .list-group-item:hover { color: var(--d-brand); }
.sidebar .panel, .sidebar .card { box-shadow: var(--d-sh-sm); }

/* Tables */
.table thead th { border-bottom: 1px solid var(--d-line-2); color: var(--d-ink-2); font-family: "Sora", sans-serif; font-size: var(--d-fs-sm); }
.table td, .table th { border-top-color: var(--d-line); }
.table-hover tbody tr:hover { background: var(--d-surface-alt); }

/* Tabs / pagination */
.nav-tabs { border-bottom-color: var(--d-line); }
.nav-tabs .nav-link.active { color: var(--d-brand); border-color: var(--d-line) var(--d-line) #fff; }
.nav-tabs .nav-link:hover { border-color: var(--d-line); }
.page-link { color: var(--d-brand); border-color: var(--d-line); }
.page-item.active .page-link { background: var(--d-brand); border-color: var(--d-brand); }

/* Alerts */
.alert { border-radius: var(--d-r-md); border: 1px solid transparent; }
.alert-success { background: #e7f8ef; color: #0c7044; border-color: #bfe9d2; }
.alert-danger { background: #fdeaea; color: #9f0712; border-color: #f6cccc; }
.alert-info { background: var(--d-brand-soft); color: var(--d-brand-deep); border-color: #cdd7ff; }
.alert-warning { background: #fff4e0; color: #a86e00; border-color: #ffe2b3; }

/* Progress / misc accents */
.progress-bar { background: var(--d-brand); }
.text-success { color: #0c7044 !important; }

/* ---------- Domain checker (search results page) ---------- */
.home-domain-search { background: var(--d-brand-deep) !important; border-radius: 0; }
.home-domain-search h2 { color: #fff; }
.home-domain-search .input-group { box-shadow: var(--d-sh-md); border-radius: var(--d-r-sm); overflow: hidden; }
.home-domain-search .form-control { border: none; padding: 1rem 1.1rem; height: auto; }
.home-domain-search .btn { border-radius: 0; padding-inline: 1.6rem; }
.home-domain-search .tld-logos { display: flex; flex-wrap: wrap; gap: 1.2rem; justify-content: center; list-style: none; padding: 1.2rem 0 0; margin: 0; color: rgba(255,255,255,0.85); }
.home-domain-search .btn-link { color: #fff; }
.domain-checker-result, .domain-check-result { border-radius: var(--d-r-md); border: 1px solid var(--d-line); }
.domainchecker-result-available, .available { border-left: 4px solid #15b66b; }
.domainchecker-result-unavailable, .unavailable { border-left: 4px solid #e7000b; }

/* ---------- Auth: login + register (branded split) ---------- */
/* Auth pages: hide the WHMCS breadcrumb + sidebar, use the full width, keep it contained */
.tpl-login .master-breadcrumb, .tpl-register .master-breadcrumb, .tpl-clientregister .master-breadcrumb { display: none; }
.tpl-login .sidebar, .tpl-register .sidebar, .tpl-clientregister .sidebar { display: none; }
.tpl-login #main-body .col-lg-4, .tpl-register #main-body .col-lg-4, .tpl-clientregister #main-body .col-lg-4 { display: none; }
.tpl-login #main-body .container, .tpl-register #main-body .container, .tpl-clientregister #main-body .container { max-width: 100%; padding: 0; }
.tpl-login #main-body .row, .tpl-register #main-body .row, .tpl-clientregister #main-body .row { margin: 0; }
.tpl-login #main-body .primary-content, .tpl-register #main-body .primary-content, .tpl-clientregister #main-body .primary-content { flex: 0 0 100%; max-width: 100%; padding: 0; }
.dm-auth-form .form-control, #registration .form-control, #registration .field { background: #fff; }

/* Login: contained — an OPEN form on the page beside a dark, rounded brand card.
   Mirrors .dm-container max-width + padding so the form lines up with the header logo/nav. */
.dm-auth { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 4vw, 4.5rem); align-items: center; max-width: var(--d-maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2rem); }
@media (max-width: 900px) { .dm-auth { grid-template-columns: 1fr; gap: 2rem; } .dm-auth__aside { display: none; } }
.dm-auth__main { min-width: 0; }
.dm-auth__main .dm-auth-form { max-width: 450px; }
.dm-auth__head { display: grid; gap: 0.3rem; }
.dm-auth__sub { margin: 0; color: var(--d-ink-2); }
.dm-auth__aside { position: relative; overflow: hidden; background: var(--d-brand-deep); color: #fff; border-radius: var(--d-r-lg); box-shadow: var(--d-sh-lg); padding: clamp(2rem,1.5rem+3vw,3.5rem); }
.dm-auth__aside::after { content: ""; position: absolute; right: -20%; bottom: -25%; width: 460px; height: 460px; border-radius: 50%; background: radial-gradient(50% 50% at 50% 50%, rgba(61,134,246,0.55), transparent 70%); filter: blur(4px); }
.dm-auth__aside-inner { position: relative; z-index: 1; max-width: 420px;padding: 20px; }
.dm-auth__aside .dm-eyebrow { color: #9fb0ff; }
.dm-auth__aside h2 { color: #fff; font-size: var(--d-fs-xl); }
.dm-auth__aside p { color: rgba(255,255,255,0.8); }
.dm-auth__points { display: grid; gap: 1rem; margin-top: 1.6rem; padding: 0; list-style: none; }
.dm-auth__points li { display: flex; gap: 0.75rem; align-items: flex-start; color: rgba(255,255,255,0.9); font-size: var(--d-fs-sm); }
.dm-auth__points i { color: #9fb0ff; margin-top: 0.2rem; }
.dm-auth__title { font-family: "Sora", sans-serif; }
.dm-auth__quote { margin: 1.8rem 0 0; padding: 1.3rem 0 0; border-top: 1px solid rgba(255, 255, 255, 0.14); }
.dm-auth__quote p { margin: 0 0 0.8rem; color: rgba(255, 255, 255, 0.9); font-size: var(--d-fs-sm); font-style: italic; }
.dm-auth__quote .who { display: flex; align-items: center; gap: 0.7rem; }
.dm-auth__quote .who img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.dm-auth__quote .who b { display: block; color: #fff; font-size: var(--d-fs-sm); }
.dm-auth__quote .who span { color: rgba(255, 255, 255, 0.6); font-size: var(--d-fs-xs); }

/* Clean label-above auth fields (login + register) */
.dm-auth-form { display: grid; gap: 1.05rem; }
.dm-field { display: grid; gap: 0.4rem; align-content: start; }
.dm-field > label { font-size: var(--d-fs-sm); font-weight: 600; color: var(--d-ink); margin: 0; }
.dm-field .form-control, .dm-field select.form-control { width: 100%; }
.dm-field .field-help-text { font-size: var(--d-fs-xs); color: var(--d-muted); }
.dm-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.1rem; }
.dm-field--full { grid-column: 1 / -1; }
@media (max-width: 575px) { .dm-form-grid { grid-template-columns: 1fr; } }
.dm-auth__legend { font-family: "Sora", sans-serif; font-size: var(--d-fs-base); color: var(--d-ink); margin: 0 0 1rem; }
.dm-pw { position: relative; }
.dm-pw .form-control { padding-right: 2.9rem; }
.dm-pw__toggle { position: absolute; right: 0.35rem; top: 50%; transform: translateY(-50%); width: 2.3rem; height: 2.3rem; display: grid; place-items: center; background: none; border: 0; color: var(--d-muted); cursor: pointer; border-radius: 8px; }
.dm-pw__toggle:hover { color: var(--d-brand); }
.dm-auth__row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.dm-auth__row a { font-size: var(--d-fs-sm); color: var(--d-muted); }
.dm-auth__row a:hover { color: var(--d-brand); }
.dm-auth__check { display: flex; align-items: flex-start; gap: 0.55rem; margin: 0.4rem 0 0; font-size: var(--d-fs-sm); font-weight: 500; color: var(--d-ink-2); }
.dm-auth__check input { margin-top: 0.2rem; flex: none; }
.dm-auth__check a { color: var(--d-brand); }
.dm-auth__or { display: flex; align-items: center; gap: 0.8rem; margin: 1.2rem 0; color: var(--d-muted); font-size: var(--d-fs-xs); text-transform: uppercase; letter-spacing: 0.1em; }
.dm-auth__or::before, .dm-auth__or::after { content: ""; flex: 1; height: 1px; background: var(--d-line); }
.dm-auth__alt { margin: 0; color: var(--d-ink-2); font-size: var(--d-fs-sm); }
.dm-auth__alt a { font-weight: 600; }

/* register page: centered, branded */
#registration { max-width: 880px; margin-inline: auto; padding: var(--d-s-6) 1.2rem; }
#registration .dm-crumb { text-align: center; }
.dm-register-head { text-align: center; margin-bottom: 1.8rem; }
.dm-register-head h1 { font-size: var(--d-fs-2xl); margin: 0 0 0.4rem; }
.dm-register-head p { color: var(--d-ink-2); margin: 0; }
#registration .card-title { font-family: "Sora", sans-serif; font-size: var(--d-fs-lg); margin-bottom: 1.2rem; }

/* ---------- Inner marketing page hero ---------- */
.dm-phero { padding-block: clamp(2.2rem,1.5rem+3vw,4rem); }
.dm-phero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem,1rem+4vw,4rem); align-items: center; }
@media (max-width: 900px){ .dm-phero__grid { grid-template-columns: 1fr; text-align:center; } .dm-phero__media{order:-1} }
.dm-phero h1 { font-size: clamp(2.2rem,1.7rem+2.4vw,3.4rem); margin-bottom: 0.4rem; }
.dm-phero h1 em { font-style: normal; color: var(--d-brand); }
.dm-phero__sub { font-size: var(--d-fs-lg); color: var(--d-ink-2); max-width: 46ch; margin-bottom: 1.6rem; }
@media (max-width: 900px){ .dm-phero__sub{ margin-inline:auto; } }
.dm-phero__cta { display: flex; gap: 0.8rem; flex-wrap: wrap; }
@media (max-width: 900px){ .dm-phero__cta{ justify-content:center; } }
.dm-phero__art { position: relative; }
.dm-phero__art::before { content:""; position:absolute; inset:-8% -6%; z-index:0; background: radial-gradient(58% 58% at 55% 45%, rgba(37,64,217,0.12), transparent 70%); }
.dm-phero__art img { position: relative; z-index:1; width:100%; height:auto; }
.dm-crumb { font-size: var(--d-fs-sm); color: var(--d-muted); margin-bottom: 0.9rem; }
.dm-crumb a { color: var(--d-muted); } .dm-crumb a:hover { color: var(--d-brand); }

/* ---------- Feature split ---------- */
.dm-feature { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,1rem+4vw,4.5rem); align-items: center; }
.dm-feature + .dm-feature { margin-top: var(--d-s-6); }
@media (max-width: 840px){ .dm-feature { grid-template-columns: 1fr; } .dm-feature__media{order:-1} }
.dm-feature--rev .dm-feature__text { order: 2; }
@media (max-width: 840px){ .dm-feature--rev .dm-feature__text { order:1; } }
.dm-feature h2 { font-size: var(--d-fs-xl); }
.dm-feature__media img { width: 100%; height: auto; border-radius: var(--d-r-lg); }
.dm-list { display: grid; gap: 0.8rem; margin-top: 1.3rem; padding: 0; list-style: none; }
.dm-list li { display: flex; gap: 0.7rem; align-items: flex-start; color: var(--d-ink-2); font-size: var(--d-fs-sm); }
.dm-list .tick { flex: none; width: 22px; height: 22px; border-radius: 6px; background: var(--d-brand-soft); color: var(--d-brand); display: grid; place-items: center; font-size: 0.7rem; }

/* ---------- FAQ ---------- */
.dm-faq { max-width: 760px; margin-inline: auto; display: grid; gap: 0.8rem; }
.dm-faq details { background: var(--d-surface); border: 1px solid var(--d-line); border-radius: var(--d-r-md); box-shadow: var(--d-sh-sm); overflow: hidden; }
.dm-faq summary { list-style: none; cursor: pointer; padding: 1.1rem 1.3rem; font-family: "Sora", sans-serif; font-weight: 600; color: var(--d-ink); display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.dm-faq summary::-webkit-details-marker { display: none; }
.dm-faq summary::after { content: "+"; font-size: 1.4rem; color: var(--d-brand); line-height: 1; }
.dm-faq details[open] summary::after { content: "\2013"; }
.dm-faq details p { margin: 0; padding: 0 1.3rem 1.2rem; color: var(--d-ink-2); font-size: var(--d-fs-sm); }

/* pricing list inside marketing pages */
.dm-plan ul { list-style: none; padding: 1.2rem 0 0; margin: 0 0 1.4rem; border-top: 1px solid var(--d-line); display: grid; gap: 0.6rem; }
.dm-plan li { display: flex; gap: 0.55rem; align-items: center; color: var(--d-ink-2); font-size: var(--d-fs-sm); }
.dm-plan li i { color: var(--d-brand); }
.dm-plan--featured ul { border-top-color: rgba(255,255,255,0.16); }
.dm-plan--featured li { color: #fff; }
.dm-plan--featured li i { color: #9fb0ff; }
.dm-plan__tag { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); }

/* ---------- Generic content page (terms, privacy, about…) ---------- */
.dm-doc { max-width: 820px; margin-inline: auto; }
.dm-doc h1 { font-size: var(--d-fs-2xl); margin-bottom: 0.4rem; }
.dm-doc .dm-doc__meta { color: var(--d-muted); font-size: var(--d-fs-sm); margin-bottom: 2rem; }
.dm-doc h2 { font-size: var(--d-fs-lg); margin-top: 2rem; }
.dm-doc p, .dm-doc li { color: var(--d-ink-2); }
.dm-doc ul { list-style: disc; padding-left: 1.4rem; margin-bottom: 1rem; }

.dm-home a, .dm-header a, .dm-footer a, .dm-nav-links .nav-link, .dm-tile, .dm-arrow, .dm-btn { text-decoration: none; }
.dm-home a:hover, .dm-footer a:hover { text-decoration: none; }
.dm-container { width: 100%; max-width: var(--d-maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2rem); }
/* full-bleed: lets a section escape the WHMCS content column to span the viewport */
.dm-bleed { width: 100vw; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; }
/* Marketing pages (homepage + product/service pages): drop the WHMCS
   column padding so our full-bleed sections span the viewport. */
.tpl-homepage, .tpl-web-hosting, .tpl-wordpress-hosting, .tpl-vps-server,
.tpl-managed-cloud-server, .tpl-web-design { }
.tpl-homepage #main-body, .tpl-web-hosting #main-body, .tpl-wordpress-hosting #main-body,
.tpl-vps-server #main-body, .tpl-managed-cloud-server #main-body, .tpl-web-design #main-body { padding: 0; }
.tpl-homepage #main-body .container, .tpl-web-hosting #main-body .container,
.tpl-wordpress-hosting #main-body .container, .tpl-vps-server #main-body .container,
.tpl-managed-cloud-server #main-body .container, .tpl-web-design #main-body .container { max-width: 100%; padding: 0; }
.tpl-homepage #main-body .row, .tpl-web-hosting #main-body .row, .tpl-wordpress-hosting #main-body .row,
.tpl-vps-server #main-body .row, .tpl-managed-cloud-server #main-body .row, .tpl-web-design #main-body .row { margin: 0; }
.tpl-homepage #main-body .primary-content, .tpl-web-hosting #main-body .primary-content,
.tpl-wordpress-hosting #main-body .primary-content, .tpl-vps-server #main-body .primary-content,
.tpl-managed-cloud-server #main-body .primary-content, .tpl-web-design #main-body .primary-content { padding: 0; }
/* hide breadcrumb on the homepage only (product pages keep theirs) */
.tpl-homepage .master-breadcrumb { display: none; }
.dm-home { overflow-x: clip; }
.dm-section { padding-block: var(--d-s-6); }
.dm-section--alt { background: var(--d-surface-alt); }
.dm-section--ink { background: var(--d-brand-deep); color: #fff; }
.dm-eyebrow { display: inline-block; font-family: "JetBrains Mono", monospace; font-size: var(--d-fs-xs); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--d-brand); margin-bottom: 0.9rem; }
.dm-section--ink .dm-eyebrow { color: #9fb0ff; }
.dm-head { max-width: 620px; margin: 0 auto var(--d-s-5); text-align: center; }
.dm-head h2 { font-size: var(--d-fs-2xl); margin: 0 0 0.4rem; color: var(--d-ink); }
.dm-head p { font-size: var(--d-fs-lg); color: var(--d-ink-2); margin: 0; }
.dm-section--ink .dm-head h2 { color: #fff; }
.dm-section--ink .dm-head p { color: rgba(255, 255, 255, 0.78); }

.dm-btn { --bg: var(--d-brand); --fg: #fff; --bd: transparent; display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.8rem 1.5rem; font-weight: 600; font-size: var(--d-fs-sm); border: 1px solid var(--bd); border-radius: var(--d-r-sm); background: var(--bg); color: var(--fg); cursor: pointer; transition: transform var(--d-dur-fast) var(--d-ease), background var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease), border-color var(--d-dur); }
.dm-btn:hover { color: var(--fg); text-decoration: none; }
.dm-btn:active { transform: scale(0.97); }
.dm-btn-primary { box-shadow: 0 8px 20px -8px var(--d-brand-ring); }
.dm-btn-primary:hover { --bg: var(--d-brand-hover); transform: translateY(-2px); box-shadow: 0 14px 28px -10px var(--d-brand-ring); }
.dm-btn-ghost { --bg: var(--d-surface); --fg: var(--d-ink); --bd: var(--d-line-2); }
.dm-btn-ghost:hover { --bg: var(--d-surface-alt); transform: translateY(-2px); }
.dm-btn-lg { padding: 0.95rem 1.9rem; font-size: var(--d-fs-base); }
.dm-btn--onink { --bg: #fff; --fg: var(--d-brand-deep); }
.dm-btn--onink:hover { --bg: #eef1ff; transform: translateY(-2px); }
.dm-btn-block { width: 100%; }
@media (hover: none) { .dm-btn:hover { transform: none; } }

.dm-arrow { color: var(--d-brand); font-weight: 600; font-size: var(--d-fs-sm); display: inline-flex; align-items: center; gap: 0.35rem; }
.dm-arrow svg { width: 16px; height: 16px; transition: transform var(--d-dur) var(--d-ease); }
.dm-arrow:hover { color: var(--d-brand-hover); } .dm-arrow:hover svg { transform: translateX(4px); }

/* ---------- Header ---------- */
.dm-topbar { background: var(--d-brand-deep); color: #eef1ff; font-size: var(--d-fs-xs); text-align: center; padding: 0.5rem 1rem; }
.dm-topbar a, .dm-topbar strong { color: #fff; font-weight: 700; }
.dm-topbar a { text-decoration: underline; text-underline-offset: 2px; margin-left: 0.4rem; }
.dm-header { position: sticky; top: 0; z-index: 1030; background: rgba(247, 248, 252, 0.92); backdrop-filter: saturate(150%) blur(12px); border-bottom: 1px solid var(--d-line); }
.dm-navbar { padding: 0; }
.dm-navbar .dm-container { display: flex; align-items: center; flex-wrap: wrap; gap: clamp(2rem, 2.5vw, 3rem); padding-block: 0.7rem; }
.dm-logo { display: inline-flex; align-items: center; padding: 0; margin: 0; }
.dm-logo img { height: 52px; width: auto; }
.dm-logo--brandfilter img { filter: brightness(0); }
.dm-toggle { display: none; width: 44px; height: 44px; border-radius: 10px; background: var(--d-surface); border: 1px solid var(--d-line-2); color: var(--d-ink); align-items: center; justify-content: center; font-size: 1.1rem; }
.dm-menu { display: flex; align-items: center; flex: 1 1 auto; gap: 1rem; }
.dm-nav-links { display: flex; align-items: center; gap: clamp(0.5rem, 0.9vw, 1.4rem); list-style: none; margin: 0; padding: 0; }
.dm-nav-links.dm-primary { margin-right: auto; }
.dm-nav-links .nav-item { list-style: none; }
.dm-nav-links .nav-link { padding: 0.5rem 0.85rem; border-radius: 8px; font-size: var(--d-fs-sm); font-weight: 600; color: var(--d-ink-2); white-space: nowrap; transition: color var(--d-dur-fast), background var(--d-dur-fast); }
.dm-nav-links .nav-link:hover, .dm-nav-links .nav-item.active > .nav-link { color: var(--d-ink); background: var(--d-surface); }
.dm-nav-links .dropdown-menu { border: 1px solid var(--d-line); border-radius: var(--d-r-md); box-shadow: var(--d-sh-md); padding: 0.4rem; margin-top: 0.4rem; }
.dm-nav-links .dropdown-item { border-radius: 8px; font-size: var(--d-fs-sm); padding: 0.5rem 0.8rem; color: var(--d-ink-2); }
.dm-nav-links .dropdown-item:hover { background: var(--d-surface-alt); color: var(--d-ink); }
.dm-nav-cta { display: flex; align-items: center; gap: 0.6rem; }
.dm-cart { position: relative; display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 10px; color: var(--d-ink-2); border: 1px solid transparent; }
.dm-cart:hover { color: var(--d-ink); background: var(--d-surface); }
.dm-cart .badge { position: absolute; top: 2px; right: 2px; background: var(--d-brand); color: #fff; font-size: 0.6rem; }

/* Desktop (>=1200px): keep the whole header on ONE row — logo at the far left,
   then the nav links, then the cart + auth buttons pushed to the right.
   (Overrides Bootstrap's .navbar-collapse flex-basis:100% which was wrapping the
   menu onto its own row below the logo.) */
@media (min-width: 1200px) {
  .dm-navbar .dm-container { flex-wrap: nowrap; }
  .dm-header .dm-navbar .dm-menu { flex: 1 1 auto; flex-basis: auto; width: auto; min-width: 0; }
}

/* Tablet / small laptop / phone (<1200px): collapse the nav behind the toggle. */
@media (max-width: 1199.98px) {
  .dm-toggle { display: inline-flex; margin-left: auto; order: 3; }
  .dm-menu { order: 4; flex-basis: 100%; flex-direction: column; align-items: stretch; gap: 0.3rem; padding-top: 0.8rem; }
  .dm-nav-links { flex-direction: column; align-items: stretch; }
  .dm-nav-links .nav-link { padding: 0.8rem 0.9rem; font-size: var(--d-fs-base); }
  .dm-nav-cta { padding-top: 0.6rem; border-top: 1px solid var(--d-line); }
  .dm-nav-cta .dm-btn { flex: 1; }
}

/* ---------- Hero ---------- */
.dm-hero { padding-block: clamp(2.5rem, 1.5rem + 4vw, 5rem) var(--d-s-6); }
.dm-hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem, 1rem + 4vw, 4rem); align-items: center; }
@media (max-width: 900px) { .dm-hero__grid { grid-template-columns: 1fr; text-align: center; } }
.dm-hero h1 { font-size: var(--d-fs-3xl); margin-bottom: 0.35em; color: var(--d-ink); line-height: 1.08; }
.dm-hero h1 em { font-style: normal; color: var(--d-brand); }
.dm-hero__sub { font-size: var(--d-fs-lg); color: var(--d-ink-2); max-width: 40ch; margin-bottom: 1.8rem; }
@media (max-width: 900px) { .dm-hero__sub { margin-inline: auto; } }
.dm-hero__cta { display: flex; gap: 0.8rem; flex-wrap: wrap; }
@media (max-width: 900px) { .dm-hero__cta { justify-content: center; } }
.dm-hero__meta { margin-top: 1.8rem; display: flex; gap: 1.4rem; flex-wrap: wrap; color: var(--d-ink-2); font-size: var(--d-fs-sm); }
@media (max-width: 900px) { .dm-hero__meta { justify-content: center; } }
.dm-hero__meta span { display: inline-flex; align-items: center; gap: 0.4rem; }
.dm-hero__meta i { color: var(--d-brand); }
.dm-hero__media { position: relative; }
.dm-hero__art { position: relative; }
.dm-hero__art::before { content: ""; position: absolute; inset: -8% -6%; z-index: 0; background: radial-gradient(58% 58% at 58% 42%, rgba(37, 64, 217, 0.12), transparent 70%); }
.dm-hero__art img { position: relative; z-index: 1; width: 100%; height: auto; }
.dm-uptime { position: absolute; bottom: -18px; left: -18px; display: flex; align-items: center; gap: 0.7rem; background: var(--d-surface); border: 1px solid var(--d-line); border-radius: var(--d-r-sm); padding: 0.7rem 1rem; box-shadow: var(--d-sh-md); z-index: 2; }
.dm-uptime .pulse { width: 10px; height: 10px; border-radius: 50%; background: #15b66b; box-shadow: 0 0 0 0 rgba(21,182,107,0.5); animation: dmpulse 2.2s var(--d-ease) infinite; }
.dm-uptime b { font-family: "JetBrains Mono", monospace; font-size: var(--d-fs-base); color: var(--d-ink); }
.dm-uptime span { display: block; font-size: var(--d-fs-xs); color: var(--d-muted); }
@keyframes dmpulse { 70% { box-shadow: 0 0 0 10px rgba(21,182,107,0); } 100% { box-shadow: 0 0 0 0 rgba(21,182,107,0); } }
@media (max-width: 900px) { .dm-uptime { left: 50%; transform: translateX(-50%); } }

.dm-trust { border-top: 1px solid var(--d-line); border-bottom: 1px solid var(--d-line); background: var(--d-surface); }
.dm-trust__inner { display: flex; flex-wrap: wrap; gap: 1rem 2.5rem; justify-content: center; align-items: center; padding-block: 1.4rem; }
.dm-trust__inner span { font-size: var(--d-fs-sm); color: var(--d-ink-2); display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600; }
.dm-trust__inner i { color: var(--d-brand); }

/* ---------- Service cards ---------- */
.dm-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.1rem; }
.dm-card { display: flex; flex-direction: column; padding: 1.6rem; border-radius: var(--d-r-md); background: var(--d-surface); border: 1px solid var(--d-line); box-shadow: var(--d-sh-sm); transition: transform var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease), border-color var(--d-dur); }
.dm-card:hover { transform: translateY(-4px); box-shadow: var(--d-sh-md); border-color: var(--d-line-2); }
.dm-card__icon { width: 54px; height: 54px; border-radius: 14px; background: var(--d-brand-soft); display: grid; place-items: center; margin-bottom: 1.1rem; }
.dm-card__icon img { width: 30px; height: 30px; }
.dm-card__icon i { font-size: 1.4rem; color: var(--d-brand); }
.dm-card h3 { font-size: var(--d-fs-lg); margin-bottom: 0.35rem; color: var(--d-ink); }
.dm-card p { font-size: var(--d-fs-sm); color: var(--d-ink-2); margin-bottom: 1.3rem; }
.dm-card__foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--d-line); }
.dm-card__price small { display: block; font-size: var(--d-fs-xs); color: var(--d-muted); }
.dm-card__price b { font-size: var(--d-fs-lg); font-family: "Sora", sans-serif; color: var(--d-ink); }
.dm-card__price b span { font-size: 0.6em; font-weight: 600; color: var(--d-muted); }

/* ---------- Why-us ---------- */
.dm-why { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.4rem; }
.dm-why__item { padding: 1.4rem; }
.dm-why__icon { width: 56px; height: 56px; border-radius: 14px; background: var(--d-brand-soft); color: var(--d-brand); display: grid; place-items: center; margin-bottom: 1rem; }
.dm-why__icon i { font-size: 1.5rem; }
.dm-why__item h3 { font-size: var(--d-fs-lg); color: var(--d-ink); }
.dm-why__item p { font-size: var(--d-fs-sm); color: var(--d-ink-2); margin: 0; }

/* ---------- Pricing / product groups ---------- */
.dm-pricing { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.2rem; align-items: stretch; }
.dm-plan { display: flex; flex-direction: column; padding: 2rem 1.7rem; border-radius: var(--d-r-lg); background: var(--d-surface); border: 1px solid var(--d-line); box-shadow: var(--d-sh-sm); transition: transform var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease); text-align: left; }
.dm-plan:hover { transform: translateY(-4px); box-shadow: var(--d-sh-md); }
.dm-plan h3 { font-size: var(--d-fs-lg); margin-bottom: 0.3rem; color: var(--d-ink); }
.dm-plan__desc { color: var(--d-muted); font-size: var(--d-fs-sm); margin-bottom: 1.3rem; min-height: 2.6em; }
.dm-plan__price { display: flex; align-items: baseline; gap: 0.25rem; margin-bottom: 1.4rem; }
.dm-plan__price b { font-family: "Sora", sans-serif; font-size: clamp(2rem, 1.6rem + 1.4vw, 2.6rem); color: var(--d-ink); }
.dm-plan__price span { color: var(--d-muted); font-size: var(--d-fs-sm); }
.dm-plan .dm-btn { margin-top: auto; width: 100%; }
.dm-plan--featured { position: relative; background: var(--d-brand-deep); border-color: var(--d-brand-deep); color: #fff; box-shadow: var(--d-sh-lg); }
.dm-plan--featured h3, .dm-plan--featured .dm-plan__price b { color: #fff; }
.dm-plan--featured .dm-plan__desc, .dm-plan--featured .dm-plan__price span { color: rgba(255, 255, 255, 0.78); }
.dm-plan__tag { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); white-space: nowrap; font-size: var(--d-fs-xs); font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: #fff; background: var(--d-brand); padding: 0.32rem 0.9rem; border-radius: 999px; box-shadow: var(--d-sh-sm); }

/* ---------- Reviews (dark grid + brand glow) ---------- */
.dm-reviews { position: relative; overflow: hidden; }
.dm-reviews__glow { position: absolute; left: 50%; bottom: -26%; transform: translateX(-50%); width: min(820px, 110%); height: 560px; pointer-events: none; z-index: 0; background: radial-gradient(50% 50% at 50% 50%, rgba(61,134,246,0.7) 0%, rgba(61,134,246,0.28) 36%, transparent 70%); filter: blur(6px); }
.dm-reviews .dm-container { position: relative; z-index: 1; }
.dm-quotes { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.2rem; }
.dm-quote { position: relative; padding: 1.8rem; border-radius: var(--d-r-md); background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.1); display: flex; flex-direction: column; overflow: hidden; transition: transform var(--d-dur) var(--d-ease), background var(--d-dur), border-color var(--d-dur); }
.dm-quote::before { content: "\201C"; position: absolute; top: -0.7rem; right: 1.1rem; font-family: "Sora", serif; font-size: 5.5rem; line-height: 1; color: rgba(255,255,255,0.08); }
.dm-quote:hover { transform: translateY(-4px); background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); }
.dm-quote__stars { display: flex; gap: 0.25rem; color: #fff; margin-bottom: 1rem; }
.dm-quote__stars svg { width: 17px; height: 17px; }
.dm-quote p { color: rgba(255,255,255,0.88); font-size: var(--d-fs-sm); line-height: 1.66; margin-bottom: 1.6rem; }
.dm-quote__who { display: flex; align-items: center; gap: 0.85rem; margin-top: auto; padding-top: 1.2rem; border-top: 1px solid rgba(255,255,255,0.1); }
.dm-quote__who img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; object-position: center 20%; box-shadow: 0 0 0 2px var(--d-brand-deep), 0 0 0 3px rgba(255,255,255,0.18); }
.dm-quote__who b { display: block; font-size: var(--d-fs-sm); color: #fff; }
.dm-quote__who span { color: rgba(255,255,255,0.6); font-size: var(--d-fs-xs); }

/* ---------- Quick-action tiles ---------- */
.dm-tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1rem; }
.dm-tile { display: flex; flex-direction: column; align-items: center; gap: 0.7rem; text-align: center; padding: 1.5rem 1rem; border-radius: var(--d-r-md); background: var(--d-surface); border: 1px solid var(--d-line); box-shadow: var(--d-sh-sm); color: var(--d-ink); font-weight: 600; font-size: var(--d-fs-sm); transition: transform var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease), border-color var(--d-dur); }
.dm-tile:hover { transform: translateY(-4px); box-shadow: var(--d-sh-md); border-color: var(--d-line-2); color: var(--d-brand); text-decoration: none; }
.dm-tile i { font-size: 1.6rem; color: var(--d-brand); }

/* ---------- CTA band ---------- */
.dm-cta { text-align: center; padding: var(--d-s-6) var(--d-s-4); border-radius: var(--d-r-lg); background: var(--d-brand-deep); color: #fff; }
.dm-cta h2 { color: #fff; font-size: var(--d-fs-2xl); }
.dm-cta p { color: rgba(255,255,255,0.8); max-width: 46ch; margin: 0 auto 1.8rem; }
.dm-cta__cta { display: flex; gap: 0.8rem; justify-content: center; flex-wrap: wrap; }

/* ---------- Footer ---------- */
.dm-footer { background: var(--d-brand-deep); color: #fff; padding-block: var(--d-s-6) var(--d-s-4); }
.dm-footer a { color: rgba(255,255,255,0.68); }
.dm-footer__top { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; padding-bottom: var(--d-s-5); margin-bottom: var(--d-s-5); border-bottom: 1px solid rgba(255,255,255,0.12); }
.dm-footer__top h3 { color: #fff; font-size: var(--d-fs-xl); margin-bottom: 0.3rem; }
.dm-footer__top p { color: rgba(255,255,255,0.7); font-size: var(--d-fs-sm); margin: 0; }
.dm-subscribe { display: flex; gap: 0.5rem; flex: 1; min-width: 280px; max-width: 460px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.16); border-radius: var(--d-r-sm); padding: 0.4rem; }
.dm-subscribe input { flex: 1; min-width: 0; background: transparent; border: none; color: #fff; font-family: inherit; font-size: var(--d-fs-sm); padding: 0.55rem 0.8rem; }
.dm-subscribe input::placeholder { color: rgba(255,255,255,0.5); }
.dm-subscribe input:focus { outline: none; }
@media (max-width: 620px) { .dm-subscribe { max-width: none; } }
.dm-footer__grid { display: grid; grid-template-columns: 1.7fr repeat(3, 1fr); gap: 2rem; }
@media (max-width: 760px) { .dm-footer__grid { grid-template-columns: 1fr 1fr; } .dm-footer__brand { grid-column: 1 / -1; } }
.dm-footer__brand img { height: 40px; margin-bottom: 1rem; filter: brightness(0) invert(1); }
.dm-footer__brand p { color: rgba(255,255,255,0.7); font-size: var(--d-fs-sm); max-width: 300px; }
.dm-footer__contact { display: grid; gap: 0.55rem; margin: 1.2rem 0 0; padding: 0; list-style: none; }
.dm-footer__contact li { display: flex; align-items: center; gap: 0.6rem; color: rgba(255,255,255,0.75); font-size: var(--d-fs-sm); }
.dm-footer__contact svg { width: 18px; height: 18px; color: #9fb0ff; flex: none; }
.dm-footer__contact a { color: rgba(255,255,255,0.75); }
.dm-footer__contact a:hover { color: #fff; }
.dm-footer__social { display: flex; align-items: center; justify-content: center; gap: 0.6rem; margin-top: 1.4rem; padding: 0; list-style: none; }
.dm-footer__social li { list-style: none; }
.dm-footer__social a { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; background: rgba(255,255,255,0.08); color: #fff; line-height: 0; transition: transform var(--d-dur-fast) var(--d-ease), background var(--d-dur); }
.dm-footer__social a:hover { transform: translateY(-3px); background: rgba(255,255,255,0.16); color: #fff; }
.dm-footer__social img { width: 18px; height: 18px; filter: brightness(0) invert(1); }
.dm-footer__social i { font-size: 1rem; }
.dm-footer__col h4 { font-size: var(--d-fs-sm); color: #fff; letter-spacing: 0.04em; margin-bottom: 1rem; }
.dm-footer__col a { display: block; color: rgba(255,255,255,0.68); font-size: var(--d-fs-sm); padding-block: 0.32rem; transition: color var(--d-dur-fast); }
.dm-footer__col a:hover { color: #fff; }
.dm-footer__bar { margin-top: var(--d-s-5); padding-top: var(--d-s-4); border-top: 1px solid rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; color: rgba(255,255,255,0.55); font-size: var(--d-fs-xs); }
.dm-footer__bar .dm-footer__legal a { color: rgba(255,255,255,0.55); }
.dm-footer__legal { display: flex; gap: 1.4rem; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; }
.dm-footer__legal a:hover { color: #fff; }
@media (max-width: 560px) { .dm-footer__bar { justify-content: center; text-align: center; } }

/* ============================================================
   CLIENT AREA — branded Dunamis customer dashboard & account.
   Purely additive: new dm-* classes for the dashboard plus light
   scoped polish for the account sidebar and home panels. No WHMCS
   markup logic is changed, so every client page keeps full
   functionality — only the visual layer is branded.
   ============================================================ */

/* ---- Welcome banner (dashboard header) ---- */
.dm-welcome { position: relative; overflow: hidden; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.5rem; padding: clamp(1.6rem, 1.1rem + 2vw, 2.6rem) clamp(1.4rem, 1rem + 2vw, 2.6rem); border-radius: var(--d-r-lg); background: linear-gradient(115deg, var(--d-brand-deep), var(--d-brand)); color: #fff; box-shadow: var(--d-sh-md); }
.dm-welcome::after { content: ""; position: absolute; right: -10%; top: -55%; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(50% 50% at 50% 50%, rgba(61, 134, 246, 0.5), transparent 70%); pointer-events: none; }
.dm-welcome__text { position: relative; z-index: 1; }
.dm-welcome__eyebrow { display: inline-block; font-family: "JetBrains Mono", monospace; font-size: var(--d-fs-xs); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: #9fb0ff; margin-bottom: 0.5rem; }
.dm-welcome__title { color: #fff; font-size: var(--d-fs-xl); margin: 0 0 0.4rem; }
.dm-welcome__sub { color: rgba(255, 255, 255, 0.82); font-size: var(--d-fs-sm); margin: 0; max-width: 54ch; }
.dm-welcome__actions { position: relative; z-index: 1; display: flex; gap: 0.7rem; flex-wrap: wrap; }
.dm-btn--onink-ghost { --bg: rgba(255, 255, 255, 0.12); --fg: #fff; --bd: rgba(255, 255, 255, 0.3); }
.dm-btn--onink-ghost:hover { --bg: rgba(255, 255, 255, 0.2); transform: translateY(-2px); }
@media (max-width: 600px) { .dm-welcome__actions { width: 100%; } .dm-welcome__actions .dm-btn { flex: 1; } }

/* ---- Stat cards (replace the stock Nexus dashboard tiles) ---- */
.dm-statgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(168px, 1fr)); gap: 1rem; margin-bottom: 1.6rem; }
.dm-stat { position: relative; overflow: hidden; display: flex; flex-direction: column; padding: 1.4rem 1.4rem 1.45rem; border-radius: var(--d-r-md); background: var(--d-surface); border: 1px solid var(--d-line); box-shadow: var(--d-sh-sm); color: var(--d-ink); transition: transform var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease), border-color var(--d-dur); }
.dm-stat:hover { transform: translateY(-4px); box-shadow: var(--d-sh-md); border-color: var(--d-line-2); color: var(--d-ink); text-decoration: none; }
.dm-stat::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--d-brand); }
.dm-stat__icon { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 0.85rem; background: var(--d-brand-soft); color: var(--d-brand); font-size: 1.2rem; }
.dm-stat__num { font-family: "Sora", sans-serif; font-size: 2.3rem; line-height: 1; color: var(--d-ink); }
.dm-stat__label { margin-top: 0.35rem; font-size: var(--d-fs-xs); font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--d-muted); }
.dm-stat--green::before { background: var(--success); }
.dm-stat--green .dm-stat__icon { background: #e7f8ef; color: var(--success-accented); }
.dm-stat--red::before { background: var(--error); }
.dm-stat--red .dm-stat__icon { background: #fdeaea; color: var(--error-accented); }
.dm-stat--gold::before { background: var(--d-gold); }
.dm-stat--gold .dm-stat__icon { background: #fff4e0; color: var(--warning-accented); }

/* ---- Home panels (dynamic cards beneath the stats) ---- */
.client-home-cards .card { margin-bottom: 1.25rem; }
.client-home-cards .list-group-item { border-left: 0; border-right: 0; transition: background var(--d-dur-fast); }
.client-home-cards .list-group-item:hover { background: var(--d-surface-alt); }
.client-home-cards .list-group-item .badge { background: var(--d-brand-soft); color: var(--d-brand); }

/* ---- Account sidebar (left-hand nav shown on every client page) ---- */
.sidebar .card-sidebar .card-title { font-size: var(--d-fs-sm); letter-spacing: 0.02em; color: var(--d-ink); }
.sidebar .list-group-item { border-color: var(--d-line); color: var(--d-ink-2); font-size: var(--d-fs-sm); font-weight: 600; }
.sidebar .list-group-item .sidebar-menu-item-icon, .sidebar .list-group-item > i { color: var(--d-muted); transition: color var(--d-dur-fast); }
.sidebar .list-group-item:hover { color: var(--d-brand); background: var(--d-surface-alt); }
.sidebar .list-group-item:hover .sidebar-menu-item-icon, .sidebar .list-group-item:hover > i { color: var(--d-brand); }
.sidebar .list-group-item.active, .sidebar .panel-sidebar .list-group-item.active { background: var(--d-brand); border-color: var(--d-brand); color: #fff; box-shadow: 0 8px 18px -12px var(--d-brand-ring); }
.sidebar .list-group-item.active .sidebar-menu-item-icon, .sidebar .list-group-item.active > i, .sidebar .list-group-item.active .badge { color: #fff; }
.sidebar .list-group-item.active .badge { background: rgba(255, 255, 255, 0.22); }

/* ============================================================
   MODERN DOMAIN SEARCH — replaces the stock home-domain-search.
   Brand-deep band + white pill input + inline AJAX results.
   Shared by homepage, domainchecker page and domain.php.
   ============================================================ */
.dm-domainsearch { position: relative; overflow: hidden; padding-block: var(--d-s-5); background: linear-gradient(135deg, var(--d-brand-deep), var(--d-brand)); }
.dm-domainsearch::before { content: ""; position: absolute; right: -8%; top: -60%; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(50% 50% at 50% 50%, rgba(61, 134, 246, 0.45), transparent 70%); pointer-events: none; }
.dm-domainsearch .dm-container { position: relative; z-index: 1; }
.dm-domainsearch__card { max-width: 760px; margin-inline: auto; text-align: center; }
.dm-domainsearch__head { margin-bottom: 1.4rem; }
.dm-domainsearch .dm-eyebrow { color: #9fb0ff; }
.dm-domainsearch__title { color: #fff; font-size: var(--d-fs-2xl); margin: 0; }
.dm-domainsearch__bar { display: flex; align-items: center; gap: 0.4rem; padding: 0.5rem; background: #fff; border-radius: var(--d-r-md); box-shadow: var(--d-sh-lg); }
.dm-domainsearch__search-icon { flex: none; display: grid; place-items: center; width: 44px; color: var(--d-muted); font-size: 1.05rem; }
.dm-domainsearch__input { flex: 1; min-width: 0; border: none; background: transparent; font-family: inherit; font-size: var(--d-fs-lg); color: var(--d-ink); padding: 0.6rem 0.4rem; }
.dm-domainsearch__input:focus { outline: none; }
.dm-domainsearch__btn { flex: none; white-space: nowrap; }
.dm-domainsearch__alt { margin-top: 0.95rem; color: rgba(255, 255, 255, 0.8); font-size: var(--d-fs-sm); }
.dm-domainsearch__altlink { padding: 0; background: none; border: none; cursor: pointer; color: #fff; font-weight: 600; font-size: var(--d-fs-sm); text-decoration: underline; text-underline-offset: 3px; }
.dm-domainsearch__altlink:hover { color: #dfe5ff; }
.dm-domainsearch__tlds { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.6rem 1.5rem; margin: 1.5rem 0 0; padding: 0; list-style: none; }
.dm-domainsearch__tlds li { display: inline-flex; align-items: baseline; gap: 0.4rem; color: rgba(255, 255, 255, 0.92); font-size: var(--d-fs-sm); }
.dm-domainsearch__tld { font-family: "Sora", sans-serif; font-weight: 700; }
.dm-domainsearch__tldprice { color: rgba(255, 255, 255, 0.6); font-size: var(--d-fs-xs); }
.dm-domainsearch__pricing { display: inline-flex; align-items: center; gap: 0.45rem; margin-top: 1.2rem; color: #fff; font-size: var(--d-fs-sm); font-weight: 600; }
.dm-domainsearch__pricing:hover { color: #dfe5ff; }

/* inline AJAX result row */
.dm-domainsearch__results { margin-top: 1rem; text-align: left; }
.dm-domainsearch__result { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; padding: 1rem 1.2rem; background: #fff; border-radius: var(--d-r-md); box-shadow: var(--d-sh-md); border-left: 4px solid var(--d-line); }
.dm-domainsearch__result.is-available { border-left-color: var(--success); }
.dm-domainsearch__result.is-taken { border-left-color: var(--error); }
.dm-domainsearch__result.is-invalid { border-left-color: var(--warning); }
.dm-domainsearch__result-main { display: flex; align-items: center; gap: 0.5rem; font-size: var(--d-fs-base); color: var(--d-ink); }
.dm-domainsearch__result-main b { font-family: "Sora", sans-serif; }
.dm-domainsearch__result-main span { color: var(--d-muted); }
.dm-domainsearch__result.is-available .dm-domainsearch__result-main > i { color: var(--success); }
.dm-domainsearch__result.is-taken .dm-domainsearch__result-main > i { color: var(--error); }
.dm-domainsearch__result.is-invalid .dm-domainsearch__result-main > i { color: var(--warning); }
.dm-domainsearch__result-price { margin-left: auto; font-family: "Sora", sans-serif; font-weight: 700; font-size: var(--d-fs-lg); color: var(--d-ink); }
.dm-domainsearch__result-cta { flex: none; }
.dm-domainsearch__result.is-taken .dm-domainsearch__result-price { margin-left: auto; }
@media (max-width: 560px) {
    .dm-domainsearch__bar { flex-wrap: wrap; }
    .dm-domainsearch__search-icon { display: none; }
    .dm-domainsearch__input { flex: 1 1 100%; order: 1; padding: 0.7rem 0.8rem; }
    .dm-domainsearch__btn { flex: 1 1 100%; order: 2; }
    .dm-domainsearch__result-price { margin-left: 0; }
    .dm-domainsearch__result-cta { width: 100%; }
}

/* ---------- Domain page: TLD pricing grid ---------- */
.dm-tldgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; }
.dm-tld { display: flex; flex-direction: column; gap: 0.15rem; padding: 1.3rem 1.4rem; background: var(--d-surface); border: 1px solid var(--d-line); border-radius: var(--d-r-md); box-shadow: var(--d-sh-sm); transition: transform var(--d-dur) var(--d-ease), box-shadow var(--d-dur) var(--d-ease), border-color var(--d-dur); }
.dm-tld:hover { transform: translateY(-4px); box-shadow: var(--d-sh-md); border-color: var(--d-line-2); }
.dm-tld b { font-family: "Sora", sans-serif; font-size: var(--d-fs-lg); color: var(--d-ink); }
.dm-tld span { font-size: var(--d-fs-xs); color: var(--d-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.dm-tld__price { margin-top: 0.6rem; font-family: "Sora", sans-serif; font-weight: 700; font-size: var(--d-fs-lg); color: var(--d-brand); }
.dm-tld__price small { color: var(--d-muted); font-weight: 600; font-size: 0.6em; }

/* domain.php is a marketing page — make it full-bleed like the other service pages */
.tpl-domain #main-body { padding: 0; }
.tpl-domain #main-body .container { max-width: 100%; padding: 0; }
.tpl-domain #main-body .row { margin: 0; }
.tpl-domain #main-body .primary-content { padding: 0; }

/* ---------- Domain search: "other available extensions" suggestion chips ---------- */
.dm-domainsearch__suggest { margin-top: 0.9rem; text-align: left; }
.dm-domainsearch__suggest-label { margin: 0 0 0.6rem; color: rgba(255, 255, 255, 0.8); font-size: var(--d-fs-sm); }
.dm-domainsearch__suggest-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.6rem; }
.dm-domainsearch__suggest-item { display: flex; align-items: center; gap: 0.6rem; padding: 0.7rem 0.95rem; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.16); border-radius: var(--d-r-sm); color: #fff; font-family: inherit; text-align: left; cursor: pointer; transition: background var(--d-dur-fast), border-color var(--d-dur-fast), transform var(--d-dur-fast); }
.dm-domainsearch__suggest-item:hover { background: rgba(255, 255, 255, 0.16); border-color: rgba(255, 255, 255, 0.32); transform: translateY(-2px); }
.dm-domainsearch__suggest-name { font-family: "Sora", sans-serif; font-weight: 600; }
.dm-domainsearch__suggest-price { margin-left: auto; color: rgba(255, 255, 255, 0.85); font-size: var(--d-fs-sm); }
.dm-domainsearch__suggest-add { display: inline-flex; align-items: center; gap: 0.3rem; color: #9fb0ff; font-weight: 600; font-size: var(--d-fs-sm); }

/* ---------- Knowledgebase readability (excerpts + category text were too light) ---------- */
.kb-article-item small, .kb-article-item small * { color: var(--d-ink-2) !important; }
.kb-article-item small { display: block; margin-top: 0.3rem; line-height: 1.5; }
.kb-article-item .text-black-50 { color: var(--d-muted) !important; }
.kb-category .card-body { color: var(--d-ink); }
.kb-category .card-body .text-muted, .kb-category .card-body .text-muted small { color: var(--d-ink-2) !important; }
.kbarticle-content, .kbarticle-content p, .kbarticle-content li { color: var(--d-ink-2); }
