/* WebRust v2 design system, scoped under .wr-v2 wrapper so it doesn't leak to other pages */

.wr-v2 {
    --blue: #1B4FE0;
    --blue-700: #143fb8;
    --blue-50: #EDF1FE;
    --navy: #0A1A3D;
    --navy-2: #122351;
    --bg: #F7F6F2;
    --bg-2: #ECEAE2;
    --ink: #0B0E1A;
    --ink-2: #2A2E3D;
    --muted: #6A6E7E;
    --line: #DCD9CF;
    --line-dark: #1B2A55;
    --accent: #F4E3B2;
    --radius: 14px;
    --maxw: 1240px;

    font-family: "Geist", ui-sans-serif, system-ui, -apple-system, sans-serif;
    font-feature-settings: "ss01","cv11";
    background: var(--bg);
    color: var(--ink);
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
.wr-v2 * { box-sizing: border-box; }
.wr-v2 img, .wr-v2 svg { display: block; max-width: 100%; }
.wr-v2 a { color: inherit; text-decoration: none; }
.wr-v2 button { font: inherit; cursor: pointer; }

.wr-v2 .mono { font-family: "Geist Mono", ui-monospace, monospace; font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase; }
.wr-v2 .serif,
.wr-v2 .ital { color: var(--blue); font-weight: 400; font-style: normal; }

.wr-v2 .container { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* Buttons */
.wr-v2 .btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 13px 20px; border-radius: 999px;
    font-size: 14.5px; font-weight: 500;
    border: 1px solid transparent;
    transition: transform .15s ease, background .15s, border-color .15s, color .15s;
    white-space: nowrap;
    text-decoration: none;
    line-height: 1;
}
.wr-v2 .btn-primary { background: var(--blue); color: #fff; }
.wr-v2 .btn-primary:hover { background: var(--blue-700); transform: translateY(-1px); color: #fff; }
.wr-v2 .btn-ink { background: var(--ink); color: var(--bg); }
.wr-v2 .btn-ink:hover { background: var(--blue); color: #fff; }
.wr-v2 .btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.wr-v2 .btn-ghost:hover { border-color: var(--ink); color: var(--ink); }
.wr-v2 .btn-light { background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.18); }
.wr-v2 .btn-light:hover { background: rgba(255,255,255,0.14); color: #fff; }
.wr-v2 .btn-arrow { width: 16px; height: 16px; }

/* Eyebrow / section header */
.wr-v2 .eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--muted);
}
.wr-v2 .eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); }
.wr-v2 .eyebrow.on-dark { color: rgba(255,255,255,0.6); }

.wr-v2 h1, .wr-v2 h2, .wr-v2 h3, .wr-v2 h4 { margin: 0; font-weight: 500; letter-spacing: -0.025em; line-height: 1.05; }
.wr-v2 h1 { font-size: clamp(48px, 7vw, 96px); }
.wr-v2 h2 { font-size: clamp(34px, 4.6vw, 60px); letter-spacing: -0.03em; }
.wr-v2 h3 { font-size: 22px; letter-spacing: -0.015em; line-height: 1.25; }
.wr-v2 p  { margin: 0; }

.wr-v2 .lead { font-size: 19px; line-height: 1.5; color: var(--ink-2); max-width: 56ch; }

/* Hero */
.wr-v2 .v2-hero {
    padding: 64px 0 88px;
    position: relative;
    overflow: hidden;
}
.wr-v2 .hero-grid {
    display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: end;
}
.wr-v2 .v2-hero h1 .accent { color: var(--blue); }
.wr-v2 .v2-hero h1 .ital { color: var(--blue); font-weight: 400; font-style: normal; }
.wr-v2 .hero-side { display: flex; flex-direction: column; gap: 22px; align-items: flex-start; }
.wr-v2 .hero-side .lead { font-size: 17px; }
.wr-v2 .cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* status pill */
.wr-v2 .status-pill {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11.5px; letter-spacing: 0.06em;
    padding: 7px 12px; border-radius: 999px;
    background: rgba(27,79,224,0.08); color: var(--blue);
    border: 1px solid rgba(27,79,224,0.18);
}
.wr-v2 .status-pill .pulse {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--blue);
    box-shadow: 0 0 0 0 rgba(27,79,224,0.6);
    animation: wr-v2-pulse 1.8s ease-out infinite;
    flex-shrink: 0;
}
@keyframes wr-v2-pulse {
    0% { box-shadow: 0 0 0 0 rgba(27,79,224,0.55); }
    70% { box-shadow: 0 0 0 8px rgba(27,79,224,0); }
    100% { box-shadow: 0 0 0 0 rgba(27,79,224,0); }
}

/* metric strip */
.wr-v2 .metrics {
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}
.wr-v2 .metric {
    padding: 28px 24px;
    border-right: 1px solid var(--line);
    display: flex; flex-direction: column; gap: 8px;
}
.wr-v2 .metric:last-child { border-right: none; }
.wr-v2 .metric .num { font-size: 38px; font-weight: 500; letter-spacing: -0.03em; line-height: 1; }
.wr-v2 .metric .num .small { font-size: 18px; color: var(--muted); margin-left: 4px; font-weight: 400; }
.wr-v2 .metric .lbl { font-family: "Geist Mono", ui-monospace, monospace; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }

/* Sections */
.wr-v2 .v2-section { padding: 96px 0; }
.wr-v2 .v2-section.no-pad-top { padding-top: 0; }
.wr-v2 .v2-section.bg-2 { background: var(--bg-2); }

.wr-v2 .section-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
    align-items: end; margin-bottom: 48px;
}
.wr-v2 .section-head .l { display: flex; flex-direction: column; gap: 16px; }
.wr-v2 .section-head .r { color: var(--ink-2); font-size: 17px; line-height: 1.55; max-width: 48ch; }

/* Services list */
.wr-v2 .services { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid var(--line); }
.wr-v2 .service {
    display: grid; grid-template-columns: 56px 1.1fr 1.6fr 200px;
    gap: 32px; align-items: start;
    padding: 32px 8px;
    border-bottom: 1px solid var(--line);
    transition: background .2s;
}
.wr-v2 .service:hover { background: color-mix(in oklab, var(--blue) 4%, transparent); }
.wr-v2 .service .idx { font-family: "Geist Mono", ui-monospace, monospace; font-size: 12px; color: var(--muted); padding-top: 8px; }
.wr-v2 .service h3 { padding-top: 4px; }
.wr-v2 .service p { color: var(--ink-2); font-size: 15.5px; line-height: 1.55; padding-top: 4px; }
.wr-v2 .service .tag-row { padding-top: 4px; display: flex; gap: 8px; flex-wrap: wrap; }
.wr-v2 .tag {
    padding: 4px 10px; border-radius: 999px; border: 1px solid var(--line);
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--ink-2); background: rgba(255,255,255,0.5);
}
.wr-v2 .tag.b { color: var(--blue); border-color: rgba(27,79,224,0.25); background: rgba(27,79,224,0.06); }

/* Dark sections */
.wr-v2 .dark { background: var(--navy); color: #fff; }
.wr-v2 .dark .eyebrow { color: rgba(255,255,255,0.6); }
.wr-v2 .dark .lead, .wr-v2 .dark .section-head .r { color: rgba(255,255,255,0.7); }
.wr-v2 .dark h2, .wr-v2 .dark h3 { color: #fff; }
.wr-v2 .dark .tag { color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.04); }

.wr-v2 .process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.wr-v2 .step {
    position: relative;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    padding: 28px 24px 96px;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.0));
    min-height: 320px;
    display: flex; flex-direction: column;
    overflow: hidden;
}
.wr-v2 .step .num {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 12px; color: rgba(255,255,255,0.5);
}
.wr-v2 .step h3 { margin-top: 24px; font-size: 24px; }
.wr-v2 .step p { margin-top: 12px; color: rgba(255,255,255,0.72); font-size: 15px; line-height: 1.55; }
.wr-v2 .step .visual {
    position: absolute; left: 24px; right: 24px; bottom: 24px; height: 56px;
    border-top: 1px solid rgba(255,255,255,0.12);
    padding-top: 18px;
    display: flex; align-items: center; gap: 8px;
}
.wr-v2 .step .chip {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 10.5px; letter-spacing: 0.06em;
    padding: 5px 10px; border-radius: 999px;
    background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.85);
}
.wr-v2 .step .chip.b { background: var(--blue); color: #fff; }

/* Dashboard mock */
.wr-v2 .dash-card {
    border: 1px solid var(--line); border-radius: 18px;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 1px 0 rgba(11,14,26,0.04), 0 24px 48px -24px rgba(11,14,26,0.18);
}
.wr-v2 .dash-bar {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 16px; border-bottom: 1px solid var(--line);
    background: #fbfaf6;
}
.wr-v2 .dash-bar .dot { width: 10px; height: 10px; border-radius: 50%; background: #E2DDCB; }
.wr-v2 .dash-bar .url {
    margin-left: 10px;
    font-family: "Geist Mono", ui-monospace, monospace; font-size: 12px;
    color: var(--muted);
    background: #fff; border: 1px solid var(--line); border-radius: 6px;
    padding: 4px 10px;
}
.wr-v2 .dash-body {
    display: grid; grid-template-columns: 220px 1fr;
    min-height: 360px;
}
.wr-v2 .dash-side { background: #faf9f4; border-right: 1px solid var(--line); padding: 16px 12px; display: flex; flex-direction: column; gap: 4px; }
.wr-v2 .dash-item { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 8px; font-size: 13px; color: var(--ink-2); }
.wr-v2 .dash-item.active { background: var(--ink); color: #fff; }
.wr-v2 .dash-item .ico { width: 14px; height: 14px; border-radius: 4px; background: currentColor; opacity: 0.4; }
.wr-v2 .dash-item.active .ico { opacity: 0.85; }
.wr-v2 .dash-main { padding: 22px 24px; display: flex; flex-direction: column; gap: 16px; }
.wr-v2 .dash-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.wr-v2 .dash-stat { border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; background: #fff; }
.wr-v2 .dash-stat .lbl { font-family: "Geist Mono", ui-monospace, monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.wr-v2 .dash-stat .val { font-size: 22px; font-weight: 500; letter-spacing: -0.02em; margin-top: 6px; }
.wr-v2 .dash-stat .delta { font-size: 11px; color: #1aa572; margin-top: 2px; font-family: "Geist Mono", monospace; }
.wr-v2 .dash-stat.alt .val { color: var(--blue); }

.wr-v2 .spark { width: 100%; height: 90px; }

.wr-v2 .dash-table { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: #fff; }
.wr-v2 .dash-row { display: grid; grid-template-columns: 1.4fr 1fr 100px 80px; gap: 8px; align-items: center; padding: 10px 16px; font-size: 13px; border-bottom: 1px solid var(--line); }
.wr-v2 .dash-row:last-child { border-bottom: none; }
.wr-v2 .dash-row.head { background: #faf9f4; font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); padding: 8px 16px; }
.wr-v2 .dash-pill { display: inline-flex; align-items: center; gap: 6px; padding: 3px 8px; border-radius: 999px; font-size: 11px; font-family: "Geist Mono", monospace; background: #E8F6EF; color: #178a5d; }
.wr-v2 .dash-pill .d { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* Hosting cards */
.wr-v2 .hosting-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.wr-v2 .h-card {
    position: relative;
    border: 1px solid var(--line); border-radius: 18px;
    background: #fff;
    padding: 28px;
    display: flex; flex-direction: column; gap: 16px;
    min-height: 280px;
    transition: transform .2s, border-color .2s;
}
.wr-v2 .h-card:hover { transform: translateY(-2px); border-color: var(--ink); }
.wr-v2 .h-card .badge {
    position: absolute; top: 16px; right: 16px;
    left: auto; transform: none;
    font-family: "Geist Mono", monospace; font-size: 10px;
    letter-spacing: 0.1em; text-transform: uppercase;
    background: var(--blue); color: #fff;
    padding: 4px 8px; border-radius: 999px;
    white-space: nowrap;
}
.wr-v2 .h-card h3 { font-size: 22px; }
.wr-v2 .h-card p { color: var(--ink-2); font-size: 14.5px; line-height: 1.55; }
.wr-v2 .h-card .arrow { margin-top: auto; font-family: "Geist Mono", monospace; font-size: 12px; color: var(--blue); display: flex; align-items: center; gap: 6px; }
.wr-v2 .h-card.feat { background: var(--ink); color: #fff; border-color: var(--ink); }
.wr-v2 .h-card.feat p { color: rgba(255,255,255,0.7); }
.wr-v2 .h-card.feat .arrow { color: #fff; }

/* Builder mock */
.wr-v2 .builder-block {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center;
}
.wr-v2 .builder-mock {
    position: relative;
    border-radius: 18px; overflow: hidden;
    border: 1px solid var(--line);
    background: #fff;
    box-shadow: 0 24px 60px -32px rgba(11,14,26,0.2);
    aspect-ratio: 4 / 3;
}
.wr-v2 .bm-bar { display: flex; align-items: center; gap: 6px; padding: 10px 14px; border-bottom: 1px solid var(--line); background: #fbfaf6; }
.wr-v2 .bm-bar .d { width: 8px; height: 8px; border-radius: 50%; background: #E2DDCB; }
.wr-v2 .bm-canvas {
    display: grid; grid-template-columns: 60px 1fr 240px; height: calc(100% - 38px);
}
.wr-v2 .bm-tools { background: #fbfaf6; border-right: 1px solid var(--line); padding: 12px 8px; display: flex; flex-direction: column; gap: 8px; align-items: center; }
.wr-v2 .bm-tool { width: 36px; height: 36px; border-radius: 8px; background: #ECEAE2; }
.wr-v2 .bm-tool.on { background: var(--blue); }
.wr-v2 .bm-stage { padding: 24px; display: flex; flex-direction: column; gap: 12px; }
.wr-v2 .bm-block { background: #ECEAE2; border-radius: 8px; }
.wr-v2 .bm-block.h { height: 28px; width: 60%; }
.wr-v2 .bm-block.h2 { height: 18px; width: 38%; }
.wr-v2 .bm-block.img { height: 90px; background: linear-gradient(135deg, #DCE6FF 0%, #B8C9F5 100%); position: relative; overflow: hidden; }
.wr-v2 .bm-block.img::after { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent 0 12px, rgba(255,255,255,0.18) 12px 14px); }
.wr-v2 .bm-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.wr-v2 .bm-row .bm-block { height: 50px; }
.wr-v2 .bm-side { background: #fbfaf6; border-left: 1px solid var(--line); padding: 16px 14px; }
.wr-v2 .bm-side h4 { font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin: 0 0 12px; }
.wr-v2 .bm-prop { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 12px; }
.wr-v2 .bm-prop:last-child { border-bottom: none; }
.wr-v2 .bm-prop .k { color: var(--muted); }
.wr-v2 .bm-swatch { display: flex; gap: 6px; margin-top: 14px; }
.wr-v2 .bm-swatch span { width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line); }

/* Speed test block */
.wr-v2 .speed-block { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.wr-v2 .speed-card {
    border-radius: 24px; overflow: hidden;
    background: var(--navy);
    color: #fff;
    padding: 32px;
    position: relative;
}
.wr-v2 .gauge {
    width: 100%; aspect-ratio: 1.7;
    position: relative;
    display: flex; align-items: flex-end; justify-content: center;
}
.wr-v2 .gauge svg { width: 100%; height: 100%; }
.wr-v2 .gauge .score {
    position: absolute; bottom: 6%; left: 50%; transform: translateX(-50%);
    font-size: 88px; font-weight: 500; letter-spacing: -0.04em; line-height: 1;
}
.wr-v2 .gauge .score sub { font-size: 24px; color: rgba(255,255,255,0.55); margin-left: 6px; vertical-align: super; }
.wr-v2 .gauge .lbl { position: absolute; left: 50%; transform: translateX(-50%); top: 8%; font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.14em; color: rgba(255,255,255,0.55); text-transform: uppercase; }
.wr-v2 .speed-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 20px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.1); }
.wr-v2 .speed-meta .it { font-size: 13px; }
.wr-v2 .speed-meta .it .v { font-size: 22px; font-weight: 500; letter-spacing: -0.02em; }
.wr-v2 .speed-meta .it .l { font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.55); margin-top: 4px; }

/* Migration card */
.wr-v2 .mig-card {
    background: var(--blue); color: #fff;
    border-radius: 24px; padding: 56px;
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center;
    position: relative; overflow: hidden;
}
.wr-v2 .mig-card::before {
    content: ""; position: absolute; right: -120px; top: -120px;
    width: 480px; height: 480px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,0.16), rgba(255,255,255,0) 60%);
}
.wr-v2 .mig-card h2 { color: #fff; }
.wr-v2 .mig-card p { color: rgba(255,255,255,0.85); font-size: 17px; line-height: 1.5; }

.wr-v2 .mig-flow {
    position: relative;
    border-radius: 16px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    padding: 24px;
    display: flex; flex-direction: column; gap: 14px;
}
.wr-v2 .mig-step {
    display: flex; align-items: center; gap: 14px;
    font-family: "Geist Mono", monospace; font-size: 12px; letter-spacing: 0.06em;
}
.wr-v2 .mig-step .b { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,0.12); }
.wr-v2 .mig-step .ar { color: rgba(255,255,255,0.6); }
.wr-v2 .mig-step.done .b { background: #fff; color: var(--blue); }
.wr-v2 .mig-step.done .check { width: 14px; height: 14px; border-radius: 50%; background: var(--blue); display: inline-grid; place-items: center; color: #fff; font-size: 9px; }

/* FAQ - overrides the element-level details/summary rules in styles.css */
.wr-v2 .v2-faq { display: flex; flex-direction: column; gap: 0; }
.wr-v2 .v2-faq .faq-item {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--line);
    border-radius: 0;
    overflow: visible;
}
.wr-v2 .v2-faq .faq-item[open] { border-color: var(--line); }
.wr-v2 .v2-faq .faq-q {
    display: flex; justify-content: space-between; align-items: center;
    padding: 24px 0; cursor: pointer; user-select: none;
    font-size: 19px; letter-spacing: -0.01em; font-weight: 500;
    list-style: none;
    color: var(--ink);
    gap: 16px;
}
.wr-v2 .v2-faq .faq-q::-webkit-details-marker,
.wr-v2 .v2-faq .faq-q::after { display: none; content: none; }
.wr-v2 .v2-faq .faq-q .ic {
    width: 32px; height: 32px; border-radius: 50%;
    border: 1px solid var(--line);
    display: grid; place-items: center;
    transition: transform .2s, background .2s, border-color .2s;
    flex-shrink: 0;
    font-size: 18px;
    line-height: 1;
    color: var(--ink);
    background: transparent;
}
.wr-v2 .v2-faq .faq-item[open] .faq-q .ic { background: var(--blue); border-color: var(--blue); color: #fff; transform: rotate(45deg); }
.wr-v2 .v2-faq .faq-a {
    padding: 0 0 24px;
    color: var(--ink-2);
    font-size: 15.5px;
    line-height: 1.6;
    max-width: 70ch;
    font-weight: 400;
}

/* Final CTA */
.wr-v2 .final-cta {
    padding: 120px 0;
    text-align: center;
}
.wr-v2 .final-cta h2 { font-size: clamp(48px, 7vw, 96px); max-width: 14ch; margin: 0 auto 32px; }
.wr-v2 .final-cta h2 .ital { color: var(--blue); font-weight: 400; font-style: normal; }
.wr-v2 .final-cta .lead { margin: 0 auto 32px; text-align: center; }

/* Hosting page specific */
.wr-v2 .hp-hero { padding: 72px 0 56px; }
.wr-v2 .hp-hero h1 { font-size: clamp(42px, 6vw, 80px); }
.wr-v2 .hp-hero h1 .ital { color: var(--blue); font-weight: 400; font-style: normal; }
.wr-v2 .hp-hero .lead { font-size: 18px; }

.wr-v2 .billing-tab {
    padding: 6px 14px; border-radius: 999px; border: 0;
    background: transparent; font-size: 13px; color: var(--ink-2);
    cursor: pointer;
}
.wr-v2 .billing-tab.on { background: var(--ink); color: #fff; }

/* Override the global interval-picker partial styling to match v2 look */
.wr-v2 .interval-picker-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
}
.wr-v2 .interval-picker {
    display: inline-flex;
    background: var(--bg-2);
    border: none;
    border-radius: 999px;
    padding: 3px;
    gap: 2px;
    box-shadow: none;
}
.wr-v2 .interval-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    border: 0;
    background: transparent;
    border-radius: 999px;
    font-family: "Geist", ui-sans-serif, system-ui, sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: var(--ink-2);
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
    box-shadow: none;
}
.wr-v2 .interval-btn:hover:not(.active) {
    background: transparent;
    color: var(--ink);
}
.wr-v2 .interval-btn.active {
    background: var(--ink);
    color: #fff;
    box-shadow: none;
}
.wr-v2 .interval-discount {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(27,79,224,0.1);
    color: var(--blue);
}
.wr-v2 .interval-btn.active .interval-discount {
    background: rgba(255,255,255,0.18);
    color: var(--accent);
}

.wr-v2 .tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.wr-v2 .tier {
    background: #fff; border: 1px solid var(--line);
    border-radius: 22px; padding: 32px;
    display: flex; flex-direction: column; gap: 18px;
    position: relative;
}
.wr-v2 .tier.feat { background: var(--ink); color: #fff; border-color: var(--ink); }
.wr-v2 .tier.feat h3 { color: #fff; }
.wr-v2 .tier.feat .price { color: #fff; }
.wr-v2 .tier.feat .feat-list li { color: rgba(255,255,255,0.85); }
.wr-v2 .tier.feat .feat-list svg { color: var(--blue); }
.wr-v2 .tier .ribbon {
    position: absolute; top: -12px; right: 24px;
    background: var(--blue); color: #fff;
    font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
    padding: 5px 10px; border-radius: 999px;
}
.wr-v2 .tier h3 { font-size: 24px; }
.wr-v2 .price { display: flex; align-items: baseline; gap: 6px; padding: 16px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.wr-v2 .tier.feat .price { border-color: rgba(255,255,255,0.12); }
.wr-v2 .price .cur { font-size: 18px; color: var(--muted); }
.wr-v2 .price .num { font-size: 56px; font-weight: 500; letter-spacing: -0.04em; line-height: 1; }
.wr-v2 .price .per { font-size: 13px; color: var(--muted); margin-left: 6px; font-family: "Geist Mono", monospace; }
.wr-v2 .tier.feat .price .cur,
.wr-v2 .tier.feat .price .per { color: rgba(255,255,255,0.6); }
.wr-v2 .feat-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.wr-v2 .feat-list li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--ink-2); line-height: 1.45; }
.wr-v2 .feat-list li::before { display: none; content: none; }
.wr-v2 .feat-list svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--blue); margin-top: 2px; }
.wr-v2 .tier .btn { width: 100%; justify-content: center; }

/* Spec table */
.wr-v2 .spec-table {
    width: 100%; border-collapse: collapse;
    background: #fff; border: 1px solid var(--line); border-radius: 18px; overflow: hidden;
}
.wr-v2 .spec-table th, .wr-v2 .spec-table td {
    text-align: left; padding: 16px 20px; font-size: 14px; vertical-align: middle;
    border-bottom: 1px solid var(--line);
    color: var(--ink-2);
}
.wr-v2 .spec-table thead th {
    font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--muted); background: #fbfaf6;
    font-weight: 400;
}
.wr-v2 .spec-table thead th.col-feat { background: var(--ink); color: #fff; }
.wr-v2 .spec-table tbody tr:last-child td { border-bottom: none; }
.wr-v2 .spec-table td.feat-row { font-weight: 500; color: var(--ink); }
.wr-v2 .spec-table .yes { color: var(--blue); font-weight: 500; }
.wr-v2 .spec-table td.col-feat-cell { background: rgba(11,14,26,0.03); }
.wr-v2 .spec-table tr:hover td { background: transparent; }
.wr-v2 .spec-table tr:hover td.col-feat-cell { background: rgba(11,14,26,0.05); }

/* Infra panels */
.wr-v2 .infra { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.wr-v2 .infra .panel {
    background: var(--navy); color: #fff;
    border-radius: 18px;
    padding: 32px;
    display: flex; flex-direction: column; gap: 20px;
    position: relative; overflow: hidden;
}
.wr-v2 .infra .panel.alt { background: #fff; color: var(--ink); border: 1px solid var(--line); }
.wr-v2 .infra h3 { font-size: 26px; max-width: 18ch; color: #fff; }
.wr-v2 .infra .panel.alt h3 { color: var(--ink); }
.wr-v2 .infra .panel p { color: rgba(255,255,255,0.72); font-size: 15px; line-height: 1.55; max-width: 38ch; }
.wr-v2 .infra .panel.alt p { color: var(--ink-2); }

/* Performance bars */
.wr-v2 .perf-card {
    background: #fff; border: 1px solid var(--line); border-radius: 18px;
    padding: 32px;
}
.wr-v2 .perf-bars { display: flex; flex-direction: column; gap: 16px; margin-top: 24px; }
.wr-v2 .perf-row { display: grid; grid-template-columns: 180px 1fr 80px; gap: 16px; align-items: center; font-size: 13px; }
.wr-v2 .perf-row .name { font-weight: 500; color: var(--ink); }
.wr-v2 .perf-row .bar { height: 10px; border-radius: 999px; background: #ECEAE2; position: relative; overflow: hidden; }
.wr-v2 .perf-row .bar i { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 999px; background: linear-gradient(90deg, var(--blue), #4D7BF0); }
.wr-v2 .perf-row.us .name { color: var(--blue); font-weight: 600; }
.wr-v2 .perf-row.us .bar i { background: var(--blue); }
.wr-v2 .perf-row .ms { font-family: "Geist Mono", monospace; font-size: 12px; color: var(--muted); text-align: right; }
.wr-v2 .perf-row.us .ms { color: var(--blue); }

/* About page: values + team */
.wr-v2 .values {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
    border-top: 1px solid var(--line); padding-top: 48px;
}
.wr-v2 .value { display: flex; flex-direction: column; gap: 12px; }
.wr-v2 .value .n { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.12em; color: var(--blue); text-transform: uppercase; }
.wr-v2 .value h3 { font-size: 24px; }
.wr-v2 .value p { font-size: 15px; color: var(--ink-2); line-height: 1.6; max-width: 38ch; }

.wr-v2 .team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.wr-v2 .member {
    background: #fff; border: 1px solid var(--line); border-radius: 18px;
    padding: 28px;
    display: flex; flex-direction: column; gap: 12px;
}
.wr-v2 .member .role { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.08em; color: var(--blue); text-transform: uppercase; }
.wr-v2 .member .name { font-size: 22px; font-weight: 500; letter-spacing: -0.015em; line-height: 1.2; color: var(--ink); }
.wr-v2 .member .bio { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }

/* Contact page: channels, form, availability card */
.wr-v2 .contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; align-items: start; }
.wr-v2 .channel-list { display: flex; flex-direction: column; gap: 12px; }
.wr-v2 .channel {
    display: flex; gap: 16px; align-items: flex-start;
    padding: 20px 22px;
    background: #fff; border: 1px solid var(--line); border-radius: 14px;
    transition: border-color .2s, transform .2s;
    text-decoration: none;
    color: var(--ink);
}
.wr-v2 .channel:hover { border-color: var(--ink); transform: translateY(-1px); }
.wr-v2 .channel .glyph {
    width: 42px; height: 42px; border-radius: 12px;
    background: var(--blue-50); color: var(--blue);
    display: grid; place-items: center; flex-shrink: 0;
}
.wr-v2 .channel .glyph svg { width: 20px; height: 20px; }
.wr-v2 .channel .body { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 0; }
.wr-v2 .channel .body .k { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.wr-v2 .channel .body .v { font-size: 17px; font-weight: 500; letter-spacing: -0.01em; color: var(--ink); }
.wr-v2 .channel .body .hint { font-size: 13px; color: var(--muted); line-height: 1.5; }

.wr-v2 .form-card {
    background: #fff; border: 1px solid var(--line); border-radius: 22px;
    padding: 36px;
    display: flex; flex-direction: column; gap: 18px;
}
.wr-v2 .form-card .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.wr-v2 .form-card .field { display: flex; flex-direction: column; gap: 6px; }
.wr-v2 .form-card .field > label {
    font-family: "Geist Mono", monospace; font-size: 10.5px;
    letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted);
}
.wr-v2 .form-card .field input,
.wr-v2 .form-card .field textarea,
.wr-v2 .form-card .field select {
    font: inherit; font-size: 15px; color: var(--ink);
    background: var(--bg); border: 1px solid var(--line);
    border-radius: 10px; padding: 12px 14px;
    transition: border-color .15s, background .15s;
    width: 100%;
    font-family: inherit;
}
.wr-v2 .form-card .field input:focus,
.wr-v2 .form-card .field textarea:focus,
.wr-v2 .form-card .field select:focus {
    outline: none; border-color: var(--ink); background: #fff;
}
.wr-v2 .form-card .field textarea { resize: vertical; min-height: 120px; }
.wr-v2 .form-card .budget-row { display: flex; flex-wrap: wrap; gap: 8px; }
.wr-v2 .form-card .budget-row label {
    font-family: "Geist Mono", monospace; font-size: 11px;
    padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
    cursor: pointer; transition: border-color .15s, background .15s, color .15s;
    color: var(--ink-2); background: var(--bg);
    text-transform: uppercase; letter-spacing: 0.08em;
}
.wr-v2 .form-card .budget-row input { display: none; }
.wr-v2 .form-card .budget-row input:checked + label { background: var(--ink); color: #fff; border-color: var(--ink); }
.wr-v2 .form-card .form-foot { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 8px; }
.wr-v2 .form-card .form-foot .small { font-size: 12px; color: var(--muted); max-width: 36ch; line-height: 1.5; }

/* Repurposed addr-card: availability/schedule */
.wr-v2 .addr-card {
    background: var(--navy); color: #fff;
    border-radius: 22px; overflow: hidden;
    display: grid; grid-template-columns: 1fr 1fr; align-items: stretch;
    position: relative;
}
.wr-v2 .addr-info { padding: 40px; display: flex; flex-direction: column; gap: 24px; }
.wr-v2 .addr-info h3 { font-size: 32px; max-width: 14ch; color: #fff; }
.wr-v2 .addr-info p { color: rgba(255,255,255,0.72); font-size: 15px; line-height: 1.55; max-width: 38ch; }
.wr-v2 .addr-info .lines { font-family: "Geist Mono", monospace; font-size: 13px; line-height: 1.8; color: rgba(255,255,255,0.85); letter-spacing: 0.04em; }

.wr-v2 .addr-sched {
    background: var(--navy);
    border-left: 1px solid rgba(255,255,255,0.08);
    position: relative; overflow: hidden;
    padding: 36px 32px;
    display: flex; flex-direction: column;
    min-height: 320px;
}
.wr-v2 .addr-sched .sched-head {
    display: grid;
    grid-template-columns: 36px repeat(7, 1fr);
    gap: 8px;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.wr-v2 .addr-sched .sched-head .d {
    font-family: "Geist Mono", monospace; font-size: 11px;
    color: rgba(255,255,255,0.65); letter-spacing: 0.1em;
    text-align: center;
}
.wr-v2 .addr-sched .sched-head .d.off { color: rgba(255,255,255,0.3); }
.wr-v2 .addr-sched .sched-body {
    display: grid;
    grid-template-columns: 36px repeat(7, 1fr);
    gap: 8px;
    flex: 1;
    min-height: 220px;
}
.wr-v2 .addr-sched .hours {
    display: flex; flex-direction: column;
    justify-content: space-between;
    font-family: "Geist Mono", monospace; font-size: 10px;
    color: rgba(255,255,255,0.4); letter-spacing: 0.08em;
    text-align: right;
    padding: 2px 0;
}
.wr-v2 .addr-sched .day-col {
    position: relative;
    background: rgba(255,255,255,0.04);
    border-radius: 6px;
    overflow: hidden;
}
.wr-v2 .addr-sched .day-col .open {
    position: absolute;
    left: 4px; right: 4px;
    background: var(--blue);
    border-radius: 4px;
}
.wr-v2 .addr-sched .day-col.off { background: rgba(255,255,255,0.02); }
.wr-v2 .addr-sched .sched-legend {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
    display: flex; align-items: center; gap: 16px;
    font-family: "Geist Mono", monospace; font-size: 11px;
    color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
    flex-wrap: wrap;
}
.wr-v2 .addr-sched .sched-legend .item {
    display: inline-flex; align-items: center; gap: 8px;
}
.wr-v2 .addr-sched .sched-legend .swatch {
    width: 10px; height: 10px;
    border-radius: 3px;
    background: var(--blue);
}
.wr-v2 .addr-sched .sched-legend .swatch.off { background: rgba(255,255,255,0.08); }

/* Site Builder page: WIP pill, larger builder hero, palette, feature grid */
.wr-v2 .wip-pill {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: "Geist Mono", monospace;
    font-size: 11.5px; letter-spacing: 0.08em;
    padding: 7px 12px; border-radius: 999px;
    background: rgba(244,227,178,0.4); color: #6b5818;
    border: 1px solid rgba(180,150,40,0.3);
    text-transform: uppercase;
}
.wr-v2 .wip-pill .d { width: 7px; height: 7px; border-radius: 50%; background: #b9933a; }

.wr-v2 .builder-hero {
    border: 1px solid var(--line); border-radius: 22px; overflow: hidden;
    background: #fff;
    box-shadow: 0 30px 70px -36px rgba(11,14,26,0.25);
}
.wr-v2 .builder-hero .bm-canvas { grid-template-columns: 64px 1fr 260px; height: 480px; }
.wr-v2 .builder-hero .bm-stage { background: #fbfaf6; gap: 14px; }
.wr-v2 .builder-hero .bm-block.img { height: 130px; }
.wr-v2 .builder-hero .bm-tool {
    display: grid; place-items: center;
    width: 40px; height: 40px;
}
.wr-v2 .builder-hero .bm-tool .glyph {
    width: 18px; height: 18px; border-radius: 4px;
    background: var(--ink-2); opacity: 0.35;
}
.wr-v2 .builder-hero .bm-tool.on .glyph { background: #fff; opacity: 1; }

/* Component library palette (dark strip) */
.wr-v2 .palette {
    background: var(--ink); color: #fff;
    border-radius: 22px;
    padding: 36px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
}
.wr-v2 .palette h2 { color: #fff; }
.wr-v2 .palette p { color: rgba(255,255,255,0.72); font-size: 16px; line-height: 1.55; max-width: 44ch; margin-top: 14px; }
.wr-v2 .palette-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.wr-v2 .palette-tile {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px;
    aspect-ratio: 1;
    padding: 14px;
    background: rgba(255,255,255,0.04);
    display: flex; flex-direction: column; justify-content: space-between;
    font-family: "Geist Mono", monospace; font-size: 11px;
    color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
    transition: background .15s, border-color .15s;
}
.wr-v2 .palette-tile:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); }
.wr-v2 .palette-tile .preview {
    flex: 1;
    margin-bottom: 10px;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.8);
}
.wr-v2 .palette-tile.b { background: var(--blue); border-color: var(--blue); color: rgba(255,255,255,0.9); }

/* 3x2 feature grid */
.wr-v2 .feat-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.wr-v2 .feat-item {
    padding: 32px 28px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    display: flex; flex-direction: column; gap: 10px;
}
.wr-v2 .feat-item:nth-child(3n) { border-right: none; }
.wr-v2 .feat-item:nth-last-child(-n+3) { border-bottom: none; }
.wr-v2 .feat-item .n { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: 0.12em; color: var(--blue); text-transform: uppercase; }
.wr-v2 .feat-item h3 { font-size: 22px; margin-top: 4px; font-weight: 500; letter-spacing: -0.015em; line-height: 1.25; }
.wr-v2 .feat-item p { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }

/* Dark variant of feat-grid (used on snelheidstest "Wat doen we") */
.wr-v2 .dark .feat-grid { border-top-color: rgba(255,255,255,0.1); border-bottom-color: rgba(255,255,255,0.1); }
.wr-v2 .dark .feat-item { border-right-color: rgba(255,255,255,0.1); border-bottom-color: rgba(255,255,255,0.1); }
.wr-v2 .dark .feat-item h3 { color: #fff; }
.wr-v2 .dark .feat-item p { color: rgba(255,255,255,0.7); }

/* Rail / step process (web dev page) */
.wr-v2 .rail {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.wr-v2 .rail .r-step {
    padding: 28px 24px;
    border-right: 1px solid var(--line);
    display: flex; flex-direction: column; gap: 12px;
}
.wr-v2 .rail .r-step:last-child { border-right: none; padding-right: 0; }
.wr-v2 .rail .r-step:first-child { padding-left: 0; }
.wr-v2 .rail .r-step .n {
    font-family: "Geist Mono", monospace; font-size: 11px;
    letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue);
}
.wr-v2 .rail .r-step h4 { font-size: 18px; line-height: 1.3; font-weight: 500; letter-spacing: -0.01em; }
.wr-v2 .rail .r-step p { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; }

/* Work / portfolio cards (web dev page, currently commented out) */
.wr-v2 .work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.wr-v2 .work-card {
    background: #fff; border: 1px solid var(--line); border-radius: 18px;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .2s, border-color .2s;
}
.wr-v2 .work-card:hover { transform: translateY(-3px); border-color: var(--ink); }
.wr-v2 .work-card .thumb {
    aspect-ratio: 4 / 3;
    background: repeating-linear-gradient(45deg, #ECEAE2 0 8px, #E2DDCB 8px 9px);
    border-bottom: 1px solid var(--line);
    position: relative;
    display: flex; align-items: center; justify-content: center;
}
.wr-v2 .work-card .thumb .label {
    font-family: "Geist Mono", monospace; font-size: 11px;
    letter-spacing: 0.08em; color: var(--muted); text-transform: uppercase;
    background: var(--bg); padding: 6px 12px; border-radius: 999px;
    border: 1px solid var(--line);
}
.wr-v2 .work-card .meta { padding: 22px 24px; display: flex; flex-direction: column; gap: 6px; }
.wr-v2 .work-card .meta .sub {
    font-family: "Geist Mono", monospace; font-size: 11px;
    letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted);
}
.wr-v2 .work-card .meta h4 { font-size: 19px; font-weight: 500; letter-spacing: -0.015em; }
.wr-v2 .work-card .meta .tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }

/* Legal documents (privacy, terms, cookies) */
.wr-v2 .legal-doc {
    max-width: 760px;
    margin: 0 auto;
    color: var(--ink-2);
    font-size: 15.5px;
    line-height: 1.7;
}
.wr-v2 .legal-section {
    padding: 32px 0;
    border-bottom: 1px solid var(--line);
}
.wr-v2 .legal-section:first-child { padding-top: 0; }
.wr-v2 .legal-section:last-child { border-bottom: none; padding-bottom: 0; }
.wr-v2 .legal-section h2 {
    font-size: 24px;
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin: 0 0 16px;
    line-height: 1.2;
}
.wr-v2 .legal-section h3 {
    font-size: 17px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    margin: 24px 0 10px;
}
.wr-v2 .legal-section p {
    margin: 0 0 12px;
    color: var(--ink-2);
}
.wr-v2 .legal-section p:last-child { margin-bottom: 0; }
.wr-v2 .legal-section strong { color: var(--ink); font-weight: 500; }
.wr-v2 .legal-section ul,
.wr-v2 .legal-section ol {
    margin: 12px 0;
    padding-left: 24px;
    color: var(--ink-2);
}
.wr-v2 .legal-section ul li,
.wr-v2 .legal-section ol li {
    margin-bottom: 8px;
    line-height: 1.6;
}
.wr-v2 .legal-section a {
    color: var(--blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(27,79,224,0.3);
    transition: border-color .15s;
}
.wr-v2 .legal-section a:hover { border-color: var(--blue); }
.wr-v2 .legal-section code {
    font-family: "Geist Mono", monospace;
    font-size: 13.5px;
    background: var(--bg-2);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--ink);
}
.wr-v2 .legal-section table {
    width: 100%;
    border-collapse: collapse;
    margin: 16px 0;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    overflow: hidden;
    font-size: 14px;
}
.wr-v2 .legal-section thead th {
    background: #fbfaf6;
    text-align: left;
    padding: 12px 16px;
    font-family: "Geist Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    font-weight: 500;
    border-bottom: 1px solid var(--line);
}
.wr-v2 .legal-section tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--line);
    vertical-align: top;
    color: var(--ink-2);
}
.wr-v2 .legal-section tbody tr:last-child td { border-bottom: none; }
.wr-v2 .legal-section tbody tr:hover td { background: rgba(11,14,26,0.02); }

/* Blog listing */
.wr-v2 .blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.wr-v2 .blog-card-wrap { display: flex; flex-direction: column; gap: 8px; }
.wr-v2 .blog-card-admin {
    display: flex;
    gap: 8px;
    padding: 0 4px;
}
.wr-v2 .blog-card-admin form { display: inline; margin: 0; }
.wr-v2 .blog-admin-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-2);
    background: #fff;
    border: 1px solid var(--line);
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
    text-decoration: none;
    line-height: 1;
}
.wr-v2 .blog-admin-chip:hover { border-color: var(--ink); color: var(--ink); }
.wr-v2 .blog-admin-chip.danger { color: #b42318; border-color: rgba(180,35,24,0.25); }
.wr-v2 .blog-admin-chip.danger:hover { background: rgba(180,35,24,0.06); border-color: #b42318; color: #b42318; }

.wr-v2 .blog-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px;
    display: flex; flex-direction: column;
    gap: 14px;
    transition: border-color .2s, transform .2s;
    text-decoration: none;
    color: inherit;
}
.wr-v2 .blog-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.wr-v2 .blog-card .meta {
    font-family: "Geist Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
    display: flex; gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.wr-v2 .blog-card .meta .sep { color: var(--line); }
.wr-v2 .blog-card h2 {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--ink);
    line-height: 1.2;
    margin: 0;
}
.wr-v2 .blog-card p {
    font-size: 14.5px;
    color: var(--ink-2);
    line-height: 1.55;
    margin: 0;
}
.wr-v2 .blog-card .read-more {
    font-family: "Geist Mono", monospace;
    font-size: 12px;
    color: var(--blue);
    margin-top: auto;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* Blog pagination */
.wr-v2 .pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    margin-top: 48px;
    font-family: "Geist Mono", monospace;
    font-size: 12px;
    color: var(--muted);
    letter-spacing: 0.04em;
}
.wr-v2 .pagination .disabled { opacity: 0.4; cursor: not-allowed; }

/* Blog single article */
.wr-v2 .blog-article {
    max-width: 720px;
    margin: 0 auto;
    color: var(--ink);
    font-size: 16.5px;
    line-height: 1.75;
}
.wr-v2 .blog-article > *:first-child { margin-top: 0; }
.wr-v2 .blog-article h1 { font-size: 32px; margin: 32px 0 16px; font-weight: 500; letter-spacing: -0.025em; line-height: 1.15; }
.wr-v2 .blog-article h2 { font-size: 24px; margin: 32px 0 14px; font-weight: 500; letter-spacing: -0.02em; line-height: 1.2; }
.wr-v2 .blog-article h3 { font-size: 19px; margin: 28px 0 12px; font-weight: 500; letter-spacing: -0.015em; }
.wr-v2 .blog-article p { margin: 0 0 18px; color: var(--ink-2); }
.wr-v2 .blog-article ul,
.wr-v2 .blog-article ol { margin: 0 0 18px; padding-left: 24px; color: var(--ink-2); }
.wr-v2 .blog-article li { margin-bottom: 8px; }
.wr-v2 .blog-article a { color: var(--blue); text-decoration: none; border-bottom: 1px solid rgba(27,79,224,0.3); }
.wr-v2 .blog-article a:hover { border-color: var(--blue); }
.wr-v2 .blog-article code {
    font-family: "Geist Mono", monospace;
    font-size: 14px;
    background: var(--bg-2);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--ink);
}
.wr-v2 .blog-article pre {
    background: #050B22; color: #C8D6FF;
    padding: 20px;
    border-radius: 14px;
    overflow-x: auto;
    margin: 24px 0;
    font-family: "Geist Mono", monospace;
    font-size: 13px;
    line-height: 1.7;
}
.wr-v2 .blog-article pre code { background: transparent; padding: 0; color: inherit; }
.wr-v2 .blog-article blockquote {
    margin: 24px 0;
    padding: 16px 24px;
    border-left: 3px solid var(--blue);
    background: rgba(27,79,224,0.04);
    color: var(--ink);
    font-style: italic;
}
.wr-v2 .blog-article img { max-width: 100%; height: auto; border-radius: 10px; margin: 24px 0; }

.wr-v2 .blog-back {
    display: inline-flex; align-items: center; gap: 8px;
    margin-top: 48px; padding-top: 32px;
    border-top: 1px solid var(--line);
    width: 100%;
    font-family: "Geist Mono", monospace;
    font-size: 12px;
    color: var(--blue);
    text-decoration: none;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.wr-v2 .blog-back:hover { color: var(--blue-700); }

@media (max-width: 960px) {
    .wr-v2 .blog-grid { grid-template-columns: 1fr; }
}

/* Standaard / inbegrepen grid (3 cells per row, responsive) */
.wr-v2 .standaard-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid var(--line);
}
.wr-v2 .standaard-grid > .cell {
    padding: 28px 24px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    min-width: 0;
    overflow-wrap: anywhere;
}
.wr-v2 .standaard-grid > .cell:nth-child(3n) { border-right: none; }
.wr-v2 .standaard-grid > .cell:nth-last-child(-n+3) { border-bottom: none; }

@media (max-width: 720px) {
    .wr-v2 .standaard-grid { grid-template-columns: repeat(2, 1fr); }
    .wr-v2 .standaard-grid > .cell { padding: 22px 18px; }
    .wr-v2 .standaard-grid > .cell:nth-child(3n) { border-right: 1px solid var(--line); }
    .wr-v2 .standaard-grid > .cell:nth-child(2n) { border-right: none; }
    .wr-v2 .standaard-grid > .cell:nth-last-child(-n+3) { border-bottom: 1px solid var(--line); }
    .wr-v2 .standaard-grid > .cell:nth-last-child(-n+2) { border-bottom: none; }
}

/* Investering grid (4 cards with gap, dark variant) */
.wr-v2 .invest-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.wr-v2 .invest-grid .invest-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    padding: 24px;
}
@media (max-width: 960px) {
    .wr-v2 .invest-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .wr-v2 .invest-grid { grid-template-columns: 1fr; }
}

/* Services list (lateren-maken etc.): compacter op phone */
@media (max-width: 720px) {
    .wr-v2 .service { padding: 24px 4px; gap: 16px; }
    .wr-v2 .service h3 { font-size: 17px; line-height: 1.3; padding-top: 0; }
    .wr-v2 .service p { font-size: 13.5px; line-height: 1.55; }
    .wr-v2 .service .idx { padding-top: 4px; font-size: 11px; }
    .wr-v2 .service .tag-row { gap: 6px; }
    .wr-v2 .service .tag { font-size: 9.5px; padding: 3px 8px; }
}

/* Scroll-hint voor horizontaal scrollable spec-tables (alleen zichtbaar op phone) */
.wr-v2 .spec-scroll-hint {
    display: none;
    text-align: center;
    font-family: "Geist Mono", monospace;
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--blue);
    margin-top: 12px;
}

/* Reasons grid (4 cells, responsive) */
.wr-v2 .reasons-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid var(--line);
}
.wr-v2 .reasons-grid .cell {
    padding: 28px 24px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.wr-v2 .reasons-grid .cell:nth-child(4n) { border-right: none; }

@media (max-width: 960px) {
    .wr-v2 .reasons-grid { grid-template-columns: repeat(2, 1fr); }
    .wr-v2 .reasons-grid .cell { border-right: 1px solid var(--line); }
    .wr-v2 .reasons-grid .cell:nth-child(2n) { border-right: none; }
    .wr-v2 .reasons-grid .cell:nth-last-child(-n+2) { border-bottom: none; }
}
@media (max-width: 480px) {
    .wr-v2 .reasons-grid .cell { padding: 22px 18px; }
}

/* TLD price grid (domein registreren page) */
.wr-v2 .tld-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.wr-v2 .tld {
    background: #fff; border: 1px solid var(--line); border-radius: 14px;
    padding: 22px 22px;
    display: flex; flex-direction: column; gap: 4px;
    transition: border-color .2s, transform .2s;
    text-decoration: none; color: inherit;
}
.wr-v2 .tld:hover { border-color: var(--ink); transform: translateY(-2px); }
.wr-v2 .tld .ext { font-family: "Geist Mono", monospace; font-size: 13px; color: var(--muted); letter-spacing: 0.04em; }
.wr-v2 .tld .pr { display: flex; align-items: baseline; gap: 4px; }
.wr-v2 .tld .pr .c { font-size: 16px; color: var(--muted); }
.wr-v2 .tld .pr .n { font-size: 30px; font-weight: 500; letter-spacing: -0.03em; color: var(--ink); line-height: 1.1; }
.wr-v2 .tld .pr .y { font-family: "Geist Mono", monospace; font-size: 11px; color: var(--muted); margin-left: 4px; }
.wr-v2 .tld.feat { background: var(--ink); color: #fff; border-color: var(--ink); }
.wr-v2 .tld.feat .ext { color: rgba(255,255,255,0.65); }
.wr-v2 .tld.feat .pr .n { color: #fff; }
.wr-v2 .tld.feat .pr .c,
.wr-v2 .tld.feat .pr .y { color: rgba(255,255,255,0.55); }

@media (max-width: 960px) {
    .wr-v2 .tld-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Domain search (verhuizen page) - v2 overrides on top of styles.css */
.wr-v2 .search-box-large {
    display: flex;
    align-items: center;
    max-width: 720px;
    margin: 0 auto;
    gap: 8px;
    background: #fff;
    padding: 6px 6px 6px 20px;
    border-radius: 999px;
    border: 1px solid var(--line);
    box-shadow: 0 1px 0 rgba(11,14,26,0.04), 0 24px 48px -24px rgba(11,14,26,0.18);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.wr-v2 .search-box-large::before {
    content: "";
    width: 18px; height: 18px;
    flex-shrink: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%236A6E7E' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: 0.7;
    transition: opacity .15s ease;
}
.wr-v2 .search-box-large:hover { border-color: var(--ink); }
.wr-v2 .search-box-large:focus-within {
    border-color: var(--blue);
    box-shadow: 0 1px 0 rgba(11,14,26,0.04), 0 24px 48px -24px rgba(11,14,26,0.18), 0 0 0 4px rgba(27,79,224,0.1);
}
.wr-v2 .search-box-large:focus-within::before { opacity: 1; }
.wr-v2 .search-box-large input {
    flex: 1;
    min-width: 0;
    border: 0;
    background: transparent;
    padding: 14px 4px;
    font-family: "Geist", ui-sans-serif, system-ui, sans-serif;
    font-size: 15px;
    color: var(--ink);
    outline: none;
}
.wr-v2 .search-box-large input::placeholder { color: var(--muted); }
.wr-v2 .search-box-large .btn {
    padding: 12px 24px;
    font-size: 14.5px;
    flex-shrink: 0;
}

.wr-v2 .domain-results {
    max-width: 720px;
    margin: 16px auto 0;
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 1px 0 rgba(11,14,26,0.04), 0 24px 48px -24px rgba(11,14,26,0.12);
}
.wr-v2 .domain-result-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 22px;
    border-bottom: 1px solid var(--line);
    gap: 16px;
}
.wr-v2 .domain-result-row:last-child { border-bottom: none; }
.wr-v2 .domain-result-name {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 14px; font-weight: 500;
    color: var(--ink); letter-spacing: -0.01em;
}
.wr-v2 .domain-result-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.wr-v2 .domain-result-badge {
    font-family: "Geist Mono", monospace;
    font-size: 10.5px; font-weight: 500;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 5px 10px; border-radius: 999px;
    white-space: nowrap;
}
.wr-v2 .badge-avail { background: #E8F6EF; color: #178a5d; }
.wr-v2 .badge-taken { background: #FCE9E9; color: #b8322f; }
.wr-v2 .domain-results-loading {
    padding: 22px 24px;
    color: var(--muted);
    font-family: "Geist Mono", monospace;
    font-size: 12px; letter-spacing: 0.04em;
    display: flex; align-items: center; gap: 12px;
}
.wr-v2 .domain-results-spinner {
    width: 14px; height: 14px;
    border: 2px solid var(--line);
    border-top-color: var(--blue);
    border-radius: 50%;
    animation: wr-v2-spin 0.7s linear infinite;
    flex-shrink: 0;
}
@keyframes wr-v2-spin { to { transform: rotate(360deg); } }
.wr-v2 .domain-results-empty {
    padding: 22px 24px;
    color: var(--muted);
    font-family: "Geist Mono", monospace;
    font-size: 12px; letter-spacing: 0.04em;
}

/* Stack mock (about/over-ons page) */
.wr-v2 .stack-mock {
    position: relative;
    border-radius: 18px; overflow: hidden;
    border: 1px solid var(--line);
    background: #fff;
    box-shadow: 0 24px 60px -32px rgba(11,14,26,0.2);
}
.wr-v2 .stack-mock .sk-bar {
    display: flex; align-items: center; gap: 6px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--line);
    background: #fbfaf6;
}
.wr-v2 .stack-mock .sk-bar .d { width: 9px; height: 9px; border-radius: 50%; background: #E2DDCB; }
.wr-v2 .stack-mock .sk-bar .url {
    margin-left: 10px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 12px; color: var(--muted);
    background: #fff; border: 1px solid var(--line); border-radius: 6px;
    padding: 4px 12px;
}
.wr-v2 .stack-mock .sk-body {
    padding: 20px;
    display: flex; flex-direction: column;
    gap: 8px;
    background: linear-gradient(180deg, #fff 0%, #fbfaf6 100%);
}
.wr-v2 .stack-mock .layer {
    display: grid;
    grid-template-columns: 36px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    position: relative;
    transition: border-color .15s, transform .15s;
}
.wr-v2 .stack-mock .layer:hover { border-color: var(--blue); transform: translateX(2px); }
.wr-v2 .stack-mock .layer .ln {
    font-family: "Geist Mono", monospace;
    font-size: 11px;
    color: var(--blue);
    letter-spacing: 0.08em;
    font-weight: 500;
}
.wr-v2 .stack-mock .layer .info {
    display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.wr-v2 .stack-mock .layer .name {
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    line-height: 1.2;
}
.wr-v2 .stack-mock .layer .tech {
    font-family: "Geist Mono", monospace;
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.02em;
}
.wr-v2 .stack-mock .layer .status {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    background: #E8F6EF;
    color: #178a5d;
    font-family: "Geist Mono", monospace;
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}
.wr-v2 .stack-mock .layer .status::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
}

/* Responsive */
@media (max-width: 960px) {
    .wr-v2 .hero-grid,
    .wr-v2 .section-head,
    .wr-v2 .builder-block,
    .wr-v2 .speed-block,
    .wr-v2 .mig-card,
    .wr-v2 .infra { grid-template-columns: 1fr; gap: 32px; }
    .wr-v2 .metrics { grid-template-columns: repeat(2, 1fr); }
    .wr-v2 .metric:nth-child(2) { border-right: none; }
    .wr-v2 .metric:nth-child(odd) { border-right: 1px solid var(--line); }
    .wr-v2 .metric { border-bottom: 1px solid var(--line); }
    .wr-v2 .metric:nth-last-child(-n+2) { border-bottom: none; }
    .wr-v2 .service { grid-template-columns: 36px 1fr; }
    .wr-v2 .service .tag-row, .wr-v2 .service p { grid-column: 2; }
    .wr-v2 .process-grid,
    .wr-v2 .hosting-grid,
    .wr-v2 .tier-grid { grid-template-columns: 1fr; }
    .wr-v2 .v2-section { padding: 64px 0; }
    .wr-v2 .mig-card { padding: 32px; }
    .wr-v2 .spec-table { font-size: 13px; display: block; overflow-x: auto; }
    .wr-v2 .infra { grid-template-columns: 1fr; }
    .wr-v2 .perf-row { grid-template-columns: 110px 1fr 60px; }
    .wr-v2 .values,
    .wr-v2 .team-grid { grid-template-columns: 1fr; }
    .wr-v2 .contact-grid,
    .wr-v2 .addr-card { grid-template-columns: 1fr; }
    .wr-v2 .palette { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
    .wr-v2 .feat-grid,
    .wr-v2 .feat-grid.size-9 { grid-template-columns: repeat(2, 1fr); }
    /* Reset: alle cells krijgen right+bottom border op 2-col layout */
    .wr-v2 .feat-grid .feat-item {
        border-right: 1px solid var(--line);
        border-bottom: 1px solid var(--line);
        min-width: 0;
        overflow-wrap: anywhere;
    }
    /* Rechter kolom: geen border-right */
    .wr-v2 .feat-grid .feat-item:nth-child(2n) { border-right: none; }
    /* Laatste cell: geen border-bottom */
    .wr-v2 .feat-grid .feat-item:last-child { border-bottom: none; }
    /* Bij even aantal (size-6, size-8): ook tweede-laatste geen border-bottom */
    .wr-v2 .feat-grid:not(.size-9) .feat-item:nth-last-child(2) { border-bottom: none; }
    /* Dark variant borders */
    .wr-v2 .dark .feat-grid .feat-item { border-color: rgba(255,255,255,0.1); }
    .wr-v2 .builder-hero .bm-canvas {
        grid-template-columns: 48px 1fr;
        grid-template-rows: auto auto;
        height: auto;
    }
    .wr-v2 .builder-hero .bm-tools { grid-row: 1; grid-column: 1; padding: 10px 6px; }
    .wr-v2 .builder-hero .bm-stage { grid-row: 1; grid-column: 2; padding: 16px; min-height: 280px; }
    .wr-v2 .builder-hero .bm-side {
        display: block;
        grid-row: 2;
        grid-column: 1 / -1;
        border-left: 0;
        border-top: 1px solid var(--line);
        padding: 16px;
    }
    .wr-v2 .builder-hero .bm-tool { width: 28px; height: 28px; }
    .wr-v2 .rail { grid-template-columns: 1fr; }
    .wr-v2 .rail .r-step { border-right: 0; border-bottom: 1px solid var(--line); padding: 24px 0; }
    .wr-v2 .rail .r-step:last-child { border-bottom: 0; }
    .wr-v2 .work-grid { grid-template-columns: 1fr; }
    .wr-v2 .form-card { padding: 24px; }
    .wr-v2 .form-card .row2 { grid-template-columns: 1fr; }
}

/* === Phone-size fixes (≤ 720px) === */
@media (max-width: 720px) {
    /* Globale fix voor alle inline-style 4/3-koloms grids: zet ze op 2 kolommen */
    .wr-v2 [style*="grid-template-columns: repeat(4, 1fr)"],
    .wr-v2 [style*="grid-template-columns:repeat(4, 1fr)"],
    .wr-v2 [style*="grid-template-columns: repeat(3, 1fr)"],
    .wr-v2 [style*="grid-template-columns:repeat(3, 1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    /* Voorkom dat lange content de grid-cell wijder maakt dan z'n track */
    .wr-v2 [style*="grid-template-columns: repeat(4, 1fr)"] > *,
    .wr-v2 [style*="grid-template-columns:repeat(4, 1fr)"] > *,
    .wr-v2 [style*="grid-template-columns: repeat(3, 1fr)"] > *,
    .wr-v2 [style*="grid-template-columns:repeat(3, 1fr)"] > * {
        min-width: 0;
        overflow-wrap: anywhere;
    }
    /* Borders alleen tussen cells op 2-koloms layout: rechter kolom geen border-right,
       laatste rij geen border-bottom. Werkt voor even aantal cells (4/6/8). */
    .wr-v2 [style*="grid-template-columns: repeat(4, 1fr)"] > *:nth-child(2n),
    .wr-v2 [style*="grid-template-columns:repeat(4, 1fr)"] > *:nth-child(2n),
    .wr-v2 [style*="grid-template-columns: repeat(3, 1fr)"] > *:nth-child(2n),
    .wr-v2 [style*="grid-template-columns:repeat(3, 1fr)"] > *:nth-child(2n) {
        border-right: none !important;
    }
    .wr-v2 [style*="grid-template-columns: repeat(4, 1fr)"] > *:nth-last-child(-n+2),
    .wr-v2 [style*="grid-template-columns:repeat(4, 1fr)"] > *:nth-last-child(-n+2),
    .wr-v2 [style*="grid-template-columns: repeat(3, 1fr)"] > *:nth-last-child(-n+2),
    .wr-v2 [style*="grid-template-columns:repeat(3, 1fr)"] > *:nth-last-child(-n+2) {
        border-bottom: none !important;
    }
    /* Stack-rij met label + value: smaller label column op phone */
    .wr-v2 [style*="grid-template-columns: 140px 1fr"],
    .wr-v2 [style*="grid-template-columns:140px 1fr"] {
        grid-template-columns: 80px 1fr !important;
        gap: 10px !important;
        padding: 12px 14px !important;
    }

    /* Metrics: voorkom overflow door lange woorden, kleinere font */
    .wr-v2 .metric {
        padding: 20px 16px;
        min-width: 0;
    }
    .wr-v2 .metric .num {
        font-size: 26px;
        line-height: 1.1;
        overflow-wrap: anywhere;
        word-break: break-word;
    }
    .wr-v2 .metric .num .small { font-size: 14px; }
    .wr-v2 .metric .lbl { font-size: 10px; }

    /* Service h3 met inline tag (Site Builder · In ontwikkeling) */
    .wr-v2 .service h3 .tag {
        white-space: nowrap;
        display: inline-block;
        vertical-align: middle;
    }

    /* Hosting card "Populair" badge naar boven van de card */
    .wr-v2 .h-card .badge {
        position: static;
        top: auto; right: auto; left: auto;
        align-self: flex-start;
        margin-bottom: 0;
    }

    /* Dashboard mock: telefoon-stijl met inklapbare sidebar */
    .wr-v2 .dash-body {
        grid-template-columns: 1fr;
        min-height: 0;
    }
    .wr-v2 .dash-side {
        display: flex;
        flex-direction: row;
        overflow-x: auto;
        border-right: none;
        border-bottom: 1px solid var(--line);
        padding: 12px 12px;
        gap: 4px;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }
    .wr-v2 .dash-side::-webkit-scrollbar { display: none; }
    .wr-v2 .dash-item {
        white-space: nowrap;
        flex-shrink: 0;
        padding: 6px 10px;
        font-size: 12px;
    }
    .wr-v2 .dash-main { padding: 18px; gap: 14px; min-width: 0; }
    .wr-v2 .dash-stats { grid-template-columns: 1fr 1fr; gap: 8px; min-width: 0; }
    .wr-v2 .dash-stat { padding: 12px 14px; min-width: 0; overflow-wrap: anywhere; }
    .wr-v2 .dash-stat .val { font-size: 18px; }
    .wr-v2 .dash-stat .lbl { font-size: 9.5px; }
    .wr-v2 .dash-stat .delta { font-size: 10px; }
    .wr-v2 .dash-row {
        grid-template-columns: 1.4fr 70px 70px;
        gap: 6px;
        padding: 10px 14px;
        font-size: 12px;
    }
    .wr-v2 .dash-row > span {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .wr-v2 .dash-row > span:nth-child(2) { display: none; }
    .wr-v2 .dash-row.head > span:nth-child(2) { display: none; }
    .wr-v2 .dash-bar { padding: 10px 14px; }
    .wr-v2 .dash-bar .url { font-size: 11px; padding: 3px 8px; }
    .wr-v2 .dash-bar > span:last-child { display: none; }

    /* Builder mock: Inspector-paneel verplaatst naar onder de canvas */
    .wr-v2 .builder-mock { aspect-ratio: auto; height: auto; }
    .wr-v2 .builder-mock .bm-canvas {
        grid-template-columns: 48px 1fr;
        grid-template-rows: auto auto;
        height: auto;
    }
    .wr-v2 .builder-mock .bm-tools { grid-row: 1; grid-column: 1; padding: 10px 6px; }
    .wr-v2 .builder-mock .bm-stage { grid-row: 1; grid-column: 2; padding: 16px; }
    .wr-v2 .builder-mock .bm-side {
        display: block;
        grid-row: 2;
        grid-column: 1 / -1;
        border-left: 0;
        border-top: 1px solid var(--line);
        padding: 16px;
    }
    .wr-v2 .builder-mock .bm-tool { width: 28px; height: 28px; }
    .wr-v2 .builder-mock .bm-block.img { height: 70px; }

    /* Snelheidstest gauge: balans tussen label, arc en score */
    .wr-v2 .gauge { aspect-ratio: 1.5; }
    .wr-v2 .gauge .score { font-size: 42px; bottom: 10%; }
    .wr-v2 .gauge .score sub { font-size: 14px; }
    .wr-v2 .gauge .lbl { font-size: 9px; top: 12px; }

    /* Speed-meta op phone in 1 kolom */
    .wr-v2 .speed-meta { grid-template-columns: 1fr; gap: 10px; }

    /* Domein zoek-balk: stack op phone */
    .wr-v2 .search-box-large {
        flex-direction: column;
        align-items: stretch;
        border-radius: 18px;
        padding: 12px;
        gap: 10px;
    }
    .wr-v2 .search-box-large::before { display: none; }
    .wr-v2 .search-box-large input {
        padding: 12px 14px;
        background: var(--bg);
        border: 1px solid var(--line);
        border-radius: 10px;
        font-size: 15px;
    }
    .wr-v2 .search-box-large input:focus {
        border-color: var(--ink);
        background: #fff;
    }
    .wr-v2 .search-box-large .btn {
        width: 100%;
        justify-content: center;
        padding: 12px;
    }

    /* TLD tiles: voorkom overflow op phone */
    .wr-v2 .tld { padding: 18px 16px; min-width: 0; }
    .wr-v2 .tld .pr { flex-wrap: wrap; row-gap: 0; }
    .wr-v2 .tld .pr .n { font-size: 24px; }
    .wr-v2 .tld .ext { font-size: 12px; }

    /* Interval picker: compacter zodat het past op phone */
    .wr-v2 .interval-picker {
        display: flex;
        flex-wrap: wrap;
        max-width: 100%;
    }
    .wr-v2 .interval-btn {
        padding: 8px 12px;
        font-size: 12px;
        flex: 1 1 auto;
    }
    .wr-v2 .interval-discount { font-size: 9px; padding: 1px 5px; }

    /* Tier cards: kleinere prijs en wrap zodat oude prijs/discount niet uit kaart loopt */
    .wr-v2 .tier { padding: 24px; }
    .wr-v2 .tier h3 { font-size: 22px; }
    .wr-v2 .price { flex-wrap: wrap; row-gap: 4px; }
    .wr-v2 .price .num { font-size: 44px; }
    .wr-v2 .price .cur { font-size: 16px; }
    .wr-v2 .price-original { font-size: 14px; }
    .wr-v2 .price-discount { font-size: 10px; padding: 2px 6px; }

    /* Spec-table: scroll-hint en zichtbare scrollbar */
    .wr-v2 .spec-table {
        scrollbar-color: var(--blue) var(--bg-2);
        position: relative;
    }
    .wr-v2 .spec-table::-webkit-scrollbar { height: 6px; }
    .wr-v2 .spec-table::-webkit-scrollbar-thumb { background: var(--blue); border-radius: 999px; }
    .wr-v2 .spec-table::-webkit-scrollbar-track { background: var(--bg-2); }
    .wr-v2 .spec-scroll-hint { display: block; }

    /* Component library palette: kleiner zodat tiles passen */
    .wr-v2 .palette { padding: 24px; }
    .wr-v2 .palette-grid { gap: 6px; }
    .wr-v2 .palette-tile { padding: 8px; min-width: 0; }
    .wr-v2 .palette-tile .preview { margin-bottom: 4px; }
    .wr-v2 .palette-tile .preview svg { width: 22px; height: auto; }
    .wr-v2 .palette-tile div:last-child { font-size: 9.5px; letter-spacing: 0.04em; }
}

/* ============================================================
   AUTH PAGES (login / register / reset)
   ============================================================ */

.wr-v2 .auth-wrap {
    max-width: 480px;
    margin: 0 auto;
}
.wr-v2 .auth-wrap-wide { max-width: 720px; }

.wr-v2 .auth-foot {
    margin-top: 8px;
    padding-top: 16px;
    border-top: 1px solid var(--line);
    text-align: center;
    font-size: 14px;
    color: var(--muted);
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}
.wr-v2 .auth-foot .sep { color: var(--line); }
.wr-v2 .auth-foot a {
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
.wr-v2 .auth-foot a:hover { color: var(--blue-700); text-decoration: underline; }

/* ============================================================
   ADMIN INTERFACE (v2)
   ============================================================ */

.admin-topbar .admin-brand-tag {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--v2-blue, #1B4FE0);
    color: #fff;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-left: 10px;
    line-height: 1;
}

.wr-v2.admin-shell { min-height: calc(100vh - 200px); padding-bottom: 96px; }

/* Admin hero */
.wr-v2 .admin-hero { padding: 56px 0 32px; }
.wr-v2 .admin-hero .crumbs {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 20px;
}
.wr-v2 .admin-hero .crumbs a { color: var(--muted); }
.wr-v2 .admin-hero .crumbs a:hover { color: var(--ink); }
.wr-v2 .admin-hero .crumbs .sep { margin: 0 10px; color: var(--line); }
.wr-v2 .admin-hero .crumbs .current { color: var(--ink); }
.wr-v2 .admin-hero h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: 12px; }
.wr-v2 .admin-hero .lead { font-size: 17px; margin-bottom: 24px; }
.wr-v2 .admin-hero .hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 24px;
}

/* Admin card / panel */
.wr-v2 .admin-section { padding: 24px 0 64px; }
.wr-v2 .admin-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px;
}
.wr-v2 .admin-card + .admin-card { margin-top: 24px; }
.wr-v2 .admin-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.wr-v2 .admin-card-header h2 { font-size: 22px; margin: 0; }
.wr-v2 .admin-card-header .eyebrow { margin-bottom: 6px; }

/* Admin table */
.wr-v2 .admin-table-wrap {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
}
.wr-v2 .admin-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}
.wr-v2 .admin-table thead th {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
    font-weight: 500;
    padding: 16px 20px;
    background: var(--bg-2);
    border-bottom: 1px solid var(--line);
}
.wr-v2 .admin-table tbody td {
    padding: 16px 20px;
    border-bottom: 1px solid var(--line);
    color: var(--ink-2);
    font-size: 15px;
    vertical-align: middle;
}
.wr-v2 .admin-table tbody tr:last-child td { border-bottom: none; }
.wr-v2 .admin-table tbody tr:hover td { background: rgba(27,79,224,0.03); }
.wr-v2 .admin-table .title-cell strong { color: var(--ink); font-weight: 500; }
.wr-v2 .admin-table .text-right { text-align: right; }
.wr-v2 .admin-table code {
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 12px;
    color: var(--blue);
    background: rgba(27,79,224,0.06);
    padding: 2px 8px;
    border-radius: 6px;
}

/* Inline action chips inside tables */
.wr-v2 .admin-actions { display: inline-flex; gap: 8px; justify-content: flex-end; }
.wr-v2 .admin-actions form { display: inline; margin: 0; }
.wr-v2 .action-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-2);
    background: transparent;
    border: 1px solid var(--line);
    cursor: pointer;
    text-decoration: none;
    transition: border-color .15s, color .15s, background .15s;
    line-height: 1;
}
.wr-v2 .action-chip:hover { border-color: var(--ink); color: var(--ink); }
.wr-v2 .action-chip.danger { color: #b42318; border-color: rgba(180,35,24,0.25); }
.wr-v2 .action-chip.danger:hover { background: rgba(180,35,24,0.06); border-color: #b42318; }
.wr-v2 .action-chip.primary { background: var(--blue); color: #fff; border-color: var(--blue); }
.wr-v2 .action-chip.primary:hover { background: var(--blue-700); border-color: var(--blue-700); color: #fff; }

/* Admin empty state */
.wr-v2 .admin-empty {
    padding: 48px 20px;
    text-align: center;
    color: var(--muted);
    font-size: 15px;
}

/* Admin dashboard tiles */
.wr-v2 .admin-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.wr-v2 .admin-tile {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 28px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    color: inherit;
    text-decoration: none;
    transition: border-color .2s, transform .2s;
}
.wr-v2 .admin-tile:hover { border-color: var(--ink); transform: translateY(-2px); }
.wr-v2 .admin-tile .tile-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: var(--blue-50);
    color: var(--blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wr-v2 .admin-tile h3 { font-size: 20px; }
.wr-v2 .admin-tile p { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }
.wr-v2 .admin-tile .tile-foot {
    margin-top: auto;
    padding-top: 8px;
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Reusable form layout (standalone, like form-card but for editors) */
.wr-v2 .editor-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 24px;
    align-items: start;
}
.wr-v2 .editor-side {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: 88px;
}
.wr-v2 .editor-side-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 20px;
}
.wr-v2 .editor-side-card h4 {
    font-size: 13px;
    font-family: "Geist Mono", ui-monospace, monospace;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-bottom: 12px;
    font-weight: 500;
}
.wr-v2 .editor-side-card p { font-size: 14px; color: var(--ink-2); line-height: 1.55; }

/* Footer */
.admin-footer {
    border-top: 1px solid var(--v2-line, #DCD9CF);
    background: var(--v2-bg, #F7F6F2);
    padding: 24px 0;
}
.admin-footer .container {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 28px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--v2-muted, #6A6E7E);
    font-family: "Geist Mono", ui-monospace, monospace;
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.admin-footer .dim { opacity: 0.7; }

/* Responsive */
@media (max-width: 980px) {
    .wr-v2 .admin-tiles { grid-template-columns: 1fr; }
    .wr-v2 .editor-grid { grid-template-columns: 1fr; }
    .wr-v2 .editor-side { position: static; }
    .wr-v2 .admin-table thead { display: none; }
    .wr-v2 .admin-table tbody td { display: block; padding: 10px 16px; border-bottom: none; }
    .wr-v2 .admin-table tbody tr {
        display: block;
        border-bottom: 1px solid var(--line);
        padding: 12px 0;
    }
    .wr-v2 .admin-table .text-right { text-align: left; }
}
