/* =====================================================================
   WebRust Dashboard — Layout, sidebar, topbar, cards, tables, stats.
   Companion to styles.css (tokens, buttons, badges, forms).
   --------------------------------------------------------------------- */

/* --- Layout ----------------------------------------------------------- */
.dash-body {
    background: var(--wr-bg);
    min-height: 100vh;
    color: var(--wr-ink);
}

.dash-layout {
    display: flex;
    min-height: 100vh;
    align-items: stretch;
}

.dash-main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: var(--wr-bg);
}

.dash-content {
    flex: 1;
    padding: 8px 36px 48px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    overflow-x: hidden;
}

.dash-alert-wrap {
    padding: 14px 36px 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* --- Sidebar (navy) --------------------------------------------------- */
.dash-sidebar {
    width: 248px;
    flex: 0 0 248px;
    background: var(--wr-navy);
    color: var(--wr-navy-text);
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(255, 255, 255, 0.04);
    position: sticky;
    top: 0;
    align-self: flex-start;
    height: 100vh;
    overflow-y: auto;
}

.dash-sidebar::-webkit-scrollbar { width: 6px; }
.dash-sidebar::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 3px;
}

.dash-logo {
    padding: 22px 24px 28px;
}

.dash-logo a {
    display: inline-flex;
    align-items: center;
}

.dash-logo .logo-img {
    height: 26px;
    width: auto;
    filter: brightness(0) invert(1);
}

.dash-nav {
    flex: 1;
    padding: 0 14px;
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.dash-nav-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.dash-nav-label {
    font-size: 10px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color: var(--wr-navy-text-muted);
    font-weight: 600;
    padding: 0 10px;
    display: block;
}

.dash-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    background: transparent;
    color: var(--wr-navy-text);
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}

.dash-nav-item:hover {
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    text-decoration: none;
}

.dash-nav-item .material-symbols-outlined {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.55);
    transition: color 0.12s;
}

.dash-nav-item:hover .material-symbols-outlined {
    color: #fff;
}

.dash-nav-item.active {
    background: rgba(255, 255, 255, 0.08);
    color: var(--wr-navy-text-active);
    font-weight: 600;
}

.dash-nav-item.active .material-symbols-outlined {
    color: #fff;
}

.dash-sidebar-footer {
    padding: 14px 14px 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.dash-sidebar-user-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    min-width: 0;
}

.dash-sidebar-avatar {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, #2541e0, #5677ff);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.dash-sidebar-avatar .material-symbols-outlined {
    font-size: 18px;
    color: #fff;
}

.dash-sidebar-user-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.dash-sidebar-user-name {
    font-size: 12px;
    color: #fff;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash-sidebar-user-handle {
    font-family: var(--wr-font-mono);
    font-size: 11px;
    color: var(--wr-navy-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash-sidebar-logout {
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
    border-radius: 8px;
    background: transparent;
    border: 0;
    color: var(--wr-navy-text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}

.dash-sidebar-logout:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    text-decoration: none;
}

.dash-sidebar-logout .material-symbols-outlined {
    font-size: 16px;
}

/* Legacy single-line user pill (kept so old code keeps working) */
.dash-sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: #fff;
    font-weight: 500;
}

/* --- Topbar ----------------------------------------------------------- */
.dash-topbar {
    padding: 26px 36px 16px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    background: var(--wr-bg);
}

.dash-topbar-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    flex: 1 1 auto;
}

.dash-page-title {
    margin: 0;
    font-size: 26px;
    font-weight: 600;
    letter-spacing: -0.6px;
    color: var(--wr-ink);
    line-height: 1.15;
}

.dash-page-subtitle {
    margin: 4px 0 0;
    font-size: 14px;
    color: var(--wr-ink-3);
}

.dash-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--wr-ink-3);
    margin: 0 0 2px;
    flex-wrap: wrap;
}

.dash-breadcrumb a {
    color: var(--wr-ink-3);
    text-decoration: none;
}

.dash-breadcrumb a:hover {
    color: var(--wr-blue);
    text-decoration: none;
}

.dash-breadcrumb-sep {
    color: var(--wr-ink-4);
    font-size: 11px;
}

.dash-topbar-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.dash-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid var(--wr-border);
    background: var(--wr-surface);
    font-size: 12px;
    color: var(--wr-ink-2);
    font-weight: 500;
    white-space: nowrap;
}

.dash-status-pill::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

.dash-actions {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

/* --- Card ------------------------------------------------------------- */
.dash-card {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
    overflow: hidden;
}

.dash-card-header {
    padding: 14px 18px;
    border-bottom: 1px solid var(--wr-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.dash-card-title {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--wr-ink);
    letter-spacing: -0.1px;
    line-height: 1.4;
}

.dash-card-subtitle {
    margin: 2px 0 0;
    font-size: 12px;
    color: var(--wr-ink-3);
    font-weight: 400;
}

.dash-card-status {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.dash-card-body {
    padding: 18px;
}

.dash-card-footer {
    padding: 14px 18px;
    border-top: 1px solid var(--wr-border);
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    background: var(--wr-surface);
}

.dash-card-form-pad {
    padding: 18px;
}

.dash-grid-2 {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 18px;
    align-items: flex-start;
}

.dash-stack {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

/* Payment method block (account page) */
.payment-method {
    display: flex;
    align-items: center;
    gap: 12px;
}

.payment-method-logo {
    width: 44px;
    height: 30px;
    border-radius: 4px;
    background: linear-gradient(135deg, #cc0066, #ff6f1e);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

.payment-method-body { flex: 1; min-width: 0; }
.payment-method-name { font-size: 13px; font-weight: 500; color: var(--wr-ink); }
.payment-method-account { font-size: 11px; color: var(--wr-ink-3); margin-top: 2px; }

@media (max-width: 900px) {
    .dash-grid-2 {
        grid-template-columns: 1fr;
    }
}

/* --- Info list (label / value rows) ----------------------------------- */
.dash-info-list {
    display: flex;
    flex-direction: column;
}

.dash-info-row {
    padding: 12px 18px;
    border-bottom: 1px solid var(--wr-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 44px;
}

.dash-info-row:last-child {
    border-bottom: 0;
}

.dash-info-label {
    font-size: 13px;
    color: var(--wr-ink-3);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dash-info-label small {
    font-size: 11px;
    color: var(--wr-ink-4);
}

.dash-info-value {
    font-size: 13px;
    color: var(--wr-ink);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    text-align: right;
}

/* --- Code blocks ------------------------------------------------------ */
.dash-code-block {
    background: var(--wr-surface-alt);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-sm);
    padding: 10px 12px;
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink);
    white-space: pre-wrap;
    word-break: break-all;
}

.dash-link {
    color: var(--wr-blue);
    text-decoration: none;
}

.dash-link:hover {
    text-decoration: underline;
}

/* --- Tables ----------------------------------------------------------- */
.dash-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    color: var(--wr-ink);
}

.dash-table thead th {
    padding: 10px 18px;
    background: var(--wr-surface-alt);
    border-bottom: 1px solid var(--wr-border);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color: var(--wr-ink-3);
    text-align: left;
    white-space: nowrap;
}

.dash-table tbody td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--wr-border);
    vertical-align: middle;
}

.dash-table tbody tr:last-child td {
    border-bottom: 0;
}

.dash-table tbody tr:hover {
    background: var(--wr-surface-alt);
}

.dash-table .dash-table-mono {
    font-family: var(--wr-font-mono);
    font-size: 12px;
}

.dash-table-muted {
    color: var(--wr-ink-3);
}

.dash-table-empty {
    padding: 32px 18px !important;
    text-align: center;
    color: var(--wr-ink-3);
    font-size: 13px;
}

.dash-table-empty:hover {
    background: transparent !important;
}

.dash-table-actions,
td.dash-table-actions {
    text-align: right;
    white-space: nowrap;
}

.dash-table-actions .btn {
    margin-left: 4px;
}

/* --- Stats / soft stats ----------------------------------------------- */
.dash-stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.dash-stat-card {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    padding: 20px 22px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.dash-stat-icon {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    border-radius: 10px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.dash-stat-icon .material-symbols-outlined {
    font-size: 20px;
}

.dash-stat-body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.dash-stat-label {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
    white-space: nowrap;
}

.dash-stat-num {
    font-size: 22px;
    font-weight: 600;
    color: var(--wr-ink);
    letter-spacing: -0.4px;
    line-height: 1.1;
}

.dash-stat-body .soft-stat-sub {
    margin-top: 2px;
}

/* Hero strip — used at top of detail pages */
.dash-hero {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: 14px;
    padding: 18px 22px;
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
}

.dash-hero-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 12px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.dash-hero-icon .material-symbols-outlined {
    font-size: 22px;
}

.dash-hero-body {
    flex: 1 1 280px;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dash-hero-title-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.dash-hero-title {
    margin: 0;
    font-size: 17px;
    font-weight: 600;
    color: var(--wr-ink);
}

.dash-hero-meta {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash-hero-stats {
    display: flex;
    gap: 22px;
    align-items: center;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.soft-stat {
    min-width: 0;
}

.soft-stat-label {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
    white-space: nowrap;
}

.soft-stat-value {
    font-size: 20px;
    color: var(--wr-ink);
    font-weight: 600;
    letter-spacing: -0.4px;
    margin-top: 2px;
    white-space: nowrap;
}

.soft-stat-sub {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 2px;
    white-space: nowrap;
}

/* --- Tabs ------------------------------------------------------------- */
.dash-tabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--wr-border);
    overflow-x: auto;
    margin-bottom: 4px;
}

.dash-tab {
    padding: 10px 14px;
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    color: var(--wr-ink-3);
    font-size: 13px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: -1px;
    cursor: pointer;
    white-space: nowrap;
    text-decoration: none;
}

.dash-tab:hover {
    color: var(--wr-ink);
    text-decoration: none;
}

.dash-tab.active {
    color: var(--wr-ink);
    border-bottom-color: var(--wr-blue);
    font-weight: 600;
}

.dash-tab .material-symbols-outlined { font-size: 16px; }
.dash-tab.active .material-symbols-outlined { color: var(--wr-blue); }

/* --- Tab panes (vanilla JS hide/show) -------------------------------- */
.pkg-tab-pane {
    display: none;
}

.pkg-tab-pane.active {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.pkg-tab-side {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

/* --- Usage bars (limieten) -------------------------------------------- */
.usage-row {
    padding: 12px 0;
    border-bottom: 1px solid var(--wr-border);
}

.usage-row:last-child { border-bottom: 0; }

.usage-row-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.usage-row-label {
    font-size: 12px;
    color: var(--wr-ink-3);
    font-weight: 500;
}

.usage-row-value {
    font-size: 12px;
    color: var(--wr-ink);
}

.usage-bar {
    height: 6px;
    background: var(--wr-surface-alt);
    border-radius: 999px;
    overflow: hidden;
}

.usage-bar-fill {
    height: 100%;
    background: var(--wr-blue);
    border-radius: 999px;
    transition: width 0.6s ease;
}

/* --- Quick actions list ---------------------------------------------- */
.quick-actions {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 0;
}

.dash-card-body.quick-actions {
    padding: 8px;
}

.quick-action {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 8px;
    background: transparent;
    border: 0;
    width: 100%;
    text-align: left;
    font-size: 13px;
    color: var(--wr-ink-2);
    text-decoration: none;
    cursor: pointer;
    transition: background 0.12s;
    font-family: inherit;
}

.quick-action:hover {
    background: var(--wr-surface-alt);
    text-decoration: none;
    color: var(--wr-ink);
}

.quick-action-icon {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--wr-surface-alt);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--wr-ink-2);
    flex-shrink: 0;
}

.quick-action-icon .material-symbols-outlined { font-size: 16px; }
.quick-action-label { flex: 1; }
.quick-action-chevron { color: var(--wr-ink-4); font-size: 16px !important; }

/* --- Pakketten overzicht (klant) — hero card with sub-items ---------- */
.pkg-card {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: 18px;
    padding: 26px 28px;
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
    transition: border-color 0.15s, box-shadow 0.18s, transform 0.15s;
    cursor: pointer;
    outline: none;
    display: block;
    text-decoration: none;
    color: inherit;
}

.pkg-card:hover,
.pkg-card:focus-visible {
    border-color: var(--wr-blue);
    box-shadow: 0 10px 28px rgba(11, 20, 38, 0.08);
    transform: translateY(-1px);
}

.pkg-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.pkg-card-icon {
    width: 52px;
    height: 52px;
    flex: 0 0 52px;
    border-radius: 14px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.pkg-card-icon .material-symbols-outlined { font-size: 26px; }

.pkg-card-id {
    flex: 1 1 200px;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pkg-card-type {
    font-size: 12px;
    color: var(--wr-ink-3);
}

.pkg-card-name {
    margin: 2px 0 0;
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.3px;
    color: var(--wr-ink);
}

.pkg-card-domain {
    font-size: 13px;
    color: var(--wr-blue);
    text-decoration: none;
}

.pkg-card-domain:hover { text-decoration: underline; }

.pkg-card-head-right {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.pkg-card-open {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 500;
    color: var(--wr-ink-3);
    transition: color 0.15s, transform 0.18s;
    white-space: nowrap;
}

.pkg-card-open .material-symbols-outlined { font-size: 16px; }

.pkg-card:hover .pkg-card-open {
    color: var(--wr-blue);
    transform: translateX(2px);
}

.pkg-card-stats {
    margin-top: 22px;
    padding-top: 20px;
    border-top: 1px solid var(--wr-border);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

@media (max-width: 720px) {
    .pkg-card-stats {
        grid-template-columns: repeat(2, 1fr);
    }
}

.pkg-card-included {
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--wr-border);
}

.pkg-card-included-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    color: var(--wr-ink-3);
    margin-bottom: 10px;
}

.pkg-card-rows {
    display: grid;
    gap: 6px;
}

.pkg-row {
    display: grid;
    grid-template-columns: 32px 1fr auto auto;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 12px;
    background: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s;
    text-decoration: none;
    color: inherit;
}

.pkg-row:hover {
    background: var(--wr-surface-alt);
    border-color: var(--wr-border);
    text-decoration: none;
}

.pkg-row-icon {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    background: var(--wr-surface-alt);
    border: 1px solid var(--wr-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--wr-ink-2);
}

.pkg-row-icon .material-symbols-outlined { font-size: 16px; }

.pkg-row-body {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.pkg-row-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--wr-ink);
    line-height: 1.2;
}

.pkg-row-meta {
    font-size: 11px;
    color: var(--wr-ink-3);
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pkg-row-chevron {
    color: var(--wr-ink-3);
    font-size: 18px !important;
    transition: color 0.12s;
}

.pkg-row:hover .pkg-row-chevron {
    color: var(--wr-blue);
}

/* --- Solid info CTA card (domeinen "Heb je een domein elders staan?") */
.info-cta {
    padding: 22px 24px;
    border-radius: 18px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    display: flex;
    align-items: center;
    gap: 16px;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
}

.info-cta-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 12px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.info-cta-icon .material-symbols-outlined { font-size: 22px; }

.info-cta-body { flex: 1; min-width: 0; }
.info-cta-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--wr-ink);
    margin: 0;
}
.info-cta-sub {
    font-size: 13px;
    color: var(--wr-ink-3);
    margin-top: 4px;
}

/* --- Dashed "add package" CTA --------------------------------------- */
.pkg-add-cta {
    padding: 20px 22px;
    border-radius: 18px;
    background: transparent;
    border: 1.5px dashed var(--wr-border-strong);
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
    color: inherit;
    transition: background 0.12s, border-color 0.12s;
}

.pkg-add-cta:hover {
    background: var(--wr-surface);
    border-color: var(--wr-blue);
    text-decoration: none;
}

.pkg-add-cta-icon {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border-radius: 10px;
    background: var(--wr-surface);
    box-shadow: var(--wr-shadow-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--wr-ink-2);
}

.pkg-add-cta-body { flex: 1; min-width: 0; }
.pkg-add-cta-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.pkg-add-cta-sub { font-size: 12px; color: var(--wr-ink-3); margin-top: 2px; }

/* --- Legacy pkg-group / pkg-standalone (kept for compatibility) ------ */
.pkg-group,
.pkg-standalone {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: 18px;
    overflow: hidden;
    transition: border-color 0.15s, box-shadow 0.18s, transform 0.15s;
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
}

.pkg-group:hover,
.pkg-standalone:hover {
    border-color: var(--wr-blue);
    box-shadow: 0 10px 28px rgba(11, 20, 38, 0.08);
    transform: translateY(-1px);
}

.pkg-group-header,
.pkg-standalone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 22px 24px;
    cursor: pointer;
}

.pkg-standalone {
    padding: 22px 24px;
}

.pkg-group-header-left,
.pkg-standalone-left {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.pkg-group-toggle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    font-size: 11px;
    transition: transform 0.15s;
    flex-shrink: 0;
}

.pkg-group-toggle-icon.open {
    transform: rotate(90deg);
}

.pkg-group-name,
.pkg-standalone-name {
    font-size: 17px;
    font-weight: 600;
    color: var(--wr-ink);
    letter-spacing: -0.2px;
    line-height: 1.2;
}

.pkg-group-sub {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 2px;
}

.pkg-group-header-right,
.pkg-row-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.pkg-group-children {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease;
    border-top: 1px solid transparent;
}

.pkg-group-children.open {
    max-height: 600px;
    border-top-color: var(--wr-border);
    padding: 6px 14px 14px;
}

.pkg-child-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 10px 14px;
    border-radius: 10px;
    transition: background 0.12s;
    margin-top: 4px;
}

.pkg-child-item:hover {
    background: var(--wr-surface-alt);
}

.pkg-child-item-left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex-wrap: wrap;
}

.pkg-child-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--wr-ink);
}

.pkg-child-tag {
    margin-left: 4px;
}

.pkg-child-row,
.pkg-child-indent {
    padding-left: 18px;
}

/* --- Pakkettype detail wrap (admin: package_types pricing list) -------- */
.pkg-type-detail-wrap {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.pkg-grid,
.pakket-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}

.pakket-card {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: 14px;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pakket-type {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
}

.pakket-naam {
    font-size: 18px;
    font-weight: 600;
    color: var(--wr-ink);
}

.pakket-prijs {
    font-size: 20px;
    font-weight: 600;
    color: var(--wr-ink);
    margin-top: 4px;
}

.pakket-prijs .per,
.period {
    font-size: 12px;
    color: var(--wr-ink-3);
    font-weight: 400;
}

.pakket-specs {
    font-size: 12px;
    color: var(--wr-ink-3);
}

/* --- Domain link row (mail package detail, etc.) ---------------------- */
.domain-link-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
}

.domain-link-select {
    flex: 1;
}

.domain-spinner,
.dns-spinner {
    width: 14px;
    height: 14px;
    border: 2px solid var(--wr-border-strong);
    border-top-color: var(--wr-blue);
    border-radius: 50%;
    animation: dash-spin 0.8s linear infinite;
}

.domain-spinner-wrap {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--wr-ink-3);
    font-size: 12px;
}

@keyframes dash-spin {
    to { transform: rotate(360deg); }
}

/* --- DNS templates ---------------------------------------------------- */
.dns-new-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr auto;
    gap: 8px;
    align-items: end;
    margin-top: 10px;
}

.dns-submit-cell {
    display: flex;
    align-items: flex-end;
}

.dns-content-cell {
    word-break: break-all;
    font-family: var(--wr-font-mono);
    font-size: 12px;
}

.dns-set-ip-label {
    font-size: 11px;
    color: var(--wr-ink-3);
}

/* --- Logs ------------------------------------------------------------- */
.logs-output {
    background: #0c1729;
    color: #d6e1ff;
    font-family: var(--wr-font-mono);
    font-size: 12px;
    line-height: 1.5;
    padding: 14px 16px;
    border-radius: var(--wr-rad-md);
    overflow: auto;
    max-height: 600px;
    white-space: pre-wrap;
}

.logs-label {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
}

.log-level-debug { color: #6b7383; }
.log-level-info  { color: #2541e0; font-weight: 600; }
.log-level-warn  { color: #a16207; font-weight: 600; }
.log-level-error { color: #b91c1c; font-weight: 600; }

/* --- Audit log -------------------------------------------------------- */
.audit-cell-time {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-2);
    white-space: nowrap;
}

.audit-cell-ip {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-3);
}

.audit-cell-detail {
    font-size: 12px;
    color: var(--wr-ink-3);
}

.audit-meta {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 6px;
}

/* --- Agents page (admin) ---------------------------------------------- */
.dash-agent-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dash-agent-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-md);
}

.dash-agent-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--wr-ink-4);
    flex-shrink: 0;
}

.dash-agent-dot.online,
.dash-agent-dot[data-status="online"] {
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

.dash-agent-dot.offline,
.dash-agent-dot[data-status="offline"] {
    background: var(--wr-red);
}

.dash-agent-info { flex: 1; min-width: 0; }
.dash-agent-name { font-weight: 600; color: var(--wr-ink); font-size: 14px; }
.dash-agent-url {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-3);
}

/* --- Mail (mail package detail) --------------------------------------- */
.mail-section {
    padding: 16px 18px;
    border-bottom: 1px solid var(--wr-border);
}

.mail-section:last-child { border-bottom: 0; }

.mail-section-intro {
    font-size: 13px;
    color: var(--wr-ink-2);
    margin-bottom: 12px;
}

.mail-section-summary {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 4px;
}

.mail-noreply-label {
    font-size: 11px;
    color: var(--wr-ink-3);
}

.alias-help {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 6px;
}

.alias-subheading {
    font-size: 13px;
    font-weight: 600;
    color: var(--wr-ink);
    margin: 14px 0 6px;
}

/* --- File browser (redesign) ----------------------------------------- */

.u-spacer { flex: 1; }

/* Author display rules below outrank the UA [hidden] rule, so make the
   `hidden` attribute authoritative for the toggled elements. */
.wr-fb-item[hidden],
.wr-fb-listhead[hidden],
.wr-fb-selbar[hidden],
.wr-fb-empty[hidden] { display: none !important; }

/* Storage strip */
.wr-storage-strip {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    row-gap: 14px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    padding: 16px 20px;
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
}

.wr-storage-icon {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    border-radius: 11px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-storage-icon .material-symbols-outlined { font-size: 20px; }

.wr-storage-meta { min-width: 150px; }
.wr-storage-label { font-size: 12px; color: var(--wr-ink-3); }
.wr-storage-value { font-size: 15px; font-weight: 600; color: var(--wr-ink); margin-top: 2px; }
.wr-storage-value span { font-weight: 400; color: var(--wr-ink-3); font-size: 13px; }

.wr-storage-bar {
    flex: 1;
    min-width: 120px;
    height: 8px;
    border-radius: 999px;
    background: var(--wr-surface-alt);
    border: 1px solid var(--wr-border);
    overflow: hidden;
}
.wr-storage-fill {
    height: 100%;
    min-width: 2px;
    background: var(--wr-blue);
    border-radius: 999px;
    transition: width 0.3s ease;
}
.wr-storage-pct { font-size: 12px; color: var(--wr-ink-3); flex-shrink: 0; }
.wr-storage-divider { width: 1px; height: 32px; background: var(--wr-border); flex-shrink: 0; }
.wr-storage-stats { display: flex; gap: 22px; flex-shrink: 0; }

/* File browser card */
.wr-fb {
    --wr-fb-cols: 34px minmax(150px, 1fr) 120px 96px 150px 104px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
    overflow: hidden;
}

/* Toolbar */
.wr-fb-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 12px 16px;
    border-bottom: 1px solid var(--wr-border);
}

.wr-fb-crumbs {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1 1 auto;
    min-width: 0;
}
.wr-fb-up {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    margin-right: 4px;
    border: 1px solid var(--wr-border);
    border-radius: 8px;
    background: var(--wr-surface);
    color: var(--wr-ink-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.12s;
}
.wr-fb-up:hover:not(:disabled) { background: var(--wr-surface-alt); }
.wr-fb-up:disabled { opacity: 0.4; cursor: not-allowed; }
.wr-fb-up .material-symbols-outlined { font-size: 17px; }
.wr-fb-home-icon { font-size: 17px; color: var(--wr-ink-3); }
.wr-fb-crumb-sep { font-size: 16px; color: var(--wr-ink-4); }
.wr-fb-crumb {
    padding: 2px 4px;
    font-size: 13px;
    font-weight: 500;
    color: var(--wr-blue);
    white-space: nowrap;
    text-decoration: none;
    border-radius: 5px;
}
.wr-fb-crumb:hover { text-decoration: underline; }
.wr-fb-crumb.is-current { color: var(--wr-ink); font-weight: 600; cursor: default; }
.wr-fb-crumb.is-current:hover { text-decoration: none; }

.wr-fb-search {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: 200px;
    height: 30px;
    padding: 0 10px;
    border: 1px solid var(--wr-border-strong);
    border-radius: var(--wr-rad-sm);
    background: var(--wr-surface);
}
.wr-fb-search:focus-within { border-color: var(--wr-border-focus); }
.wr-fb-search .material-symbols-outlined { font-size: 15px; color: var(--wr-ink-3); }
.wr-fb-search input {
    flex: 1;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 13px;
    color: var(--wr-ink);
    font-family: inherit;
}

.wr-fb-viewtoggle {
    display: inline-flex;
    gap: 2px;
    padding: 3px;
    border-radius: 8px;
    background: var(--wr-surface-alt);
}
.wr-fb-viewtoggle button {
    width: 30px;
    height: 24px;
    border: 0;
    border-radius: 5px;
    background: transparent;
    color: var(--wr-ink-3);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-fb-viewtoggle button .material-symbols-outlined { font-size: 16px; }
.wr-fb-viewtoggle button.is-active {
    background: var(--wr-surface);
    color: var(--wr-ink);
    box-shadow: var(--wr-shadow-sm);
}

/* Selection bar */
.wr-fb-selbar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    background: var(--wr-surface-tint);
    border-bottom: 1px solid var(--wr-border);
}
.wr-fb-selcount { font-size: 13px; font-weight: 600; color: var(--wr-blue-soft-text); }

/* Icon buttons (row actions, selection clear) */
.wr-fb-iconbtn {
    width: 30px;
    height: 30px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--wr-ink-3);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.12s, color 0.12s;
}
.wr-fb-iconbtn .material-symbols-outlined { font-size: 17px; }
.wr-fb-iconbtn:hover { background: rgba(11, 20, 38, 0.06); color: var(--wr-ink); }
.wr-fb-iconbtn.is-danger:hover { background: var(--wr-red-soft); color: var(--wr-red); }

/* List header */
.wr-fb-listhead {
    display: grid;
    grid-template-columns: var(--wr-fb-cols);
    gap: 12px;
    align-items: center;
    padding: 10px 18px;
    background: var(--wr-surface-alt);
    border-bottom: 1px solid var(--wr-border);
}
.wr-fb-listhead > * {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color: var(--wr-ink-3);
}
.wr-fb-sort {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
    color: var(--wr-ink-3);
    font: inherit;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}
.wr-fb-sort .material-symbols-outlined { font-size: 14px; opacity: 0; transition: transform 0.12s; }
.wr-fb-sort.is-active { color: var(--wr-ink-2); }
.wr-fb-sort.is-active .material-symbols-outlined { opacity: 1; }
.wr-fb-sort.is-desc .material-symbols-outlined { transform: rotate(180deg); }
.wr-fb-col-size { justify-content: flex-end; text-align: right; }
.wr-fb-col-actions { text-align: right; }

/* Items container */
.wr-fb-items.is-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(176px, 1fr));
    gap: 12px;
    padding: 16px;
}

/* ---- LIST mode item ---- */
.wr-fb-items.is-list .wr-fb-item {
    display: grid;
    grid-template-columns: var(--wr-fb-cols);
    gap: 12px;
    align-items: center;
    padding: 11px 18px;
    border-bottom: 1px solid var(--wr-border);
    background: var(--wr-surface);
    transition: background 0.1s;
}
.wr-fb-items.is-list .wr-fb-item:last-child { border-bottom: 0; }
.wr-fb-items.is-list .wr-fb-item.is-clickable { cursor: pointer; }
.wr-fb-items.is-list .wr-fb-item:hover { background: var(--wr-surface-alt); }
.wr-fb-items.is-list .wr-fb-item.is-selected { background: var(--wr-surface-tint); }
.wr-fb-items.is-list .wr-fb-meta { display: none; }

.wr-fb-namecell {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.wr-fb-glyph {
    width: 34px;
    height: 34px;
    flex-shrink: 0;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-fb-glyph .material-symbols-outlined { font-size: 19px; }
.wr-glyph-folder    { background: #fbf3df; color: #e0a82e; }
.wr-glyph-blue      { background: var(--wr-blue-soft); color: var(--wr-blue); }
.wr-glyph-purple    { background: #f0eafc; color: #7c3aed; }
.wr-glyph-amberSoft { background: var(--wr-amber-soft); color: #a16207; }
.wr-glyph-neutral   { background: var(--wr-surface-alt); color: var(--wr-ink-3); }

.wr-fb-name-wrap { min-width: 0; flex: 1; }
.wr-fb-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--wr-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}
.wr-fb-item.is-folder .wr-fb-name { font-weight: 600; }

.wr-fb-rename {
    width: 100%;
    min-width: 0;
    height: 30px;
    padding: 0 10px;
    border: 1px solid var(--wr-border-focus);
    border-radius: 6px;
    outline: none;
    font-size: 14px;
    color: var(--wr-ink);
    font-family: var(--wr-font-mono);
    box-shadow: 0 0 0 3px rgba(37, 65, 224, 0.12);
}

.wr-fb-size { text-align: right; font-size: 13px; color: var(--wr-ink-2); }
.wr-fb-mod { font-size: 12px; color: var(--wr-ink-3); }
.wr-fb-actions {
    display: flex;
    justify-content: flex-end;
    gap: 2px;
    opacity: 0.35;
    transition: opacity 0.12s;
}
.wr-fb-items.is-list .wr-fb-item:hover .wr-fb-actions,
.wr-fb-item.is-selected .wr-fb-actions { opacity: 1; }

.wr-fb-checkbox { width: 15px; height: 15px; accent-color: var(--wr-blue); cursor: pointer; margin: 0; }
.wr-fb-check { display: inline-flex; align-items: center; }

/* ---- GRID mode item ---- */
.wr-fb-items.is-grid .wr-fb-item {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 16px 14px;
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-md);
    background: var(--wr-surface);
    transition: box-shadow 0.12s, border-color 0.12s;
}
.wr-fb-items.is-grid .wr-fb-item.is-clickable { cursor: pointer; }
.wr-fb-items.is-grid .wr-fb-item:hover { box-shadow: var(--wr-shadow-md); }
.wr-fb-items.is-grid .wr-fb-item.is-selected { border-color: var(--wr-border-focus); background: var(--wr-surface-tint); }
.wr-fb-items.is-grid .wr-fb-type,
.wr-fb-items.is-grid .wr-fb-size,
.wr-fb-items.is-grid .wr-fb-mod { display: none; }
.wr-fb-items.is-grid .wr-fb-check {
    position: absolute;
    top: 10px;
    left: 10px;
    opacity: 0;
    transition: opacity 0.12s;
}
.wr-fb-items.is-grid .wr-fb-item:hover .wr-fb-check,
.wr-fb-items.is-grid .wr-fb-item.is-selected .wr-fb-check { opacity: 1; }
.wr-fb-items.is-grid .wr-fb-namecell { flex-direction: column; gap: 10px; width: 100%; }
.wr-fb-items.is-grid .wr-fb-glyph { width: 54px; height: 54px; border-radius: 14px; margin-top: 4px; }
.wr-fb-items.is-grid .wr-fb-glyph .material-symbols-outlined { font-size: 28px; }
.wr-fb-items.is-grid .wr-fb-name-wrap { width: 100%; flex: none; }
.wr-fb-items.is-grid .wr-fb-name { font-size: 13px; text-align: center; }
.wr-fb-items.is-grid .wr-fb-meta { font-size: 11px; color: var(--wr-ink-3); }
.wr-fb-items.is-grid .wr-fb-actions {
    position: absolute;
    top: 8px;
    right: 8px;
    opacity: 0;
}
.wr-fb-items.is-grid .wr-fb-item:hover .wr-fb-actions { opacity: 1; }

/* Type badges */
.wr-tag--blue    { background: var(--wr-blue-soft); color: var(--wr-blue-soft-text); border-color: rgba(37, 65, 224, 0.18); }
.wr-tag--amber   { background: var(--wr-amber-soft); color: var(--wr-amber-soft-text); border-color: rgba(161, 98, 7, 0.22); }
.wr-tag--purple  { background: #f0eafc; color: #6d28d9; border-color: rgba(124, 58, 237, 0.18); }
.wr-tag--neutral { background: rgba(11, 20, 38, 0.06); color: var(--wr-ink-2); border-color: var(--wr-border); }

/* Empty states */
.wr-fb-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 44px 18px;
    text-align: center;
}
.wr-fb-empty-icon {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: var(--wr-surface-alt);
    color: var(--wr-ink-3);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-fb-empty-icon .material-symbols-outlined { font-size: 20px; }
.wr-fb-empty-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.wr-fb-empty-body { font-size: 13px; color: var(--wr-ink-3); max-width: 360px; }

/* Dropzone */
.wr-dropzone {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 26px 22px;
    border: 1.5px dashed var(--wr-border-strong);
    border-radius: var(--wr-rad-lg);
    background: transparent;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s;
}
.wr-dropzone:hover { border-color: var(--wr-border-focus); }
.wr-dropzone.is-dragover { border-color: var(--wr-blue); background: var(--wr-surface-tint); }
.wr-dropzone-icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: 12px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    box-shadow: var(--wr-shadow-sm);
    color: var(--wr-ink-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-dropzone-icon .material-symbols-outlined { font-size: 21px; }
.wr-dropzone.is-dragover .wr-dropzone-icon { background: var(--wr-blue); border-color: var(--wr-blue); color: #fff; }
.wr-dropzone-text { flex: 1; min-width: 0; }
.wr-dropzone-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.wr-dropzone-sub { font-size: 13px; color: var(--wr-ink-3); margin-top: 2px; }
.wr-dropzone-sub .wr-mono { color: var(--wr-ink-2); }

/* --- File browser (legacy / modal) ----------------------------------- */
.file-actions {
    display: inline-flex;
    gap: 6px;
}

.file-breadcrumb-sep {
    color: var(--wr-ink-4);
    margin: 0 6px;
}

.file-size {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-3);
}

.file-img-wrap {
    display: flex;
    justify-content: center;
    padding: 14px;
    background: var(--wr-surface-alt);
    border-radius: var(--wr-rad-md);
}

.file-img {
    max-width: 100%;
    max-height: 480px;
    border-radius: var(--wr-rad-sm);
}

.file-binary-wrap {
    padding: 18px;
    text-align: center;
    color: var(--wr-ink-3);
    font-size: 13px;
}

.file-modal-actions {
    display: flex;
    gap: 8px;
}

.file-modal-body {
    padding: 18px;
}

.file-modal-header {
    padding: 14px 18px;
    border-bottom: 1px solid var(--wr-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.file-modal-title {
    font-family: var(--wr-font-mono);
    font-size: 13px;
    color: var(--wr-ink);
    word-break: break-all;
}

.file-modal-loading {
    padding: 24px;
    text-align: center;
    color: var(--wr-ink-3);
}

.file-input {
    width: 100%;
}

/* --- Invoice (PDF-style preview) -------------------------------------- */
.invoice-heading {
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.4px;
    margin-bottom: 16px;
}

.invoice-meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    font-size: 13px;
}

.invoice-meta-text {
    color: var(--wr-ink-3);
}

.invoice-customer,
.invoice-from {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.invoice-logo {
    height: 28px;
}

.invoice-subtotal-label,
.invoice-vat-label {
    color: var(--wr-ink-3);
    font-size: 12px;
}

.invoice-subtotal-value,
.invoice-vat-value {
    text-align: right;
    font-family: var(--wr-font-mono);
    font-size: 13px;
}

.invoice-total-label {
    font-weight: 600;
    color: var(--wr-ink);
}

.invoice-total-value {
    text-align: right;
    font-weight: 600;
    font-size: 16px;
    font-family: var(--wr-font-mono);
}

.invoice-tfoot-divider td {
    border-top: 1px solid var(--wr-border);
    padding-top: 8px !important;
}

/* --- Database row actions --------------------------------------------- */
.db-row-actions {
    display: inline-flex;
    gap: 6px;
    justify-content: flex-end;
}

.pass-mask {
    font-family: var(--wr-font-mono);
    letter-spacing: 2px;
}

/* --- Whois / domain registration -------------------------------------- */
.whois-fields {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.whois-summary {
    padding: 14px 18px;
    background: var(--wr-surface-alt);
    border-radius: var(--wr-rad-md);
    border: 1px solid var(--wr-border);
    font-size: 13px;
    color: var(--wr-ink-2);
}

.whois-details {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 8px;
}

/* --- Callouts (used in DNS verify / domain confirm) ------------------- */
.callout-tabs {
    display: inline-flex;
    gap: 2px;
    background: var(--wr-surface-alt);
    padding: 3px;
    border-radius: 6px;
    margin-bottom: 12px;
}

.callout-tab {
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    color: var(--wr-ink-3);
    background: transparent;
    border: 0;
    cursor: pointer;
}

.callout-tab.active {
    background: var(--wr-surface);
    color: var(--wr-ink);
    box-shadow: var(--wr-shadow-sm);
    font-weight: 600;
}

.callout-list,
.callout-ns-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.callout-row {
    display: grid;
    grid-template-columns: 100px 1fr auto;
    gap: 10px;
    padding: 8px 12px;
    background: var(--wr-surface-alt);
    border-radius: var(--wr-rad-sm);
    border: 1px solid var(--wr-border);
    align-items: center;
}

.callout-code-block,
.callout-ns-code {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink);
    word-break: break-all;
}

.callout-code-value {
    font-family: var(--wr-font-mono);
    font-size: 13px;
    color: var(--wr-ink);
    user-select: all;
}

.callout-text {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin: 6px 0 0;
}

.callout-form-action {
    margin-top: 12px;
    display: flex;
    gap: 8px;
}

/* --- Confirm-domain (order flow) -------------------------------------- */
.confirm-domain-banner {
    padding: 18px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 18px;
}

.confirm-domain-name {
    font-family: var(--wr-font-mono);
    font-size: 18px;
    font-weight: 600;
    color: var(--wr-ink);
}

.confirm-pay-note {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 8px;
}

.coming-soon-note {
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 4px;
    font-style: italic;
}

/* --- Subdomain combo (CMS form / staging) ----------------------------- */
.subdomain-combo {
    display: flex;
    align-items: stretch;
    gap: 6px;
}

.subdomain-input {
    flex: 0 0 140px;
}

.subdomain-dot {
    display: inline-flex;
    align-items: center;
    color: var(--wr-ink-3);
    font-weight: 600;
}

.subdomain-select {
    flex: 1;
    min-width: 180px;
}

.subdomain-preview {
    font-family: var(--wr-font-mono);
    font-size: 12px;
    color: var(--wr-ink-3);
    margin-top: 4px;
}

/* --- Order / checkout flow (public) ----------------------------------- */
.order-layout,
.step3-layout {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 22px;
    align-items: flex-start;
}

@media (max-width: 960px) {
    .order-layout,
    .step3-layout {
        grid-template-columns: 1fr;
    }
}

.step3-main {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.step3-sidebar {
    position: sticky;
    top: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.order-summary {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.order-summary-title {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
}

.order-summary-name { font-size: 16px; font-weight: 600; color: var(--wr-ink); }
.order-summary-type { font-size: 12px; color: var(--wr-ink-3); }
.order-summary-price { font-size: 20px; font-weight: 600; color: var(--wr-ink); }
.order-summary-specs { font-size: 12px; color: var(--wr-ink-3); margin-top: 6px; }
.order-summary-quote {
    font-size: 12px;
    color: var(--wr-ink-3);
    padding-top: 10px;
    margin-top: 10px;
    border-top: 1px solid var(--wr-border);
}

.sidebar-row,
.sidebar-row-small {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: var(--wr-ink-2);
    padding: 4px 0;
}

.sidebar-row-small {
    font-size: 12px;
    color: var(--wr-ink-3);
}

.sidebar-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    margin-top: 6px;
    border-top: 1px solid var(--wr-border);
}

.sidebar-total-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--wr-ink);
}

.sidebar-total-amount {
    font-size: 18px;
    font-weight: 600;
    color: var(--wr-ink);
    font-family: var(--wr-font-mono);
}

.cart-table {
    width: 100%;
    border-collapse: collapse;
}

.cart-table td {
    padding: 10px 0;
    border-bottom: 1px solid var(--wr-border);
    font-size: 13px;
}

.cart-table tr:last-child td {
    border-bottom: 0;
}

.cart-item-title { font-weight: 600; color: var(--wr-ink); }
.cart-item-sub { font-size: 12px; color: var(--wr-ink-3); margin-top: 2px; }
.cart-price { font-family: var(--wr-font-mono); text-align: right; }
.cart-price-sub { font-size: 11px; color: var(--wr-ink-3); text-align: right; }

.basket-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.basket-row-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.basket-row-name { font-size: 13px; font-weight: 500; color: var(--wr-ink); }
.basket-row-price { font-family: var(--wr-font-mono); font-size: 13px; color: var(--wr-ink); }

.basket-row-remove {
    background: transparent;
    border: 0;
    color: var(--wr-ink-3);
    cursor: pointer;
    padding: 2px;
}

.basket-row-remove:hover { color: var(--wr-red); }

.checkout-wrap {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.amount,
.num,
.price {
    font-family: var(--wr-font-mono);
    font-size: 13px;
}

.accent { color: var(--wr-blue); }
.ribbon {
    display: inline-flex;
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue-soft-text);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

/* --- WR-v2 order layout (pricing + step bar) -------------------------- */
.wr-v2-order {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.wr-v2-page-header {
    padding: 32px 36px 12px;
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
}

.wr-v2-section {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 36px;
    width: 100%;
}

.wr-v2-stepbar {
    border-bottom: 1px solid var(--wr-border);
    background: var(--wr-bg);
}

.wr-v2-stepbar-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 14px 36px;
}

.wr-v2-stepbar-steps {
    display: flex;
    gap: 18px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.wr-v2-stepbar-step {
    font-size: 12px;
    color: var(--wr-ink-3);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.wr-v2-stepbar-step.active {
    color: var(--wr-ink);
    font-weight: 600;
}

.wr-v2-stepbar-step.done {
    color: var(--wr-green-soft-text);
}

.wr-v2-interval-picker-wrap {
    display: flex;
    justify-content: center;
    padding: 8px 0 18px;
}

.wr-v2-interval-picker {
    display: inline-flex;
    gap: 2px;
    background: var(--wr-surface-alt);
    padding: 4px;
    border-radius: 999px;
}

.wr-v2-interval-btn {
    padding: 8px 16px;
    border-radius: 999px;
    background: transparent;
    border: 0;
    font-size: 13px;
    font-weight: 500;
    color: var(--wr-ink-3);
    cursor: pointer;
}

.wr-v2-interval-btn.active {
    background: var(--wr-surface);
    color: var(--wr-ink);
    box-shadow: var(--wr-shadow-sm);
    font-weight: 600;
}

.wr-v2-interval-discount {
    margin-left: 6px;
    font-size: 11px;
    color: var(--wr-green-soft-text);
    font-weight: 600;
}

.wr-v2-tier-grid,
.wr-v2-looptijd-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
}

.wr-v2-tier-price {
    font-size: 28px;
    font-weight: 600;
    letter-spacing: -0.6px;
    color: var(--wr-ink);
    margin: 8px 0;
}

.wr-v2-tier-feat-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 13px;
    color: var(--wr-ink-2);
}

.wr-v2-tier-feat-list li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.wr-v2-tier-feat-list li::before {
    content: "✓";
    color: var(--wr-green);
    font-weight: 700;
    flex-shrink: 0;
}

.wr-v2-contact-bar {
    background: var(--wr-surface);
    border-top: 1px solid var(--wr-border);
    padding: 14px 0;
}

.wr-v2-contact-bar-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    font-size: 13px;
    color: var(--wr-ink-3);
}

.wr-v2-contact-bar-spacer { flex: 1; }
.wr-v2-contact-bar-cta { font-weight: 600; color: var(--wr-blue); }

.wr-v2-filter-tabs {
    display: inline-flex;
    gap: 2px;
    background: var(--wr-surface-alt);
    padding: 3px;
    border-radius: 6px;
}

.wr-v2-filter-tab {
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    color: var(--wr-ink-3);
    background: transparent;
    border: 0;
    cursor: pointer;
}

.wr-v2-filter-tab.active {
    background: var(--wr-surface);
    color: var(--wr-ink);
    box-shadow: var(--wr-shadow-sm);
    font-weight: 600;
}

/* =====================================================================
   BEM modifiers + page-specific classes used across templates.
   --------------------------------------------------------------------- */

/* --- Card modifiers --------------------------------------------------- */
.dash-card--danger { border-color: rgba(185, 28, 28, 0.35); }
.dash-card--form .dash-card-body { padding-top: 8px; }

.dash-card-body--divider { border-top: 1px solid var(--wr-border); }
.dash-card-body--tight-bottom { padding-bottom: 8px; }

/* --- Info row modifiers (label-on-top layout) ------------------------- */
.dash-info-row--top {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
}

.dash-info-row--top > .dash-info-label--top {
    width: 100%;
}

.dash-info-row--top > form,
.dash-info-row--top > .form-row {
    width: 100%;
}

.dash-info-label--top {
    font-size: 12px;
    font-weight: 600;
    color: var(--wr-ink-2);
}

/* --- Input size modifiers --------------------------------------------- */
.dash-input--xs { width: 120px; flex: 0 0 120px; }
.dash-input--md { width: 220px; flex: 0 0 220px; }

.dash-label--xs { font-size: 11px; }

/* --- Tag modifiers ---------------------------------------------------- */
.dash-tag--success {
    background: var(--wr-green-soft);
    color: var(--wr-green-soft-text);
    border-color: rgba(21, 128, 61, 0.22);
}

.dash-tag--warning {
    background: var(--wr-amber-soft);
    color: var(--wr-amber-soft-text);
    border-color: rgba(161, 98, 7, 0.22);
}

.dash-tag--danger {
    background: var(--wr-red-soft);
    color: var(--wr-red-soft-text);
    border-color: rgba(185, 28, 28, 0.18);
}

.dash-tag--alt {
    background: var(--wr-blue-soft);
    color: var(--wr-blue-soft-text);
    border-color: rgba(37, 65, 224, 0.18);
}

.main-db-tag {
    background: var(--wr-blue-soft);
    color: var(--wr-blue-soft-text);
    border-color: rgba(37, 65, 224, 0.18);
    margin-left: 6px;
    cursor: help;
}

/* --- Badge color modifiers used by status helpers --------------------- */
.dash-badge--orange {
    background: #ffedd5;
    color: #9a3412;
    border-color: rgba(154, 52, 18, 0.18);
}

.dash-badge--yellow {
    background: #fef9c3;
    color: #854d0e;
    border-color: rgba(133, 77, 14, 0.18);
}

/* --- Stat icon variants ---------------------------------------------- */
.dash-stat-icon--green {
    background: var(--wr-green-soft);
    color: var(--wr-green-soft-text);
}

/* --- Agent dot modifier (BEM-compatible) ------------------------------ */
.dash-agent-dot--online {
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

/* --- Button alias still referenced in templates ----------------------- */
.dash-btn-danger {
    background: var(--wr-red);
    border-color: var(--wr-red);
    color: #fff;
}

.dash-btn-danger:hover {
    background: #8b1414;
    border-color: #8b1414;
    color: #fff;
}

/* --- Form grids ------------------------------------------------------- */
.dash-form-grid--street { grid-template-columns: 1fr 140px; }
.dash-form-grid--postal { grid-template-columns: 140px 1fr; }

/* --- Form row modifiers ----------------------------------------------- */
.form-row--align-end { align-items: flex-end; }
.form-row--stretch > * { flex: 1 1 auto; }

.checkbox--lg {
    width: 18px;
    height: 18px;
}

.option-toggle-label--active { color: var(--wr-blue); font-weight: 600; }
.option-toggle-row--stack {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

.pakket-prijs--quote {
    font-size: 13px;
    color: var(--wr-ink-3);
    font-weight: 400;
}

/* --- Status pill variant in marketing copy --------------------------- */
.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    font-size: 12px;
    color: var(--wr-ink-2);
    font-weight: 500;
}

.status-card-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.status-icon--green { background: #ecfdf3; color: var(--wr-green); }
.status-icon--red { background: var(--wr-red-soft); color: var(--wr-red); }
.status-title--green { color: var(--wr-green-soft-text); }
.status-title--red { color: var(--wr-red-soft-text); }

/* --- Auth-card variants ----------------------------------------------- */
.auth-card--wide { width: 560px; }
.auth-title--tight { font-size: 18px; }

/* --- Sidebar (order summary) modifiers ------------------------------- */
.sidebar-row--muted { color: var(--wr-ink-3); }

.sidebar-footer {
    padding-top: 12px;
    margin-top: 8px;
    border-top: 1px solid var(--wr-border);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sidebar-user {
    font-size: 12px;
    color: var(--wr-ink-3);
}

.sidebar-checkout-btn {
    width: 100%;
    justify-content: center;
}

/* --- Modal dialog variants ------------------------------------------- */
.modal-dialog {
    width: 560px;
    max-width: 100%;
    background: var(--wr-surface);
    border-radius: var(--wr-rad-xl);
    box-shadow: 0 24px 56px rgba(11, 20, 38, 0.25);
    overflow: hidden;
}

.modal-dialog--narrow { width: 420px; }
.modal-dialog--sm { width: 360px; }

.modal-dialog-card {
    background: var(--wr-surface);
    border-radius: var(--wr-rad-xl);
    overflow: hidden;
}

.modal-dialog-card--md { width: 640px; }
.modal-dialog-card--sm { width: 420px; }

.modal-pad { padding: 18px; }
.modal-body { padding: 18px; }

.modal-binary {
    padding: 24px;
    text-align: center;
    color: var(--wr-ink-3);
    font-size: 13px;
}

.modal-image {
    max-width: 100%;
    max-height: 480px;
    display: block;
    margin: 0 auto;
    border-radius: var(--wr-rad-sm);
}

.modal-loading {
    padding: 24px;
    text-align: center;
    color: var(--wr-ink-3);
    font-size: 13px;
}

.modal-error {
    padding: 18px;
    text-align: center;
    color: var(--wr-red);
    font-size: 13px;
}

/* --- Stats chart canvases (package_detail performance graphs) -------- */
.stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    padding: 0 18px;
}

@media (max-width: 700px) {
    .stats-grid { grid-template-columns: 1fr; }
}

/* Stacked perf sections inside a single Performance card */
.perf-section {
    padding: 16px 18px;
}

.perf-section--divider {
    border-top: 1px solid var(--wr-border);
}

.perf-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.perf-label {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
}

.perf-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--wr-ink);
    letter-spacing: -0.3px;
}

/* Sparkline canvas (slim, no padding, transparent — Chart.js draws everything) */
.sparkline-canvas {
    position: relative;
    height: 90px;
    width: 100%;
}

.sparkline-canvas canvas {
    width: 100% !important;
    height: 100% !important;
}

/* Prestaties tab: side-by-side sparklines */
.perf-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-top: 1px solid var(--wr-border);
}

.perf-cell {
    padding: 16px 18px;
}

.perf-cell--divider {
    border-left: 1px solid var(--wr-border);
}

@media (max-width: 720px) {
    .perf-grid { grid-template-columns: 1fr; }
    .perf-cell--divider { border-left: 0; border-top: 1px solid var(--wr-border); }
}

.perf-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    padding: 16px 18px;
    border-top: 1px solid var(--wr-border);
}

@media (max-width: 720px) {
    .perf-stats-grid { grid-template-columns: 1fr; }
}

.perf-header-right {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

/* Config rows — inline form layout (subdomain.domain combo + save button) */
.cfg-form {
    display: inline-flex;
    align-items: stretch;
    gap: 6px;
    margin: 0;
    flex-wrap: nowrap;
    justify-content: flex-end;
}

.cfg-input-sub {
    height: 30px;
    width: 110px;
    flex: 0 0 110px;
    font-size: 12px;
}

.cfg-input-domain {
    height: 30px;
    width: 200px;
    flex: 0 1 200px;
    font-size: 12px;
    min-width: 140px;
}

.cfg-dot {
    display: inline-flex;
    align-items: center;
    color: var(--wr-ink-3);
    font-weight: 600;
}

.cfg-form .btn-sm {
    height: 30px;
    flex-shrink: 0;
    white-space: nowrap;
}

/* Let the dash-info-row value column actually have room to fit the form */
.dash-info-row {
    gap: 24px;
}

.dash-info-row > .dash-info-value {
    min-width: 0;
    flex-shrink: 1;
}

.cfg-toggle-form {
    margin: 0;
    display: inline-flex;
    align-items: center;
}

/* Toggle switch (auto-update etc.) */
.toggle-switch {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    position: relative;
    user-select: none;
}

.toggle-switch input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.toggle-switch-track {
    width: 38px;
    height: 22px;
    background: rgba(11, 20, 38, 0.15);
    border-radius: 999px;
    transition: background 0.16s;
    display: inline-flex;
    align-items: center;
    padding: 2px;
}

.toggle-switch-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 2px rgba(11, 20, 38, 0.2);
    transition: transform 0.16s;
}

.toggle-switch input:checked + .toggle-switch-track {
    background: var(--wr-blue);
}

.toggle-switch input:checked + .toggle-switch-track .toggle-switch-thumb {
    transform: translateX(16px);
}

.toggle-switch input:focus-visible + .toggle-switch-track {
    box-shadow: 0 0 0 3px rgba(37, 65, 224, 0.18);
}

/* Staging tab — domain picker block */
.staging-setup {
    padding: 18px 20px;
    border-top: 1px solid var(--wr-border);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.staging-setup-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--wr-ink-2);
}

.staging-setup-hint {
    font-size: 11px;
    color: var(--wr-ink-3);
}

.staging-form {
    display: flex;
    align-items: stretch;
    gap: 6px;
    flex-wrap: nowrap;
    margin: 0;
}

.staging-form .cfg-input-sub {
    height: 36px;
    width: 130px;
    flex: 0 0 130px;
    font-size: 13px;
}

.staging-form .cfg-input-domain {
    height: 36px;
    flex: 1 1 200px;
    width: auto;
    min-width: 160px;
    font-size: 13px;
}

.staging-form .btn {
    flex-shrink: 0;
    white-space: nowrap;
}

.stats-row {
    display: flex;
    gap: 14px;
    align-items: stretch;
}

.stats-chart-label {
    font-size: 11px;
    color: var(--wr-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
    margin-bottom: 6px;
}

.stats-chart-canvas {
    position: relative;
    height: 160px;
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-md);
    padding: 8px;
}

/* --- Password masking (db credentials) -------------------------------- */
.pass-mask {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--wr-font-mono);
    letter-spacing: 2px;
}

.pass-mask-text,
.db-pass-mask {
    cursor: copy;
    color: var(--wr-ink);
}

.pass-eye,
.db-pass-eye {
    background: transparent;
    border: 0;
    color: var(--wr-ink-3);
    cursor: pointer;
    padding: 2px;
    display: inline-flex;
    border-radius: 4px;
}

.pass-eye:hover,
.db-pass-eye:hover { color: var(--wr-blue); background: rgba(11, 20, 38, 0.04); }

/* --- Logs page ------------------------------------------------------- */
.logs-card {
    background: var(--wr-surface);
    border: 1px solid var(--wr-border);
    border-radius: var(--wr-rad-lg);
    overflow: hidden;
}

.logs-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--wr-ink-4);
    display: inline-block;
}

.logs-status-dot--ok {
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

.logs-select {
    width: 220px;
}

/* --- Filter inputs --------------------------------------------------- */
.filter-tabs {
    display: inline-flex;
    gap: 2px;
    background: var(--wr-surface-alt);
    padding: 3px;
    border-radius: 6px;
}

.filter-tab {
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    color: var(--wr-ink-3);
    background: transparent;
    border: 0;
    cursor: pointer;
}

.filter-tab.active {
    background: var(--wr-surface);
    color: var(--wr-ink);
    box-shadow: var(--wr-shadow-sm);
    font-weight: 600;
}

.filter-input--date { width: 160px; }
.filter-input--sm { width: 140px; }

/* --- Callout boxes (DNS verify, domain confirm, info banners) -------- */
.callout--amber {
    background: #fff8e1;
    border: 1px solid rgba(161, 98, 7, 0.18);
    padding: 14px 16px;
    border-radius: var(--wr-rad-lg);
    color: var(--wr-amber-soft-text);
}

.callout--blue {
    background: #eef2fb;
    border: 1px solid rgba(37, 65, 224, 0.18);
    padding: 14px 16px;
    border-radius: var(--wr-rad-lg);
    color: var(--wr-blue-soft-text);
}

.callout--green {
    background: #ecfdf3;
    border: 1px solid rgba(22, 163, 74, 0.2);
    padding: 14px 16px;
    border-radius: var(--wr-rad-lg);
    color: #0f5532;
}

.callout-title {
    margin: 0 0 4px;
    font-size: 13px;
    font-weight: 600;
}

.callout-title--amber { color: var(--wr-amber-soft-text); }
.callout-title--blue { color: var(--wr-blue-soft-text); }
.callout-title--green { color: #0f5532; }

.callout-text--amber { color: var(--wr-amber-soft-text); }
.callout-text--green { color: #0f5532; }
.callout-text--sm { font-size: 12px; }

.callout-form-narrow { max-width: 320px; }

/* --- Step navigation in multi-step forms ----------------------------- */
.step-nav {
    display: flex;
    gap: 8px;
    justify-content: space-between;
    margin-top: 18px;
}

/* --- Public marketing footer leftover --------------------------------- */
.wr-v2-public-footer .lead { color: var(--wr-ink-3); }

/* =====================================================================
   ORDER FLOW (besteltraject) — variant A: sidebar rail
   --------------------------------------------------------------------- */
.flow-screen {
    background: var(--wr-bg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    margin: 0;
}

.flow-topbar {
    background: var(--wr-surface);
    border-bottom: 1px solid var(--wr-border);
    padding: 12px 56px;
    flex-shrink: 0;
}

.flow-topbar-inner {
    max-width: 1240px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.flow-topbar-left { display: flex; align-items: center; gap: 22px; }
.flow-topbar-logo img { height: 22px; width: auto; display: block; }

.flow-topbar-back {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--wr-ink-3); text-decoration: none; font-size: 13px;
}
.flow-topbar-back:hover { color: var(--wr-blue); text-decoration: none; }
.flow-topbar-back .material-symbols-outlined { font-size: 14px; }

.flow-topbar-right { display: flex; align-items: center; gap: 18px; }

.flow-topbar-contact {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--wr-ink-2); text-decoration: none; font-size: 12px;
}
.flow-topbar-contact:hover { color: var(--wr-blue); text-decoration: none; }
.flow-topbar-contact .material-symbols-outlined { font-size: 14px; color: var(--wr-ink-3); }

.flow-titleband {
    padding: 32px 56px 24px;
    border-bottom: 1px solid var(--wr-border);
    background: var(--wr-bg);
}

.flow-titleband-inner {
    max-width: 1240px; margin: 0 auto;
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 24px; flex-wrap: wrap;
}

.flow-titleband-text { flex: 1 1 320px; min-width: 0; }
.flow-title { margin: 0; font-size: 30px; font-weight: 600; letter-spacing: -0.6px; color: var(--wr-ink); line-height: 1.1; }
.flow-subtitle { margin: 8px 0 0; font-size: 14px; color: var(--wr-ink-3); max-width: 580px; }

/* Stepper */
.flow-stepper { display: inline-flex; align-items: center; }
.flow-stepper-item { display: inline-flex; align-items: center; gap: 10px; }

.flow-stepper-dot {
    width: 22px; height: 22px; border-radius: 999px;
    background: var(--wr-surface); color: var(--wr-ink-4);
    border: 1.5px solid var(--wr-border-strong);
    font-size: 11px; font-weight: 600;
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.flow-stepper-dot .material-symbols-outlined { font-size: 12px; }
.flow-stepper-label { font-size: 13px; font-weight: 500; color: var(--wr-ink-4); }

.flow-stepper-line {
    flex: 0 0 36px; height: 1.5px; background: var(--wr-border-strong);
    margin: 0 14px; opacity: 0.6;
    transition: background 0.15s, opacity 0.15s;
}

/* Done step = filled dark navy with white check */
.flow-stepper-item.done .flow-stepper-dot {
    background: var(--wr-ink);
    color: #fff;
    border-color: var(--wr-ink);
}
.flow-stepper-item.done .flow-stepper-label { color: var(--wr-ink); font-weight: 600; }

/* Active = blue (the only highlighted state) */
.flow-stepper-item.active .flow-stepper-dot {
    background: var(--wr-blue);
    color: #fff;
    border-color: var(--wr-blue);
}
.flow-stepper-item.active .flow-stepper-label { color: var(--wr-ink); font-weight: 600; }

/* Line after a done step = dark, matches the dot */
.flow-stepper-line.done {
    background: var(--wr-ink);
    opacity: 1;
}

/* Content area */
.flow-content {
    flex: 1; max-width: 1240px; width: 100%; margin: 0 auto;
    padding: 28px 56px 48px;
}

.flow-content--single {
    display: flex; flex-direction: column; gap: 18px;
    align-items: stretch;
}

.flow-content--rail {
    display: grid; grid-template-columns: 1fr 340px; gap: 28px;
    align-items: start;
}

.flow-content-main {
    min-width: 0;
    display: flex; flex-direction: column; gap: 20px;
    align-items: stretch;
}

@media (max-width: 960px) {
    .flow-titleband, .flow-content { padding-left: 24px; padding-right: 24px; }
    .flow-content--rail { grid-template-columns: 1fr; }
}

/* Controls */
.flow-controls {
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px; flex-wrap: wrap;
}

.flow-filters { display: inline-flex; gap: 6px; flex-wrap: wrap; }

.flow-interval-wrap {
    display: flex;
    justify-content: center;
    padding: 8px 0 12px;
}

.flow-filter-pill {
    height: 34px; padding: 0 14px; border-radius: 999px;
    background: var(--wr-surface); border: 1px solid var(--wr-border);
    color: var(--wr-ink-2); font-size: 13px; font-weight: 500;
    cursor: pointer; transition: background 0.12s, color 0.12s, border-color 0.12s;
    font-family: inherit;
}
.flow-filter-pill:hover { border-color: var(--wr-border-strong); }
.flow-filter-pill.active { background: var(--wr-ink); color: #fff; border-color: var(--wr-ink); font-weight: 600; }

.flow-segmented {
    display: inline-flex; padding: 4px; border-radius: 18px;
    background: var(--wr-surface); border: 1px solid var(--wr-border); gap: 2px;
}

.flow-segmented-btn {
    height: 28px; padding: 0 14px; border-radius: 14px;
    background: transparent; color: var(--wr-ink-2);
    border: 0; font-size: 13px; font-weight: 500;
    display: inline-flex; align-items: center; gap: 6px;
    cursor: pointer; transition: background 0.15s, color 0.15s;
    font-family: inherit;
}
.flow-segmented-btn.active { background: var(--wr-ink); color: #fff; font-weight: 600; }

.flow-segmented-badge {
    font-size: 10px; font-weight: 600; padding: 2px 6px; border-radius: 999px;
    background: var(--wr-blue-soft); color: var(--wr-blue-soft-text);
}
.flow-segmented-btn.active .flow-segmented-badge { background: rgba(255, 255, 255, 0.16); color: #fff; }

/* Package cards grid */
.pkg-flow-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }

@media (max-width: 1100px) { .pkg-flow-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .pkg-flow-grid { grid-template-columns: 1fr; } }

.pkg-flow-card {
    position: relative; background: var(--wr-surface);
    border-radius: 16px; border: 1.5px solid var(--wr-border);
    padding: 24px 24px 22px;
    text-decoration: none; color: inherit; cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.18s, transform 0.15s;
    box-shadow: 0 1px 0 rgba(11, 20, 38, 0.02);
    display: flex; flex-direction: column; gap: 18px;
}
.pkg-flow-card:hover {
    border-color: var(--wr-border-strong);
    box-shadow: 0 12px 32px rgba(11, 20, 38, 0.08);
    transform: translateY(-2px); text-decoration: none;
}
.pkg-flow-card--recommended {
    border-color: var(--wr-blue);
    box-shadow: 0 6px 22px rgba(37, 65, 224, 0.10);
}

.pkg-flow-card-badge {
    position: absolute; top: -10px; left: 20px;
    padding: 3px 10px; border-radius: 999px;
    background: var(--wr-blue); color: #fff;
    font-size: 10px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
}

.pkg-flow-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pkg-flow-card-cat { font-size: 10px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--wr-ink-3); }

.pkg-flow-card-arrow {
    width: 28px; height: 28px; border-radius: 999px;
    background: var(--wr-surface-alt); border: 1px solid var(--wr-border);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--wr-ink-3); transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.pkg-flow-card-arrow .material-symbols-outlined { font-size: 14px; }
.pkg-flow-card:hover .pkg-flow-card-arrow { background: var(--wr-blue); border-color: var(--wr-blue); color: #fff; }

.pkg-flow-card-id { display: flex; flex-direction: column; gap: 4px; }
.pkg-flow-card-name { margin: 0; font-size: 20px; font-weight: 600; letter-spacing: -0.3px; color: var(--wr-ink); }
.pkg-flow-card-tagline { margin: 0; font-size: 13px; color: var(--wr-ink-3); line-height: 1.4; }

.pkg-flow-card-price { display: flex; flex-direction: column; gap: 4px; }
.pkg-flow-card-price-row { display: flex; align-items: baseline; gap: 6px; }
.pkg-flow-card-currency { font-size: 14px; color: var(--wr-ink-3); font-weight: 500; }
.pkg-flow-card-amount {
    font-size: 34px; font-weight: 600; color: var(--wr-ink);
    letter-spacing: -1.2px; line-height: 1; font-family: var(--wr-font-mono);
}
.pkg-flow-card-per { font-size: 13px; color: var(--wr-ink-3); }
.pkg-flow-card-savings { min-height: 18px; font-size: 12px; color: var(--wr-ink-3); }
.pkg-flow-card-strike { text-decoration: line-through; color: var(--wr-ink-4); font-family: var(--wr-font-mono); }
.pkg-flow-card-savings-pct { color: var(--wr-green); font-weight: 600; }
.pkg-flow-card-divider { height: 1px; background: var(--wr-border); }

.pkg-flow-card-feats { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.pkg-flow-card-feats li { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--wr-ink-2); }
.pkg-flow-card-feats .material-symbols-outlined { font-size: 14px; color: var(--wr-blue); flex-shrink: 0; margin-top: 2px; }

/* Trust strip */
.flow-trust-strip {
    margin-top: 8px;
    display: flex; align-items: center; justify-content: center;
    gap: 28px; flex-wrap: wrap;
    padding: 18px 22px; border-radius: 12px;
    background: var(--wr-surface); border: 1px solid var(--wr-border);
}

.flow-trust-item {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 13px; color: var(--wr-ink-2); font-weight: 500;
}

.flow-trust-icon {
    width: 28px; height: 28px; border-radius: 999px;
    background: var(--wr-blue-soft); color: var(--wr-blue);
    display: inline-flex; align-items: center; justify-content: center;
}
.flow-trust-icon .material-symbols-outlined { font-size: 14px; }

/* Step section */
.flow-step { display: flex; flex-direction: column; gap: 18px; }

/* Mode cards */
.flow-mode-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

/* List wrapper: Nieuw card alone on top row, then 2-col row underneath */
.flow-mode-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.flow-mode-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

.flow-mode-card--full { width: 100%; }

.flow-mode-card {
    position: relative; background: var(--wr-surface);
    border-radius: 12px; border: 1.5px solid var(--wr-border);
    padding: 16px 18px; cursor: pointer;
    display: flex; align-items: flex-start; gap: 14px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.flow-mode-card:hover { border-color: var(--wr-border-strong); }
.flow-mode-card.active {
    border-color: var(--wr-blue);
    box-shadow: 0 0 0 3px rgba(37, 65, 224, 0.08);
}

.flow-mode-card input { display: none; }

.flow-mode-card-radio {
    width: 18px; height: 18px; border-radius: 999px;
    border: 2px solid var(--wr-border-strong);
    background: transparent;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 2px;
    transition: background 0.12s, border-color 0.12s;
}
.flow-mode-card.active .flow-mode-card-radio { background: var(--wr-blue); border-color: var(--wr-blue); }
.flow-mode-card.active .flow-mode-card-radio::after {
    content: ""; width: 6px; height: 6px; border-radius: 999px; background: #fff;
}

.flow-mode-card-body { flex: 1; min-width: 0; }
.flow-mode-card-head { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.flow-mode-card-head .material-symbols-outlined { font-size: 16px; color: var(--wr-ink-2); }
.flow-mode-card.active .flow-mode-card-head .material-symbols-outlined { color: var(--wr-blue); }
.flow-mode-card-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.flow-mode-card-desc { margin: 0; font-size: 12px; color: var(--wr-ink-3); line-height: 1.4; }

/* Subdomain combo + domain search */
.flow-subdomain-combo { display: flex; align-items: stretch; gap: 6px; }
.flow-subdomain-combo > input { width: 140px; flex: 0 0 140px; }
.flow-subdomain-combo > select { flex: 1; }

.flow-domain-search { display: flex; gap: 10px; align-items: stretch; }
.flow-domain-search > input { flex: 1; height: 44px; font-size: 15px; }
.flow-domain-search > .btn { height: 44px; padding: 0 22px; flex-shrink: 0; }

.flow-domain-result {
    display: flex; align-items: center; justify-content: space-between;
    gap: 10px; padding: 10px 14px;
    background: var(--wr-surface-alt); border: 1px solid var(--wr-border);
    border-radius: 8px; margin-bottom: 6px;
}
.flow-domain-result-name { display: inline-flex; align-items: center; gap: 10px; }
.flow-domain-result-name .material-symbols-outlined { font-size: 16px; }
.flow-domain-result-actions { display: inline-flex; align-items: center; gap: 12px; }
.flow-domain-result-price { font-size: 13px; color: var(--wr-ink-2); }

/* Basket */
.flow-basket { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.flow-basket-row {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px; background: var(--wr-surface);
    border: 1px solid var(--wr-border); border-radius: 8px;
}
.flow-basket-name {
    font-size: 13px; color: var(--wr-ink); flex: 1; min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.flow-basket-price { font-size: 12px; color: var(--wr-ink-3); }

/* Help block */
.flow-help-block {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 18px; border-radius: 12px;
    background: var(--wr-surface-alt); border: 1px solid var(--wr-border);
}

.flow-help-icon {
    width: 32px; height: 32px; border-radius: 999px;
    background: var(--wr-surface); border: 1px solid var(--wr-border);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--wr-blue); flex-shrink: 0;
}
.flow-help-icon .material-symbols-outlined { font-size: 14px; }

.flow-help-body { flex: 1; font-size: 13px; color: var(--wr-ink-2); line-height: 1.5; }

.flow-help-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: var(--wr-blue);
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}

.flow-help-link:hover { text-decoration: underline; }
.flow-help-link .material-symbols-outlined { font-size: 13px; }

/* Auth toggle (Maak account / Inloggen) — segmented control */
.flow-auth-toggle {
    display: inline-flex;
    padding: 4px;
    border-radius: 18px;
    background: var(--wr-surface-alt);
    border: 1px solid var(--wr-border);
    gap: 2px;
    margin-bottom: 18px;
}

.flow-auth-pill {
    display: inline-flex;
    align-items: center;
    height: 30px;
    padding: 0 14px;
    border-radius: 14px;
    background: transparent;
    color: var(--wr-ink-2);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.flow-auth-pill input { display: none; }

.flow-auth-pill.active {
    background: var(--wr-ink);
    color: #fff;
    font-weight: 600;
}

/* Recap card (step 3) */
.flow-recap {
    background: var(--wr-surface);
    border-radius: 12px; border: 1px solid var(--wr-border);
    padding: 14px 18px;
    display: flex; align-items: center; gap: 14px;
}

.flow-recap-icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: var(--wr-blue-soft); color: var(--wr-blue);
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.flow-recap-icon .material-symbols-outlined { font-size: 18px; }

.flow-recap-body { flex: 1; min-width: 0; }
.flow-recap-cat { font-size: 10px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--wr-ink-3); }
.flow-recap-name { font-size: 16px; font-weight: 600; color: var(--wr-ink); letter-spacing: -0.2px; margin-top: 2px; }
.flow-recap-feats { font-size: 12px; color: var(--wr-ink-2); margin-top: 4px; }

/* Looptijd grid */
.flow-period-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 720px) { .flow-period-grid { grid-template-columns: 1fr; } }

.flow-period-card {
    position: relative; background: var(--wr-surface);
    border: 1.5px solid var(--wr-border); border-radius: 12px;
    padding: 16px 16px 14px; cursor: pointer;
    transition: border-color 0.12s, background 0.12s;
    display: flex; flex-direction: column; gap: 10px;
}
.flow-period-card input { display: none; }
.flow-period-card:hover { border-color: var(--wr-border-strong); }
.flow-period-card.active { background: var(--wr-surface-tint); border-color: var(--wr-blue); }

.flow-period-badge {
    position: absolute; top: -9px; right: 14px;
    padding: 3px 8px; border-radius: 999px;
    background: var(--wr-blue); color: #fff;
    font-size: 10px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase;
}

.flow-period-card-top { display: flex; align-items: center; justify-content: space-between; }

.flow-period-radio {
    width: 18px; height: 18px; border-radius: 999px;
    border: 2px solid var(--wr-border-strong);
    background: transparent;
    display: inline-flex; align-items: center; justify-content: center;
}
.flow-period-card.active .flow-period-radio { background: var(--wr-blue); border-color: var(--wr-blue); }
.flow-period-card.active .flow-period-radio::after {
    content: ""; width: 6px; height: 6px; border-radius: 999px; background: #fff;
}

.flow-period-card-info { display: flex; flex-direction: column; gap: 2px; }
.flow-period-card-label { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.flow-period-card-sub { font-size: 11px; color: var(--wr-ink-3); }

.flow-period-card-price { display: flex; align-items: baseline; gap: 4px; }
.flow-period-card-price .cur { font-size: 13px; color: var(--wr-ink-3); }
.flow-period-card-price .num {
    font-size: 26px; font-weight: 600; color: var(--wr-ink);
    letter-spacing: -0.6px; line-height: 1; font-family: var(--wr-font-mono);
}
.flow-period-card-price .per { font-size: 12px; color: var(--wr-ink-3); }

/* Extra services */
.flow-extra-row {
    padding: 14px 18px; display: flex; align-items: flex-start; gap: 14px;
    cursor: pointer; transition: background 0.12s;
}
.flow-extra-row input { display: none; }
.flow-extra-row:has(input:checked) { background: var(--wr-surface-tint); }

.flow-extra-check {
    width: 20px; height: 20px; border-radius: 5px;
    border: 1.5px solid var(--wr-border-strong);
    background: transparent;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 1px;
    transition: background 0.12s, border-color 0.12s;
    color: #fff; font-size: 0;
}
.flow-extra-row:has(input:checked) .flow-extra-check {
    background: var(--wr-blue); border-color: var(--wr-blue); font-size: 12px;
}
.flow-extra-row:has(input:checked) .flow-extra-check::after {
    content: "✓"; font-weight: 700;
}

.flow-extra-icon {
    width: 32px; height: 32px; border-radius: 8px;
    background: var(--wr-surface-alt); border: 1px solid var(--wr-border);
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.flow-extra-icon .material-symbols-outlined { font-size: 14px; color: var(--wr-ink-2); }

.flow-extra-body { flex: 1; min-width: 0; }
.flow-extra-title { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.flow-extra-sub { font-size: 12px; color: var(--wr-ink-3); margin-top: 1px; }
.flow-extra-desc { font-size: 12px; color: var(--wr-ink-2); margin-top: 6px; line-height: 1.5; }

/* Cart table (step 4) */
.flow-cart-table .flow-cart-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.flow-cart-table .flow-cart-sub { font-size: 11px; color: var(--wr-ink-3); margin-top: 2px; }
.flow-cart-table .flow-cart-price { font-size: 14px; font-weight: 600; color: var(--wr-ink); }

/* Terms */
.flow-terms { display: flex; align-items: flex-start; gap: 10px; padding: 4px; cursor: pointer; }
.flow-terms input { display: none; }

.flow-terms-check {
    width: 18px; height: 18px; border-radius: 5px;
    border: 1.5px solid var(--wr-border-strong);
    background: transparent;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 1px;
    transition: background 0.12s, border-color 0.12s;
}
.flow-terms:has(input:checked) .flow-terms-check { background: var(--wr-blue); border-color: var(--wr-blue); }
.flow-terms:has(input:checked) .flow-terms-check::after {
    content: "✓"; color: #fff; font-size: 12px; font-weight: 700;
}

.flow-terms-text { font-size: 12px; color: var(--wr-ink-2); }

/* Step nav */
.flow-step-nav {
    display: flex; align-items: center; justify-content: space-between;
    gap: 10px; padding-top: 8px; flex-wrap: wrap;
}

/* Inline validation: red border on missing fields */
.dash-input.field-error,
input.field-error,
select.field-error,
textarea.field-error {
    border-color: var(--wr-red);
    background: var(--wr-red-soft);
}

.dash-input.field-error:focus,
input.field-error:focus {
    box-shadow: 0 0 0 3px rgba(185, 28, 28, 0.15);
}

/* Submit error banner above the action buttons */
.flow-submit-error {
    padding: 14px 16px;
    border-radius: var(--wr-rad-lg);
    background: var(--wr-red-soft);
    border: 1px solid rgba(185, 28, 28, 0.3);
    color: var(--wr-red-soft-text);
    font-size: 13px;
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.flow-submit-error .material-symbols-outlined {
    font-size: 18px;
    color: var(--wr-red);
    flex-shrink: 0;
    margin-top: 1px;
}

.flow-submit-error strong { color: var(--wr-red); }

/* Order rail */
.flow-rail { position: sticky; top: 20px; align-self: start; }

.flow-rail-card {
    background: var(--wr-surface); border-radius: 14px;
    border: 1px solid var(--wr-border);
    box-shadow: 0 4px 18px rgba(11, 20, 38, 0.04);
    overflow: hidden;
}

.flow-rail-header {
    padding: 14px 18px; border-bottom: 1px solid var(--wr-border);
    display: flex; align-items: center; justify-content: space-between;
}

.flow-rail-title { font-size: 13px; font-weight: 600; color: var(--wr-ink); }

.flow-rail-section { padding: 14px 18px; border-bottom: 1px solid var(--wr-border); }

.flow-rail-line {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
}

.flow-rail-line-left { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.flow-rail-line-right { text-align: right; white-space: nowrap; flex-shrink: 0; }

.flow-rail-line-name { font-size: 14px; font-weight: 600; color: var(--wr-ink); }

.flow-rail-line-meta {
    font-size: 12px; color: var(--wr-ink-3);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px;
}

.flow-rail-line-price { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.flow-rail-line-sub { font-size: 11px; color: var(--wr-ink-3); }

.flow-rail-edit {
    margin-top: 8px; background: transparent; border: 0; padding: 0;
    color: var(--wr-blue); font-size: 12px; font-weight: 500;
    cursor: pointer; display: inline-block; text-decoration: none;
}

.flow-rail-totals {
    padding: 14px 18px; border-bottom: 1px solid var(--wr-border);
    display: flex; flex-direction: column; gap: 6px;
}

.flow-rail-total-row { display: flex; justify-content: space-between; font-size: 13px; color: var(--wr-ink-2); }
.flow-rail-total-row--final { font-size: 15px; font-weight: 600; color: var(--wr-ink); margin-top: 4px; }

.flow-rail-foot { padding: 14px 18px; }

.flow-rail-trust {
    display: flex; align-items: center; justify-content: center;
    gap: 6px; font-size: 11px; color: var(--wr-ink-3);
}
.flow-rail-trust .material-symbols-outlined { font-size: 12px; }

/* Footer */
.flow-foot {
    border-top: 1px solid var(--wr-border);
    padding: 18px 56px;
    font-size: 11px;
    color: var(--wr-ink-3);
}

.flow-foot-inner {
    max-width: 1240px;
    margin: 0 auto;
    width: 100%;
    display: flex; align-items: center; justify-content: space-between;
    gap: 14px; flex-wrap: wrap;
}

.flow-foot-links { display: inline-flex; gap: 6px; align-items: center; }
.flow-foot-links a { color: var(--wr-ink-3); text-decoration: none; }
.flow-foot-links a:hover { color: var(--wr-blue); }

@media (max-width: 960px) {
    .flow-topbar, .flow-foot { padding-left: 24px; padding-right: 24px; }
}

/* --- Access page (toegang) ------------------------------------------ */
.access-intro {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    border-bottom: 1px solid var(--wr-border);
}

.access-intro-icon {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border-radius: 10px;
    background: var(--wr-blue-soft);
    color: var(--wr-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.access-intro-icon .material-symbols-outlined { font-size: 18px; }
.access-intro-body { flex: 1; min-width: 0; }
.access-intro-title { font-size: 14px; font-weight: 600; color: var(--wr-ink); }
.access-intro-text {
    font-size: 13px;
    color: var(--wr-ink-3);
    margin: 4px 0 0;
    line-height: 1.5;
}

.access-add-form {
    display: grid;
    grid-template-columns: 1fr 220px auto;
    gap: 12px;
    align-items: start;
}

.access-add-form .dash-form-group { margin: 0; }

.access-add-form .dash-form-group .dash-input { height: 36px; }

.access-add-submit {
    display: flex;
    align-items: center;
    height: 36px;
    margin-top: 22px;
}

.access-add-form .dash-input-hint {
    grid-column: 1 / -1;
}

@media (max-width: 540px) {
    .access-add-form {
        grid-template-columns: 1fr;
    }
    .access-add-submit { margin-top: 0; }
}

/* --- Empty state inside cards --------------------------------------- */
.empty-state {
    padding: 40px 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.empty-state-icon {
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: var(--wr-surface-alt);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--wr-ink-3);
}

.empty-state-icon .material-symbols-outlined { font-size: 18px; }

.empty-state-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--wr-ink);
}

.empty-state-body {
    font-size: 12px;
    color: var(--wr-ink-3);
    max-width: 360px;
}

/* --- Card filter row (domains) -------------------------------------- */
.dash-card-filter {
    padding: 12px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--wr-border);
    flex-wrap: wrap;
}

.filter-search {
    position: relative;
    display: flex;
    align-items: center;
    flex: 0 0 260px;
    max-width: 260px;
    min-width: 200px;
}

.filter-search-icon {
    position: absolute;
    left: 10px;
    color: var(--wr-ink-3);
    font-size: 16px !important;
    pointer-events: none;
}

.filter-search .dash-input,
.filter-search input {
    height: 32px;
    padding-left: 32px;
    font-size: 12px;
}

/* --- Domain name cell ------------------------------------------------ */
.domain-name-cell {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.domain-icon {
    color: var(--wr-ink-3);
    font-size: 16px !important;
}

/* --- Security page banner (2FA status) ------------------------------- */
.security-banner {
    padding: 16px 18px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    gap: 14px;
}

.security-banner--green {
    background: #ecfdf3;
    border: 1px solid rgba(22, 163, 74, 0.2);
    color: #0f5532;
}

.security-banner--amber {
    background: #fff8e1;
    border: 1px solid rgba(161, 98, 7, 0.18);
    color: var(--wr-amber-soft-text);
}

.security-banner-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.security-banner--green .security-banner-icon {
    background: rgba(22, 163, 74, 0.14);
    color: var(--wr-green);
}

.security-banner--amber .security-banner-icon {
    background: rgba(161, 98, 7, 0.12);
    color: var(--wr-amber);
}

.security-banner-icon .material-symbols-outlined { font-size: 20px; }

.security-banner-body { flex: 1; min-width: 0; }
.security-banner-title { font-size: 13px; font-weight: 600; }
.security-banner-sub { font-size: 12px; opacity: 0.85; margin-top: 2px; }

.security-method-name {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--wr-ink);
    font-weight: 500;
}

.security-check {
    color: var(--wr-green);
    font-size: 16px;
}

/* --- Minimal fallbacks for residual class hooks ----------------------- */
.security-wrap {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.security-intro {
    font-size: 13px;
    color: var(--wr-ink-3);
    margin: 0 0 4px;
}

.pkg-group-toggle {
    display: inline-flex;
    align-items: center;
}

.icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.row {
    display: flex;
    gap: 8px;
    align-items: center;
}

label.checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--wr-ink-2);
    cursor: pointer;
}

/* --- Responsive ------------------------------------------------------ */
@media (max-width: 800px) {
    .dash-sidebar {
        position: fixed;
        z-index: 40;
        transform: translateX(-100%);
        transition: transform 0.18s;
    }

    .dash-sidebar.open {
        transform: translateX(0);
    }

    .dash-content,
    .dash-topbar {
        padding-left: 18px;
        padding-right: 18px;
    }

    .dash-alert-wrap {
        padding-left: 18px;
        padding-right: 18px;
    }
}
