/* ============================================================
   Prepaid-Host — brand homepage system (blue/navy + Inter)
   Built on the /ui design guidelines. Brand colors only.
   Scoped under .phb so the navbar/footer stay untouched.
   ============================================================ */
.phb {
    --phb-primary: #009cff;
    --phb-primary-d: #006ec8;
    --phb-primary-lt: rgba(0, 156, 255, 0.08);
    --phb-navy: #0f1c2b;
    --phb-ink: #1e293b;
    --phb-text: #334155;
    --phb-muted: #64748b;
    --phb-border: rgba(15, 23, 42, 0.10);
    --phb-border-2: rgba(15, 23, 42, 0.06);
    --phb-bg: #f7f9fb;
    --phb-amber: #f59e0b;
    --phb-radius: 16px;
    --phb-radius-sm: 10px;
    --phb-font-mono: ui-monospace, "SFMono-Regular", Menlo, "Cascadia Mono", "Liberation Mono", monospace;

    font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
    font-feature-settings: "cv02", "cv03", "cv04", "cv11", "ss01";
    -webkit-font-smoothing: antialiased;
    color: var(--phb-text);
}
.phb *, .phb *::before, .phb *::after { box-sizing: border-box; }
.phb img { max-width: 100%; }

/* ── Section shell (outer padding + inner max-width) ── */
.phb-sec { padding: clamp(3.5rem, 8vh, 6rem) 0; background: #fff; }
.phb-sec--tint { background: var(--phb-bg); }
.phb-inner { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

/* ── Heading group (no mono eyebrow) ── */
.phb-head { margin-bottom: 2.75rem; }
.phb-head--center { text-align: center; }
.phb-head--center .phb-lead { margin-left: auto; margin-right: auto; }
.phb-eyebrow { color: var(--phb-primary-d); font-weight: 600; font-size: 0.95rem; margin: 0 0 0.7rem; }
.phb-h2 { color: var(--phb-navy); font-weight: 600; font-size: clamp(1.9rem, 3vw, 2.55rem); letter-spacing: -0.02em; line-height: 1.08; margin: 0; max-width: 24ch; text-wrap: balance; }
.phb-head--center .phb-h2 { max-width: none; }
.phb-lead { color: var(--phb-muted); font-size: 1.075rem; line-height: 1.6; margin: 0.9rem 0 0; max-width: 58ch; text-wrap: pretty; }
.phb-sec__action { margin-top: 2rem; }

/* ── Grids ── */
.phb-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.phb-grid--3 { grid-template-columns: repeat(3, 1fr); }
.phb-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 1000px) { .phb-grid, .phb-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .phb-grid, .phb-grid--3, .phb-grid--2 { grid-template-columns: 1fr; } }
/* Centered card grid — an incomplete last row is centered instead of left-aligned with an orphan gap (use when the card count is not a multiple of the column count). */
.phb-grid--center { display: flex; flex-wrap: wrap; justify-content: center; }
.phb-grid--center > * { flex: 0 1 calc((100% - 2 * 1.5rem) / 3); }
@media (max-width: 1000px) { .phb-grid--center > * { flex-basis: calc((100% - 1.5rem) / 2); } }
@media (max-width: 600px) { .phb-grid--center > * { flex-basis: 100%; } }

/* ── Card ── */
.phb-card { position: relative; display: flex; flex-direction: column; justify-content: space-between; background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius); padding: 1.6rem; transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease; text-decoration: none; color: inherit; }
a.phb-card:hover, .phb-card--hover:hover { border-color: color-mix(in srgb, var(--phb-primary) 50%, var(--phb-border)); box-shadow: 0 16px 36px -24px rgba(15, 28, 43, 0.4); transform: translateY(-2px); }
.phb-card--popular { border-color: var(--phb-primary); box-shadow: 0 0 0 1px var(--phb-primary); }
.phb-flag { position: absolute; top: 1.05rem; right: 1.05rem; background: var(--phb-primary); color: #fff; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.01em; padding: 0.25rem 0.62rem; border-radius: 50px; }

.phb-icon { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: 12px; background: var(--phb-primary-lt); color: var(--phb-primary); font-size: 1.2rem; margin-bottom: 1.1rem; }
.phb-name { color: var(--phb-navy); font-weight: 600; font-size: 1.2rem; margin: 0 0 0.4rem; }
.phb-desc { color: var(--phb-muted); font-size: 0.95rem; line-height: 1.55; margin: 0 0 1.1rem; }
.phb-card--product .phb-desc { min-height: 4.3em; }

.phb-price { display: flex; align-items: baseline; gap: 0.3rem; margin: 0; font-feature-settings: "tnum"; }
.phb-price__from { color: var(--phb-muted); font-size: 0.82rem; }
.phb-price__num { color: var(--phb-navy); font-weight: 700; font-size: 1.75rem; letter-spacing: -0.02em; }
.phb-price__per { color: var(--phb-muted); font-size: 0.85rem; }

.phb-feat { list-style: none; margin: 1.25rem 0 1.6rem; padding: 1.2rem 0 0; border-top: 1px solid var(--phb-border); display: grid; gap: 0.6rem; }
.phb-feat li { display: grid; grid-template-columns: auto 1fr; gap: 0.6rem; align-items: start; font-size: 0.9rem; color: var(--phb-text); }
.phb-feat i { color: var(--phb-primary); font-size: 0.8rem; line-height: 1.55; }

/* ── Buttons ── */
.phb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.82rem 1.4rem; border-radius: var(--phb-radius-sm); font-weight: 600; font-size: 0.97rem; line-height: 1.2; white-space: nowrap; text-decoration: none; border: 1px solid transparent; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease; }
.phb-btn--block { width: 100%; }
.phb-btn--primary { background: var(--phb-primary); color: #fff; }
.phb-btn--primary:hover { background: var(--phb-primary-d); color: #fff; }
.phb-btn--secondary { background: #fff; color: var(--phb-navy); border-color: var(--phb-border); }
.phb-btn--secondary:hover { border-color: var(--phb-primary); color: var(--phb-primary-d); }
.phb-btn--ghost { background: transparent; color: var(--phb-navy); padding-left: 0.3rem; padding-right: 0.3rem; }
.phb-btn--ghost:hover { color: var(--phb-primary-d); }
.phb-btn--light { background: #fff; color: var(--phb-navy); }
.phb-btn--light:hover { background: #eef6ff; color: var(--phb-primary-d); }
.phb-btn--onnavy { background: transparent; color: #fff; border-color: rgba(255, 255, 255, 0.28); }
.phb-btn--onnavy:hover { background: rgba(255, 255, 255, 0.1); border-color: #fff; color: #fff; }

/* ── Reassurance line ── */
.phb-reassure { display: flex; flex-wrap: wrap; align-items: center; gap: 0.45rem 1.1rem; margin: 1.4rem 0 0; color: var(--phb-muted); font-size: 0.92rem; }
.phb-reassure span { display: inline-flex; align-items: center; gap: 0.45rem; }
.phb-reassure i { color: var(--phb-primary); font-size: 0.82rem; }

/* ── Hero ── */
.phb-hero { position: relative; background: linear-gradient(180deg, #fff 0%, var(--phb-bg) 100%); border-bottom: 1px solid var(--phb-border-2); }
.phb-hero::before { content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 1; background-image: radial-gradient(rgba(15, 28, 43, 0.08) 1px, transparent 1.6px); background-size: 24px 24px; mask-image: linear-gradient(180deg, rgba(0,0,0,.6), transparent 72%); -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,.6), transparent 72%); }
.phb-hero > .phb-inner { position: relative; z-index: 2; }
.phb-hero__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; padding: clamp(3rem, 7vh, 5rem) 0; }
.phb-h1 { color: var(--phb-navy); font-weight: 600; font-size: clamp(2.4rem, 4.6vw, 3.6rem); letter-spacing: -0.028em; line-height: 1.03; margin: 1rem 0 1rem; text-wrap: balance; }
.phb-h1 b { color: var(--phb-primary-d); font-weight: 600; }
.phb-hero__lead { color: var(--phb-muted); font-size: clamp(1.05rem, 1.4vw, 1.2rem); line-height: 1.6; margin: 0 0 1.9rem; max-width: 46ch; }
.phb-hero__actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.phb-hero__trust { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 0.9rem; color: var(--phb-muted); font-size: 0.9rem; font-weight: 500; text-decoration: none; transition: color .15s; }
.phb-hero__trust:hover { color: var(--phb-navy); }
.phb-hero__trust .phb-stars { color: var(--phb-amber); font-size: 0.85rem; }
.phb-promo { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--phb-primary-lt); color: var(--phb-primary-d); border: 1px solid color-mix(in srgb, var(--phb-primary) 22%, transparent); font-weight: 600; font-size: 0.85rem; padding: 0.4rem 0.85rem; border-radius: 50px; text-decoration: none; }

/* ── Hero photo (real hardware, passive ambient layer behind the grid texture) ── */
.phb-hero__photo { position: absolute; top: 0; right: 0; bottom: 0; width: 52%; overflow: hidden; pointer-events: none; z-index: 0; }
.phb-hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center right; opacity: 0.38; filter: saturate(0.7); -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 30%, transparent 92%); mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 30%, transparent 92%); }
.phb-hero__photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, var(--phb-bg) 4%, rgba(247, 249, 251, 0) 55%); }
@media (max-width: 900px) { .phb-hero__photo { display: none; } }

/* ── Domain check ── */
.phb-domaincheck { display: flex; gap: 0.8rem; max-width: 640px; }
.phb-domaincheck input { flex: 1; min-width: 0; padding: 0.82rem 1.1rem; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); font-family: var(--phb-font-mono); font-size: 0.95rem; color: var(--phb-navy); background: #fff; }
.phb-domaincheck input:focus { outline: none; border-color: var(--phb-primary); box-shadow: 0 0 0 3px var(--phb-primary-lt); }
@media (max-width: 600px) { .phb-domaincheck { flex-direction: column; } }
.phb-tldchips { display: flex; flex-wrap: wrap; gap: 0.7rem; margin: 1.3rem 0 0; }
.phb-tldchip { display: inline-flex; align-items: baseline; gap: 0.5rem; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); padding: 0.5rem 0.9rem; background: #fff; font-family: var(--phb-font-mono); font-size: 0.86rem; color: var(--phb-navy); }
.phb-tldchip small { color: var(--phb-muted); font-family: "Inter", system-ui, sans-serif; }

/* ── Trust tiles ── */
.phb-tiles { margin-bottom: 2.25rem; }
.phb-tile { border: 1px solid var(--phb-border); border-radius: var(--phb-radius); background: #fff; padding: 1.4rem 1.5rem; }
.phb-tile__k { font-family: var(--phb-font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--phb-muted); margin: 0 0 0.55rem; }
.phb-tile__v { color: var(--phb-navy); font-weight: 600; font-size: 1.12rem; letter-spacing: -0.01em; margin: 0 0 0.3rem; }
.phb-tile__v .phb-stars { font-size: 0.8rem; vertical-align: 1px; }
.phb-tile__d { color: var(--phb-muted); font-size: 0.88rem; line-height: 1.5; margin: 0; }

@media (max-width: 900px) {
    .phb-hero__grid { grid-template-columns: 1fr; gap: 2.2rem; }
}

/* ── Split (text + visual) ── */
.phb-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.phb-split--rev .phb-split__text { order: 2; }
.phb-split__visual img { width: 100%; height: auto; border-radius: var(--phb-radius); border: 1px solid var(--phb-border); display: block; }
.phb-split__cap { margin: 0.7rem 0 0; font-family: var(--phb-font-mono); font-size: 0.78rem; letter-spacing: 0.01em; color: var(--phb-muted); }
@media (max-width: 860px) { .phb-split { grid-template-columns: 1fr; } .phb-split--rev .phb-split__text { order: 0; } }

/* ── Spec list (key / value) ── */
.phb-spec { margin: 1.6rem 0 0; display: grid; gap: 0; }
.phb-spec > div { display: flex; justify-content: space-between; gap: 1rem; padding: 0.85rem 0; border-top: 1px solid var(--phb-border); }
.phb-spec > div:last-child { border-bottom: 1px solid var(--phb-border); }
.phb-spec dt, .phb-spec__k { color: var(--phb-muted); font-size: 0.92rem; }
.phb-spec dd, .phb-spec__v { color: var(--phb-navy); font-family: var(--phb-font-mono); font-weight: 600; font-size: 0.88rem; margin: 0; text-align: right; }

/* ── Reviews ── */
.phb-stars { display: inline-flex; gap: 0.15rem; color: var(--phb-amber); font-size: 0.9rem; }
.phb-review__text { color: var(--phb-text); font-size: 0.98rem; line-height: 1.6; margin: 0.9rem 0 1.2rem; }
.phb-review__author { display: flex; align-items: center; gap: 0.7rem; }
.phb-review__avatar { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; background: var(--phb-primary-lt); color: var(--phb-primary-d); font-weight: 700; font-size: 0.9rem; }
.phb-review__name { color: var(--phb-navy); font-weight: 600; font-size: 0.92rem; }
.phb-review__date { color: var(--phb-muted); font-size: 0.82rem; }
.phb-trustlink { display: inline-flex; align-items: center; gap: 0.55rem; margin-top: 2rem; color: var(--phb-navy); font-weight: 600; text-decoration: none; }
.phb-trustlink .phb-stars { color: var(--phb-amber); }
.phb-trustlink:hover { color: var(--phb-primary-d); }

/* ── FAQ ── */
.phb-faq { max-width: 820px; margin: 0; display: grid; gap: 0.75rem; }
.phb-faq__item { border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); background: #fff; overflow: hidden; }
.phb-faq__item[open] { border-color: color-mix(in srgb, var(--phb-primary) 35%, var(--phb-border)); }
.phb-faq__q { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.05rem 1.25rem; font-weight: 600; color: var(--phb-navy); cursor: pointer; list-style: none; font-size: 1rem; }
.phb-faq__q::-webkit-details-marker { display: none; }
.phb-faq__q i { color: var(--phb-primary); transition: transform 0.2s ease; flex-shrink: 0; }
.phb-faq__item[open] .phb-faq__q i { transform: rotate(180deg); }
.phb-faq__a { padding: 0 1.25rem 1.25rem; color: var(--phb-muted); font-size: 0.96rem; line-height: 1.6; }
.phb-faq__item--more { display: none; }
.phb-faq.is-expanded .phb-faq__item--more { display: block; }
.phb-faq__morewrap { display: flex; justify-content: center; margin-top: 1.4rem; }

/* ── Final CTA (navy band — the one dark moment) ── */
.phb-cta { background: var(--phb-navy); border-radius: var(--phb-radius); padding: clamp(2.5rem, 6vw, 4rem); text-align: center; }
.phb-cta h2 { color: #fff; font-weight: 600; font-size: clamp(1.8rem, 3vw, 2.5rem); letter-spacing: -0.02em; margin: 0 0 0.8rem; text-wrap: balance; }
.phb-cta p { color: rgba(255, 255, 255, 0.74); font-size: 1.08rem; margin: 0 auto 1.9rem; max-width: 52ch; }
.phb-cta__actions { display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.phb-cta__reassure { list-style: none; display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem 1.5rem; margin: 1.8rem 0 0; padding: 0; }
.phb-cta__reassure li { display: inline-flex; align-items: center; gap: 0.45rem; color: rgba(255, 255, 255, 0.82); font-size: 0.92rem; }
.phb-cta__reassure i { color: #5cc8ff; font-size: 0.82rem; }

/* ── Logo cloud (real stack) ── */
.phb-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 2.2rem 3rem; }
.phb-logos img { height: 26px; width: auto; opacity: 0.55; filter: grayscale(1); transition: opacity 0.15s ease, filter 0.15s ease; }
.phb-logos img:hover { opacity: 0.9; filter: grayscale(0); }
.phb-logos__label { text-align: center; color: var(--phb-muted); font-family: var(--phb-font-mono); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 1.6rem; }

/* ============================================================
   Additions for the rootserver overview (product page)
   ============================================================ */

/* ── Inline heading accent (hero.title / what_is.title ship a <span>) ── */
.phb-h1 span, .phb-h2 span { color: var(--phb-primary-d); font-weight: inherit; }

/* ── Subpage header (compact, with breadcrumb) — reads as a subpage, not a 2nd homepage ── */
.phb-subhead {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    /* Consistent page-header height across the site: sparse headers (cart, legal,
       info) grow to this floor and centre their content; content-rich landing
       pages (with CTAs/reassure) naturally extend past it. */
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 280px;
    border-bottom: 1px solid var(--phb-border-2);
    padding: clamp(1.3rem, 3vh, 1.9rem) 0 clamp(2.4rem, 5vh, 3.2rem);
    /* soft brand-blue glow (top-right) over a light gradient base */
    background:
        radial-gradient(62% 85% at 88% -10%, rgba(0, 156, 255, 0.12), transparent 60%),
        linear-gradient(180deg, #ffffff 0%, var(--phb-bg) 100%);
}
/* faint dot grid, concentrated top-right and masked to fade before the text */
.phb-subhead::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background-image: radial-gradient(rgba(15, 28, 43, 0.07) 1px, transparent 1.6px);
    background-size: 22px 22px;
    -webkit-mask-image: radial-gradient(115% 95% at 82% 0%, #000 0%, transparent 62%);
    mask-image: radial-gradient(115% 95% at 82% 0%, #000 0%, transparent 62%);
    pointer-events: none;
}
.phb-subhead .phb-inner { position: relative; z-index: 1; }
/* decorative hosting-icon scatter (subpage header motif) — faded toward the text */
.phb-subhead__pattern { position: absolute; inset: 0; z-index: -1; pointer-events: none; overflow: hidden;
    -webkit-mask-image: linear-gradient(100deg, rgba(0, 0, 0, 0.30) 0%, rgba(0, 0, 0, 0.52) 48%, #000 88%);
    mask-image: linear-gradient(100deg, rgba(0, 0, 0, 0.30) 0%, rgba(0, 0, 0, 0.52) 48%, #000 88%); }
.phb-subhead__pattern i { position: absolute; color: var(--phb-navy); opacity: 0.11; line-height: 1; }
@media (max-width: 700px) { .phb-subhead__pattern { display: none; } .phb-subhead { min-height: 210px; } }
.phb-subhead .phb-h1 { font-size: clamp(1.85rem, 3.3vw, 2.6rem); line-height: 1.07; margin: 0.55rem 0 0.85rem; max-width: 22ch; }
.phb-subhead .phb-lead { margin-top: 0; margin-bottom: 1.7rem; max-width: 60ch; }
.phb-subhead .phb-hero__actions { justify-content: flex-start; }

.phb-breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; font-size: 0.82rem; color: var(--phb-muted); margin: 0; }
.phb-breadcrumb a { color: var(--phb-muted); text-decoration: none; transition: color 0.15s ease; }
.phb-breadcrumb a:hover { color: var(--phb-primary-d); }
.phb-breadcrumb i { font-size: 0.6rem; opacity: 0.55; }
.phb-breadcrumb [aria-current] { color: var(--phb-navy); font-weight: 600; }


/* ── In-page anchor offset (sticky navbar) + keyboard focus target ── */
.phb-sec[id], .phb-hero[id] { scroll-margin-top: 90px; }
.phb-sec[id]:focus { outline: none; }

/* ── Keyboard focus (WCAG 2.4.7) — invisible before ── */
.phb a:focus-visible,
.phb button:focus-visible,
.phb summary:focus-visible,
.phb [tabindex]:focus-visible { outline: 2px solid var(--phb-primary); outline-offset: 2px; border-radius: 4px; }
.phb-cta a:focus-visible,
.phb-cta button:focus-visible { outline-color: #fff; }

/* ── Screen-reader-only utility (matrix ja/nein, captions) ── */
.phb .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

/* ── Comparison matrix (real <table> — a11y + featured snippet) ── */
.phb-compare-wrap { margin-top: 2.5rem; }
table.phb-compare { width: 100%; border-collapse: collapse; font-size: 0.93rem; }
.phb-compare caption { text-align: left; }
.phb-compare th, .phb-compare td { padding: 0.85rem 1rem; text-align: center; border-top: 1px solid var(--phb-border); }
.phb-compare thead th { color: var(--phb-navy); font-weight: 600; border-top: 0; border-bottom: 1px solid var(--phb-border); }
.phb-compare thead th:first-child { text-align: left; }
.phb-compare tbody th[scope="row"] { text-align: left; color: var(--phb-muted); font-weight: 500; }
.phb-compare td { color: var(--phb-navy); }
.phb-compare .phb-compare__yes { color: var(--phb-primary-d); }
.phb-compare .phb-compare__no { color: color-mix(in srgb, var(--phb-muted) 60%, transparent); }
.phb-compare .phb-compare__price { font-weight: 700; font-feature-settings: "tnum"; letter-spacing: -0.01em; }
/* recommended (KVM) column — subtle brand tint, no hard sell */
.phb-compare thead th.phb-compare__rec { color: var(--phb-primary-d); }
.phb-compare .phb-compare__rec { background: var(--phb-primary-lt); }
.phb-compare tbody tr:hover td, .phb-compare tbody tr:hover th { background: color-mix(in srgb, var(--phb-bg) 60%, transparent); }
.phb-compare tbody tr:hover .phb-compare__rec { background: var(--phb-primary-lt); }

/* Mobile (<=720px): stacked bordered cards, no horizontal scroll */
@media (max-width: 720px) {
    .phb-compare, .phb-compare tbody, .phb-compare tr, .phb-compare th, .phb-compare td { display: block; }
    .phb-compare thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); }
    .phb-compare tbody tr { border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); padding: 0.4rem 1rem 0.7rem; margin-bottom: 0.75rem; }
    .phb-compare tbody th[scope="row"] { padding: 0.6rem 0 0.3rem; color: var(--phb-navy); font-weight: 600; border: 0; }
    .phb-compare tbody td { display: flex; justify-content: space-between; align-items: center; gap: 1rem; text-align: right; padding: 0.4rem 0; border-top: 1px solid var(--phb-border-2); background: none !important; }
    .phb-compare tbody td::before { content: attr(data-col); color: var(--phb-muted); font-weight: 500; }
}

/* ── Respect reduced motion ── */
@media (prefers-reduced-motion: reduce) {
    .phb *, .phb *::before, .phb *::after { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
    .phb-card:hover { transform: none !important; }
}

/* ============================================================
   Server configurator (order page) — informaten-style, full width
   ============================================================ */
.phb-cfg2 { display: grid; gap: 1.1rem; }
.phb-cfg-seclabel { color: var(--phb-muted); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; margin: 0 0 0.55rem; display: flex; align-items: center; gap: 0.45rem; }
.phb-cfg-seclabel i { color: var(--phb-primary); }

/* card grids */
.phb-cfg-cards { display: grid; gap: 1rem; }
.phb-cfg-cards--3 { grid-template-columns: repeat(3, 1fr); }
.phb-cfg-cards--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .phb-cfg-cards--3, .phb-cfg-cards--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .phb-cfg-cards--3, .phb-cfg-cards--4 { grid-template-columns: 1fr; } }

.phb-cfg-card { background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius); padding: 1.2rem 1.25rem; display: grid; gap: 0.85rem; align-content: start; }
.phb-cfg-card__head { display: flex; align-items: center; gap: 0.6rem; }
.phb-cfg-card__head .ic { width: 34px; height: 34px; border-radius: 9px; background: var(--phb-primary-lt); color: var(--phb-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 0.88rem; flex-shrink: 0; }
.phb-cfg-card__head b { color: var(--phb-navy); font-weight: 600; font-size: 0.92rem; line-height: 1.2; }
.phb-cfg-card__head small { display: block; color: var(--phb-muted); font-size: 0.74rem; font-weight: 500; }
.phb-cfg-card__value { text-align: center; color: var(--phb-navy); }
.phb-cfg-card__value b { font-weight: 700; font-size: 1.15rem; letter-spacing: -0.01em; font-feature-settings: "tnum"; }
.phb-cfg-card__value .delta { color: var(--phb-primary-d); font-weight: 600; font-size: 0.85rem; margin-left: 0.4rem; font-feature-settings: "tnum"; }
.phb-cfg-card__value .delta.incl { color: var(--phb-muted); font-weight: 500; }
.phb-cfg-minmax { display: flex; justify-content: space-between; color: var(--phb-muted); font-size: 0.74rem; font-feature-settings: "tnum"; margin-bottom: -0.4rem; padding: 0 0.2rem; }
/* included info cards (centered, with badge) */
.phb-cfg-card--incl { display: flex; flex-direction: column; }
.phb-cfg-inclbody { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.55rem; text-align: center; padding: 0.5rem 0; }
.phb-cfg-inclbody > b { color: var(--phb-navy); font-weight: 700; font-size: 1.1rem; font-feature-settings: "tnum"; }
.phb-cfg-inclbody small { color: var(--phb-muted); font-size: 0.78rem; }
.phb-cfg-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: var(--phb-primary-lt); color: var(--phb-primary-d); font-weight: 600; font-size: 0.82rem; padding: 0.38rem 0.9rem; border-radius: 50px; }
.phb-cfg-badge i { font-size: 0.72rem; }

/* value-reactive visuals */
.phb-cfg-viz { display: flex; align-items: center; justify-content: center; min-height: 128px; }
.phb-cfg-chip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 5px; padding: 14px; border: 2px solid var(--phb-border); border-radius: 12px; background: var(--phb-bg); }
.phb-cfg-chip span { width: 15px; height: 15px; border-radius: 3px; background: var(--phb-border); transition: background .2s ease; }
.phb-cfg-chip span.on { background: var(--phb-primary); }
.phb-cfg-bars { display: flex; align-items: flex-end; gap: 5px; height: 96px; }
.phb-cfg-bars span { width: 11px; height: 100%; background: var(--phb-border); border-radius: 3px; transition: background .2s ease; }
.phb-cfg-bars span.on { background: var(--phb-primary); }
.phb-cfg-ring { width: 124px; height: 124px; border-radius: 50%; background: conic-gradient(var(--phb-primary) calc(var(--pct, 0) * 1%), var(--phb-border) 0); display: flex; align-items: center; justify-content: center; transition: background .2s ease; }
.phb-cfg-ring span { width: 86px; height: 86px; border-radius: 50%; background: #fff; }

/* slider + stepper */
.phb-cfg-slider { display: flex; align-items: center; gap: 0.6rem; }
.phb-cfg-slider button { width: 44px; height: 44px; flex-shrink: 0; border: 1px solid var(--phb-border); border-radius: 9px; background: #fff; color: var(--phb-navy); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 0.82rem; transition: background .15s, color .15s, border-color .15s; }
.phb-cfg-slider button:hover:not(:disabled) { border-color: var(--phb-primary); color: var(--phb-primary-d); background: var(--phb-primary-lt); }
.phb-cfg-slider button:disabled { opacity: 0.35; cursor: not-allowed; }
.phb-cfg-range { flex: 1; accent-color: var(--phb-primary); height: 6px; cursor: pointer; min-width: 0; }
.phb-cfg-range:focus-visible { outline: 2px solid var(--phb-primary); outline-offset: 4px; }

/* runtime + price/order row */
.phb-cfg-runtime { display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius); padding: 1.3rem 1.4rem; }
.phb-cfg-runtime__main { flex: 1; min-width: 280px; }
.phb-cfg-runtime__price { display: grid; gap: 0.45rem; justify-items: end; min-width: 200px; margin-left: auto; }
@media (max-width: 560px) {
    .phb-cfg-runtime__main, .phb-cfg-runtime__price { min-width: 0; }
    .phb-cfg-runtime__price { justify-items: start; margin-left: 0; }
}

/* use-case tiles (homepage → rootserver use-case landing pages) */
.uc-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(205px, 1fr)); gap: 0.85rem; }
.uc-tile { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.7rem; padding: 1.4rem 1rem; background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius); color: var(--phb-navy); text-decoration: none; font-weight: 600; font-size: 0.9rem; line-height: 1.3; transition: border-color .15s, transform .15s, box-shadow .15s; }
.uc-tile:hover { border-color: var(--phb-primary); color: var(--phb-navy); transform: translateY(-3px); box-shadow: 0 14px 30px -18px rgba(15, 28, 43, 0.45); }
.uc-tile__logo { height: 48px; display: inline-flex; align-items: center; justify-content: center; }
.uc-tile__logo img { width: 44px; height: 44px; object-fit: contain; }
.uc-tile__ic { height: 48px; display: inline-flex; align-items: center; justify-content: center; font-size: 2.1rem; }
@media (max-width: 540px) { .uc-tiles { grid-template-columns: repeat(2, 1fr); } }
.phb-cfg-amount { color: var(--phb-navy); font-weight: 700; font-size: 1.9rem; letter-spacing: -0.02em; font-feature-settings: "tnum"; line-height: 1; }
.phb-cfg-amount s { color: var(--phb-muted); font-weight: 500; font-size: 1.05rem; }
.phb-cfg-amount small { color: var(--phb-primary-d); font-weight: 600; font-size: 0.7rem; margin-left: 0.3rem; }
.phb-cfg-period { color: var(--phb-muted); font-size: 0.8rem; margin: -0.25rem 0 0.25rem; }
.phb-cfg-discount { display: inline-flex; align-items: center; gap: 0.45rem; background: var(--phb-primary-lt); color: var(--phb-primary-d); border-radius: 50px; padding: 0.32rem 0.75rem; font-size: 0.78rem; }

/* runtime tiles */
.phb-cfg-tiles { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.phb-cfg-tile { position: relative; display: inline-flex; flex-direction: column; align-items: center; justify-content: center; min-width: 96px; padding: 0.72rem 1.1rem; background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); cursor: pointer; font-weight: 600; font-size: 0.95rem; color: var(--phb-navy); transition: border-color .15s, background .15s, color .15s, box-shadow .15s; font-feature-settings: "tnum"; }
.phb-cfg-tile small { position: absolute; top: -9px; right: -7px; font-weight: 700; font-size: 0.66rem; color: #b45309; background: #fdf0d5; border: 1px solid rgba(245, 158, 11, 0.45); border-radius: 50px; padding: 0.1rem 0.5rem; line-height: 1.35; box-shadow: 0 2px 5px -1px rgba(15, 28, 43, 0.12); }
.phb-cfg-tile:hover:not(:disabled) { border-color: color-mix(in srgb, var(--phb-primary) 50%, var(--phb-border)); }
.phb-cfg-tile.is-active { border-color: var(--phb-primary); background: var(--phb-primary-lt); color: var(--phb-primary-d); box-shadow: 0 0 0 1px var(--phb-primary); }
.phb-cfg-tile:disabled { opacity: 0.4; cursor: not-allowed; }

/* OS chips */
.phb-os { display: flex; flex-wrap: wrap; gap: 1rem; }
.phb-os-card { display: inline-flex; align-items: center; gap: 0.7rem; background: #fff; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); padding: 0.8rem 1.2rem; font-weight: 600; color: var(--phb-navy); }
.phb-os-card img { width: 30px; height: 30px; object-fit: contain; }
.phb-os-card i { color: var(--phb-primary); font-size: 1.15rem; width: 1.35rem; text-align: center; }
.phb-os-card--more { background: var(--phb-primary-lt); border-color: color-mix(in srgb, var(--phb-primary) 40%, var(--phb-border)); color: var(--phb-primary-d); }
.phb-os-card--more i { color: var(--phb-primary-d); }

/* ── Stat block (e.g. DDoS filter capacity) ── */
.phb-stat { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.55rem; text-align: center; background: var(--phb-bg); border: 1px solid var(--phb-border); border-radius: var(--phb-radius); padding: clamp(2rem, 5vw, 3.2rem); min-height: 240px; }
.phb-stat__icon { width: 56px; height: 56px; border-radius: 14px; background: var(--phb-primary-lt); color: var(--phb-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 0.3rem; }
.phb-stat__num { color: var(--phb-navy); font-weight: 700; font-size: clamp(2.2rem, 5vw, 3rem); letter-spacing: -0.02em; line-height: 1; font-feature-settings: "tnum"; }
.phb-stat__label { color: var(--phb-muted); font-size: 0.9rem; }
.phb-stat__logo { height: 24px; width: auto; opacity: 0.6; filter: grayscale(1); margin-top: 0.5rem; }

/* ============================================================
   Order modal (rootpackets — package → cart) — keeps existing
   IDs/classes/JS hooks, restyled to the brand system
   ============================================================ */
.order-modal { position: fixed; inset: 0; z-index: 9000; display: none; align-items: center; justify-content: center; padding: 1.5rem; background: rgba(15, 28, 43, 0.55); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif; }
.order-modal.active { display: flex; }
.order-modal-content { background: #fff; border-radius: var(--phb-radius); width: 100%; max-width: 560px; max-height: 92vh; overflow-y: auto; box-shadow: 0 30px 70px -20px rgba(15, 28, 43, 0.5); }
.order-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 1.3rem 1.6rem; border-bottom: 1px solid var(--phb-border); }
.order-modal-header h3 { margin: 0; color: var(--phb-navy); font-weight: 600; font-size: 1.15rem; display: flex; align-items: center; gap: 0.6rem; }
.order-modal-header h3 i { color: var(--phb-primary); }
.order-modal-close { width: 36px; height: 36px; border: 1px solid var(--phb-border); border-radius: 9px; background: #fff; color: var(--phb-muted); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: border-color .15s, color .15s; }
.order-modal-close:hover { border-color: var(--phb-primary); color: var(--phb-primary-d); }
.order-modal-body { padding: 1.5rem 1.6rem; display: grid; gap: 1.4rem; }
.order-summary { background: var(--phb-bg); border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); padding: 1.1rem 1.2rem; }
.order-summary h4 { margin: 0 0 0.8rem; color: var(--phb-navy); font-weight: 600; font-size: 0.95rem; }
.order-summary-item { display: flex; justify-content: space-between; gap: 1rem; padding: 0.32rem 0; font-size: 0.92rem; }
.order-summary-label { color: var(--phb-muted); }
.order-summary-value { color: var(--phb-navy); font-weight: 600; font-feature-settings: "tnum"; }
.order-summary-divider { height: 1px; background: var(--phb-border); margin: 0.6rem 0; }
.order-summary-total .order-summary-value { color: var(--phb-primary-d); font-size: 1.05rem; }
.order-promo-price-info { margin-top: 0.6rem; text-align: right; font-feature-settings: "tnum"; }
.order-promo-price-info i { color: var(--phb-primary); margin: 0 0.35rem; }
.promo-original-price { color: var(--phb-muted); text-decoration: line-through; }
.promo-new-price { color: var(--phb-primary-d); font-weight: 700; }
.os-select-label, .duration-label { display: flex; align-items: center; gap: 0.5rem; color: var(--phb-navy); font-weight: 600; font-size: 0.92rem; margin-bottom: 0.7rem; }
.os-select-label i, .duration-label i { color: var(--phb-primary); }
.os-select-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.6rem; }
.duration-options { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.6rem; }
.os-select-option, .duration-option { cursor: pointer; margin: 0; }
.os-select-option input, .duration-option input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.os-select-box, .duration-box { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.28rem; text-align: center; padding: 0.7rem 0.5rem; height: 100%; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); background: #fff; transition: border-color .15s, background .15s, box-shadow .15s; }
.os-select-option input:checked + .os-select-box, .duration-option input:checked + .duration-box { border-color: var(--phb-primary); background: var(--phb-primary-lt); box-shadow: 0 0 0 1px var(--phb-primary); }
.os-select-option input:focus-visible + .os-select-box, .duration-option input:focus-visible + .duration-box { outline: 2px solid var(--phb-primary); outline-offset: 2px; }
.os-select-box img { width: 30px; height: 30px; object-fit: contain; }
.os-select-name { color: var(--phb-navy); font-weight: 600; font-size: 0.8rem; line-height: 1.2; }
.os-select-version { color: var(--phb-muted); font-size: 0.7rem; }
.duration-value { color: var(--phb-navy); font-weight: 700; font-size: 1.2rem; font-feature-settings: "tnum"; }
.duration-unit { color: var(--phb-muted); font-size: 0.72rem; }
.duration-option input:checked + .duration-box .duration-value { color: var(--phb-primary-d); }
.order-modal-footer { display: flex; gap: 0.8rem; padding: 1.2rem 1.6rem; border-top: 1px solid var(--phb-border); }
.order-btn-cancel { padding: 0.82rem 1.3rem; border: 1px solid var(--phb-border); border-radius: var(--phb-radius-sm); background: #fff; color: var(--phb-navy); font-weight: 600; cursor: pointer; transition: border-color .15s, color .15s; }
.order-btn-cancel:hover { border-color: var(--phb-primary); color: var(--phb-primary-d); }
.order-btn-confirm { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.82rem 1.3rem; border: 0; border-radius: var(--phb-radius-sm); background: var(--phb-primary); color: #fff; font-weight: 600; cursor: pointer; transition: background .15s; }
.order-btn-confirm:hover { background: var(--phb-primary-d); }
.order-btn-confirm:disabled { opacity: 0.7; cursor: default; }
/* Order modal — mobile: 4-col duration / 3-col OS grids were cramped inside the padded modal at ≤480px; close button below 44px tap target */
.order-modal-close { width: 44px; height: 44px; }
@media (max-width: 480px) {
    .order-modal { padding: 0.75rem; }
    .order-modal-body { padding: 1.2rem 1.1rem; gap: 1.1rem; }
    .order-modal-header, .order-modal-footer { padding-left: 1.1rem; padding-right: 1.1rem; }
    .duration-options { grid-template-columns: repeat(2, 1fr); }
    .os-select-grid { grid-template-columns: repeat(2, 1fr); }
}
