/* D16 — ReliableSuite public onboarding site.
   Built on top of the shared brand theme (theme.css) — reuses --rs-* brand variables and the
   .btn / .btn-brand / .btn-ghost button base. Adds the public marketing/landing + form styles.
   D28.1A — typography + visual fine-tuning pass (premium B2B SaaS feel). */

/* Premium, no-external-dependency font stack: prefers Inter / Segoe UI Variable if present, then
   graceful system fallbacks. Overriding --font here scopes it to the public site only (theme.css
   loads first; this rule wins), so inputs and shared bits pick it up too. */
:root {
    --font: "Inter", "Segoe UI Variable Text", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
}

html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }
html, body { margin: 0; padding: 0; background: var(--rs-surface); color: var(--rs-text); font-family: var(--font); }
* { box-sizing: border-box; }
a { color: var(--rs-blue-deep); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { color: var(--rs-navy); line-height: 1.15; margin: 0 0 .4em; letter-spacing: -.018em; }
h1 { letter-spacing: -.028em; }
p { text-wrap: pretty; }

/* Refined CTA buttons — a touch more presence + a subtle lift on hover (marketing only). */
.btn-lg { padding: 13px 24px; font-size: 15px; border-radius: 12px; letter-spacing: -.01em; font-weight: 700; }
.btn { transition: transform .15s ease, box-shadow .15s ease, background .15s ease; }
.btn-brand.btn-lg:hover { transform: translateY(-1px); box-shadow: var(--sh-2); }

.ob-shell { display: flex; flex-direction: column; min-height: 100vh; }
.ob-main { flex: 1; }
.ob-wrap { width: 100%; max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.ob-narrow { max-width: 760px; }
.ob-muted { color: var(--rs-muted); }
.ob-center { text-align: center; }
.ob-grad-text { background: var(--rs-grad-135); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ---- Top bar ---- */
.ob-topbar { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.92);
    backdrop-filter: saturate(160%) blur(8px); border-bottom: 1px solid var(--rs-border); }
.ob-topbar-inner { display: flex; align-items: center; justify-content: space-between; height: 66px; }
.ob-brand { display: flex; align-items: center; gap: 12px; }
.ob-brand:hover { text-decoration: none; }
.ob-brand-mark { display: inline-flex; padding: 6px; border-radius: 10px; background: var(--rs-navy);
    background-image: linear-gradient(180deg,#15396B,#0F2A50); }
.ob-brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.ob-brand-name { font-weight: 800; color: var(--rs-navy); font-size: 18px; letter-spacing: .2px; }
.ob-brand-sub { font-size: 10px; letter-spacing: 1.4px; color: var(--rs-muted); font-weight: 600; }
.ob-nav { display: flex; align-items: center; gap: 22px; }
.ob-nav > a { color: var(--rs-text); font-weight: 600; font-size: 14px; }
.ob-nav > a:hover { color: var(--rs-blue-deep); text-decoration: none; }
.ob-nav-cta { color: #fff !important; }

/* ---- Hero ---- */
.ob-hero { background: var(--rs-navy); background-image: radial-gradient(1200px 520px at 82% -12%, rgba(43,182,198,.34), transparent 60%), radial-gradient(900px 480px at 6% 120%, rgba(39,177,92,.16), transparent 62%), linear-gradient(160deg,#163C71,#0E274B); color: #fff; overflow: hidden; }
.ob-hero-inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center; padding: 84px 0 92px; }
.ob-hero-copy h1 { color: #fff; font-size: 52px; font-weight: 800; line-height: 1.06; letter-spacing: -.03em; margin-bottom: 20px; }
.ob-hero-copy h1 .ob-grad-text { background: linear-gradient(100deg,#5fe3d0 0%,#57d0e6 45%,#7ff0a8 100%); -webkit-background-clip: text; background-clip: text; }
.ob-eyebrow { display: inline-block; font-size: 12px; letter-spacing: 1.4px; font-weight: 700; text-transform: uppercase;
    color: #cdeef6; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16); padding: 7px 13px; border-radius: 999px; margin-bottom: 20px; }
.ob-lead { font-size: 18.5px; line-height: 1.62; color: rgba(255,255,255,.88); max-width: 560px; }
.ob-hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin: 26px 0 18px; }
.ob-hero-cta .btn-ghost { background: rgba(255,255,255,.10); color: #fff; border-color: rgba(255,255,255,.28); }
.ob-hero-cta .btn-ghost:hover { background: rgba(255,255,255,.18); }
.ob-hero-secondary { display: inline-flex; align-items: center; gap: 8px; margin: 2px 0 4px; font-size: 14px; font-weight: 600; color: rgba(255,255,255,.82); }
.ob-hero-secondary:hover { color: #fff; text-decoration: none; }
.ob-hero-secondary svg { color: #5fe3a3; }
.ob-hero-points { list-style: none; display: flex; flex-wrap: wrap; gap: 18px; padding: 0; margin: 18px 0 0; }
.ob-hero-points li { display: flex; align-items: center; gap: 7px; font-size: 14px; color: rgba(255,255,255,.9); }
.ob-hero-points svg { color: #5fe3a3; }
.ob-hero-art { position: relative; display: flex; justify-content: center; align-items: center; min-height: 340px; }

/* ---- Trust / benefit strip ---- */
.ob-trust { background: var(--rs-surface); border-bottom: 1px solid var(--rs-border); }
.ob-trust-strip { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px 28px; padding: 22px 24px; }
.ob-trust-item { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 14px; color: var(--rs-navy); letter-spacing: -.01em; }
.ob-trust-ic { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 11px; color: var(--rs-blue-deep); background: var(--info-bg); box-shadow: inset 0 0 0 1px var(--info-ring); }

/* ---- Sections ---- */
.ob-section { padding: 72px 0; }
.ob-section-alt { background: var(--rs-bg); }
.ob-section-head { text-align: center; max-width: 640px; margin: 0 auto 40px; }
.ob-section-head.ob-left { text-align: left; margin-left: 0; }
.ob-section-head h2 { font-size: 32px; }
.ob-section-head p { color: var(--rs-muted); font-size: 16px; margin: 0; }

.ob-grid { display: grid; gap: 20px; }
.ob-grid-3 { grid-template-columns: repeat(3, 1fr); }
.ob-grid-4 { grid-template-columns: repeat(4, 1fr); }

.ob-feature { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 24px; box-shadow: var(--sh-1); }
.ob-feature-ic { display: inline-flex; padding: 11px; border-radius: 12px; color: var(--rs-blue-deep); background: var(--info-bg); margin-bottom: 14px; }
.ob-feature h3 { font-size: 18px; }
.ob-feature p { color: var(--rs-muted); margin: 0; font-size: 14px; line-height: 1.55; }

.ob-chip-card { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-md); padding: 16px; display: flex; flex-direction: column; gap: 8px; box-shadow: var(--sh-1); }
.ob-chip-name { font-weight: 700; color: var(--rs-navy); }
.ob-chip-cat { align-self: flex-start; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; padding: 3px 9px; border-radius: 999px; }
.ob-cat-core { background: var(--info-bg); color: var(--info); }
.ob-cat-optional { background: var(--trial-bg); color: var(--trial); }
.ob-cat-premium { background: var(--warn-bg); color: var(--warn); }

.ob-industries .ob-industry { display: flex; align-items: center; gap: 12px; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-md); padding: 18px 18px; font-weight: 600; color: var(--rs-navy); box-shadow: var(--sh-1); }
.ob-industry svg { color: var(--rs-teal-logo); }

/* ---- CTA band (with subtle official build-mark watermark) ---- */
.ob-cta-band { position: relative; overflow: hidden; background: var(--rs-grad-135); color: #fff; }
.ob-cta-band::after { content: ""; position: absolute; top: 50%; right: -46px; transform: translateY(-50%);
    width: 300px; height: 300px; background: url('../images/brand/reliable-suite-build.svg') no-repeat center / contain;
    filter: brightness(0) invert(1); opacity: .12; pointer-events: none; }
.ob-cta-inner { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 48px 0; flex-wrap: wrap; }
.ob-cta-inner h2 { color: #fff; margin-bottom: 6px; }
.ob-cta-inner p { margin: 0; color: rgba(255,255,255,.9); }
.ob-cta-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.ob-cta-band .btn-brand { background: #fff; color: var(--rs-navy); }
.ob-cta-band .ob-cta-ghost { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.5); }
.ob-cta-band .ob-cta-ghost:hover { background: rgba(255,255,255,.22); }

/* ---- Footer ---- */
.ob-footer { background: var(--rs-navy-900); color: rgba(255,255,255,.8); padding: 48px 0 22px; }
.ob-footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 28px; }
.ob-footer-brand { display: flex; flex-direction: column; gap: 12px; }
.ob-footer .ob-brand-name { color: #fff; font-size: 18px; font-weight: 800; }
.ob-footer-tag { color: rgba(255,255,255,.6); font-size: 13px; line-height: 1.6; margin: 6px 0 0; max-width: 420px; }
.ob-footer-col h4 { color: #fff; font-size: 13px; letter-spacing: .5px; text-transform: uppercase; }
.ob-footer-col p { margin: 8px 0; font-size: 14px; display: flex; align-items: center; gap: 8px; }
.ob-footer-col a, .ob-footer-tag a { color: rgba(255,255,255,.82); }
.ob-footer-col svg { color: var(--rs-teal-logo); }
.ob-footer-legal { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-top: 30px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.12); font-size: 12.5px; color: rgba(255,255,255,.55); }

/* ---- Registration form ---- */
.ob-register .ob-section-head { margin-bottom: 26px; }
.ob-form { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sh-2); }
.ob-form fieldset { border: 0; margin: 0; padding: 0; }
.ob-form-group { font-size: 13px; text-transform: uppercase; letter-spacing: .8px; color: var(--rs-muted); margin: 24px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--rs-border); }
.ob-form-group:first-child { margin-top: 0; }
.ob-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.ob-form-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.ob-field { display: flex; flex-direction: column; margin-bottom: 16px; }
.ob-field > label { font-weight: 600; font-size: 13.5px; color: var(--rs-text); margin-bottom: 6px; }
.ob-req { color: var(--danger); }
.ob-hint { font-size: 12px; color: var(--rs-muted); margin-top: 5px; }
.ob-input { width: 100%; padding: 10px 12px; border: 1px solid var(--rs-border-strong); border-radius: 10px; font-size: 14px; font-family: var(--font); color: var(--rs-text); background: var(--rs-surface); }
.ob-input:focus { outline: none; border-color: var(--rs-blue); box-shadow: 0 0 0 3px rgba(47,123,195,.18); }
.ob-textarea { resize: vertical; min-height: 90px; }
.ob-modules { display: flex; flex-wrap: wrap; gap: 10px; }
.ob-module-pick { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border: 1px solid var(--rs-border-strong); border-radius: 999px; font-size: 13px; cursor: pointer; user-select: none; }
.ob-module-pick.on { border-color: var(--rs-blue); background: var(--info-bg); color: var(--rs-blue-deep); font-weight: 600; }
.ob-module-pick input { accent-color: var(--rs-blue); }
.ob-consent-label { display: flex; gap: 10px; align-items: flex-start; font-weight: 500; font-size: 14px; color: var(--rs-text); cursor: pointer; }
.ob-consent-label input { margin-top: 3px; accent-color: var(--rs-blue); }
.ob-form-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 20px; }
.validation-message, .ob-field .validation-message { color: var(--danger); font-size: 12.5px; margin-top: 5px; }

/* Honeypot — kept in the DOM (so bots fill it) but invisible & out of flow for humans. */
.ob-hp { position: absolute; left: -9999px; top: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ---- Confirmation ---- */
.ob-confirm { text-align: center; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 44px 32px; box-shadow: var(--sh-2); }
.ob-confirm-ic { display: inline-flex; padding: 16px; border-radius: 999px; background: var(--ok-bg); color: var(--ok); margin-bottom: 14px; }
.ob-ref { display: inline-flex; flex-direction: column; gap: 4px; background: var(--rs-bg); border: 1px dashed var(--rs-border-strong); border-radius: var(--r-md); padding: 16px 26px; margin: 22px auto; }
.ob-ref-label { font-size: 12px; text-transform: uppercase; letter-spacing: .8px; color: var(--rs-muted); }
.ob-ref-value { font-size: 22px; font-weight: 800; color: var(--rs-navy); letter-spacing: .5px; }
.ob-ref-hint { font-size: 12px; color: var(--rs-muted); }
.ob-confirm-next { text-align: left; max-width: 520px; margin: 12px auto 26px; }
.ob-confirm-next ol { padding-left: 20px; color: var(--rs-text); }
.ob-confirm-next li { margin: 6px 0; }

/* ---- Prose (terms) ---- */
.ob-prose h3 { margin-top: 26px; }
.ob-prose p { line-height: 1.65; color: var(--rs-text); }

/* ============================================================
   D28 — Public marketing website
   ============================================================ */

/* ---- Flash / announcement banner (slim, subtle top strip) ---- */
.ob-announce { background: var(--rs-navy-900); color: rgba(255,255,255,.92); border-bottom: 1px solid rgba(255,255,255,.08); }
.ob-announce-inner { display: flex; align-items: center; justify-content: center; gap: 9px; padding: 7px 24px; font-size: 12.5px; flex-wrap: wrap; }
.ob-announce-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--rs-grad-135); box-shadow: 0 0 0 3px rgba(43,182,198,.18); flex: 0 0 auto; }
.ob-announce-text { font-weight: 600; letter-spacing: -.005em; }
.ob-announce-link { color: #7ff0c0; font-weight: 700; text-decoration: none; }
.ob-announce-link:hover { color: #a6ffd6; text-decoration: underline; text-underline-offset: 2px; }
.ob-announce-x { position: absolute; inset-inline-end: 24px; display: inline-flex; align-items: center; justify-content: center;
    background: none; border: 0; padding: 4px; color: rgba(255,255,255,.6); cursor: pointer; border-radius: 6px; }
.ob-announce-x:hover { color: #fff; background: rgba(255,255,255,.1); }
.ob-announce-inner { position: relative; }

/* ---- Header logo (official PNG) ---- */
.ob-logo-img { height: 44px; width: auto; display: block; }
.ob-nav-demo { color: var(--rs-text) !important; }
.ob-nav-demo:hover { text-decoration: none; }

/* ---- Hero building-mark accent (official SVG) ---- */
.ob-hero { position: relative; }
.ob-hero-bgmark { position: absolute; top: 46%; right: -90px; transform: translateY(-50%);
    width: 640px; max-width: 58%; opacity: .07; pointer-events: none; user-select: none; }

/* ============================================================
   D28.1A — Premium hero dashboard visual (light theme; HTML/CSS + inline SVG).
   Brand-safe: shows the ReliableSuite NAME + our own build-mark only — never a fake/mismatched
   logo. Customer names in the sample table are generic. Floating glance card + brand tile add depth.
   ============================================================ */
.ob-dash { position: relative; width: 100%; max-width: 560px; background: var(--rs-surface);
    border-radius: 16px; border: 1px solid var(--rs-border);
    box-shadow: 0 30px 60px rgba(8,22,45,.22), 0 8px 20px rgba(8,22,45,.12); overflow: hidden; z-index: 2; }
.ob-dash-body { display: grid; grid-template-columns: 132px 1fr; min-height: 360px; }
.ob-dash-rail { background: var(--rs-navy); background-image: linear-gradient(180deg,#163C71,#0E274B); padding: 14px 10px; display: flex; flex-direction: column; gap: 2px; }
.ob-dash-brand { display: flex; align-items: center; gap: 7px; color: #fff; font-size: 11.5px; font-weight: 800; margin: 2px 4px 12px; }
.ob-dash-brand img { width: 18px; height: 18px; }
.ob-dash-nav { display: flex; align-items: center; gap: 8px; font-size: 10.5px; color: rgba(255,255,255,.68); padding: 6px 8px; border-radius: 7px; }
.ob-dash-nav i { width: 7px; height: 7px; border-radius: 2px; background: rgba(255,255,255,.35); flex: 0 0 auto; }
.ob-dash-nav.on { background: rgba(255,255,255,.12); color: #fff; }
.ob-dash-nav.on i { background: var(--rs-teal); }
.ob-dash-main { padding: 13px 14px 15px; background: var(--rs-surface-2); }
.ob-dash-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 11px; }
.ob-dash-title { font-size: 13px; font-weight: 800; color: var(--rs-navy); }
.ob-dash-daterange { font-size: 9px; font-weight: 700; color: var(--rs-muted); background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: 999px; padding: 3px 9px; }
.ob-dash-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 7px; }
.ob-dash-kpi { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: 9px; padding: 8px; display: flex; flex-direction: column; gap: 2px; box-shadow: var(--sh-1); }
.ob-dash-klbl { font-size: 7.5px; text-transform: uppercase; letter-spacing: .3px; color: var(--rs-muted); font-weight: 700; }
.ob-dash-kval { font-size: 11px; font-weight: 800; color: var(--rs-navy); letter-spacing: -.02em; }
.ob-dash-kdelta { font-size: 8px; font-weight: 700; }
.ob-dash-kdelta.up { color: var(--ok); }
.ob-dash-kdelta.dn { color: var(--danger); }
.ob-dash-mid, .ob-dash-low { display: grid; grid-template-columns: 1.5fr 1fr; gap: 8px; margin-top: 8px; }
.ob-dash-card { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: 10px; padding: 9px 10px; box-shadow: var(--sh-1); }
.ob-dash-cardhead { display: flex; align-items: center; justify-content: space-between; margin-bottom: 7px; }
.ob-dash-cardt { font-size: 9.5px; font-weight: 800; color: var(--rs-navy); }
.ob-dash-pill { font-size: 8px; font-weight: 700; color: var(--rs-blue-deep); background: var(--info-bg); border-radius: 999px; padding: 2px 7px; }
.ob-dash-link { font-size: 8.5px; font-weight: 700; color: var(--rs-blue); }
.ob-dash-line { width: 100%; height: 62px; display: block; }
.ob-dash-line polyline { fill: none; stroke: var(--rs-blue); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.ob-dash-line circle { fill: var(--rs-blue); }
.ob-dash-donutwrap { display: flex; align-items: center; gap: 10px; }
.ob-dash-donut { width: 56px; height: 56px; border-radius: 50%; flex: 0 0 auto;
    background: conic-gradient(var(--rs-blue) 0 45%, var(--rs-teal-logo) 45% 75%, var(--rs-green-accent) 75% 90%, var(--rs-border-strong) 90% 100%);
    -webkit-mask: radial-gradient(circle 14px at center, transparent 98%, #000 100%); mask: radial-gradient(circle 14px at center, transparent 98%, #000 100%); }
.ob-dash-legend { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 3px; flex: 1; }
.ob-dash-legend li { display: flex; align-items: center; gap: 5px; font-size: 8.5px; color: var(--rs-muted); }
.ob-dash-legend b { color: var(--rs-navy); margin-left: auto; }
.ob-dash-legend span { width: 7px; height: 7px; border-radius: 2px; }
.ob-dash-legend .d1 { background: var(--rs-blue); }
.ob-dash-legend .d2 { background: var(--rs-teal-logo); }
.ob-dash-legend .d3 { background: var(--rs-green-accent); }
.ob-dash-legend .d4 { background: var(--rs-border-strong); }
.ob-dash-orow, .ob-dash-srow { display: flex; align-items: center; gap: 6px; font-size: 8.5px; color: var(--rs-text); padding: 4px 0; border-top: 1px solid var(--rs-border); }
.ob-dash-orow:first-of-type, .ob-dash-srow:first-of-type { border-top: 0; }
.ob-dash-orow > span:first-child { color: var(--rs-muted); font-weight: 700; }
.ob-dash-orow > span:nth-child(2) { flex: 1; color: var(--rs-navy); }
.ob-dash-orow b { color: var(--rs-navy); }
.ob-dash-orow em { font-style: normal; font-weight: 700; padding: 1px 6px; border-radius: 999px; font-size: 7.5px; }
.ob-dash-orow .s-ok { color: var(--ok); background: var(--ok-bg); }
.ob-dash-orow .s-info { color: var(--info); background: var(--info-bg); }
.ob-dash-orow .s-warn { color: var(--warn); background: var(--warn-bg); }
.ob-dash-srow span { flex: 1; }
.ob-dash-srow b { color: var(--danger); font-weight: 800; }

/* Floating glance card + brand tile — soft depth around the panel */
.ob-float { position: absolute; z-index: 3; }
.ob-float-glance { bottom: -18px; right: -22px; width: 194px; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: 13px; padding: 11px 13px; box-shadow: 0 20px 44px rgba(8,22,45,.24); }
.ob-glance-head { font-size: 11px; font-weight: 800; color: var(--rs-navy); margin-bottom: 8px; }
.ob-glance-row { display: flex; align-items: center; gap: 7px; font-size: 10px; color: var(--rs-text); margin: 6px 0; }
.ob-glance-row b { margin-left: auto; color: var(--ok); font-size: 9.5px; }
.ob-glance-row b.muted { color: var(--rs-muted); }
.ob-glance-ic { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 6px; flex: 0 0 auto; }
.g-rev { background: var(--info-bg); color: var(--rs-blue); }
.g-ord { background: var(--trial-bg); color: var(--rs-teal); }
.g-cust { background: var(--ok-bg); color: var(--ok); }
.g-alert { background: var(--warn-bg); color: var(--warn); }
.ob-float-mark { position: absolute; z-index: 4; bottom: 44px; right: -30px; width: 50px; height: 50px; border-radius: 14px; background: var(--rs-navy); background-image: linear-gradient(180deg,#15396B,#0F2A50); display: grid; place-items: center; box-shadow: 0 14px 30px rgba(8,22,45,.35); }
.ob-float-mark img { width: 30px; height: 30px; }

/* ---- Card hover polish (subtle lift) ---- */
.ob-feature, .ob-modcard, .ob-journey, .ob-industries .ob-industry { transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.ob-feature:hover, .ob-modcard:hover, .ob-journey:hover { transform: translateY(-2px); box-shadow: var(--sh-2); border-color: var(--info-ring); }
.ob-industries .ob-industry:hover { transform: translateY(-2px); box-shadow: var(--sh-2); border-color: var(--info-ring); }
.ob-feature-ic { box-shadow: inset 0 0 0 1px var(--info-ring); }

/* ---- Choose Your Journey ---- */
.ob-journey { position: relative; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 26px 24px; box-shadow: var(--sh-1); }
.ob-journey-hi { border-color: var(--info-ring); box-shadow: var(--sh-2); }
.ob-journey-hi::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; border-radius: var(--r-lg) var(--r-lg) 0 0; background: var(--rs-grad); }
.ob-journey-ic { display: inline-flex; padding: 11px; border-radius: 12px; color: var(--rs-blue-deep); background: var(--info-bg); margin-bottom: 14px; }
.ob-journey h3 { font-size: 18px; }
.ob-journey p { color: var(--rs-muted); font-size: 14px; line-height: 1.55; margin: 0 0 16px; }
.ob-journey-link { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; color: var(--rs-blue-deep); }
.ob-journey-link:hover { text-decoration: none; gap: 9px; }

/* ---- Section footer link ---- */
.ob-section-foot { text-align: center; margin-top: 34px; }

/* ---- Sub-page hero (Modules / Industries / Deployment) ---- */
.ob-page-hero { background: var(--rs-navy); background-image: radial-gradient(1100px 460px at 82% -20%, rgba(43,182,198,.28), transparent 60%), linear-gradient(160deg,#15396B,#0F2A50); color: #fff; }
.ob-page-hero-inner { max-width: 820px; padding: 66px 0 60px; }
.ob-page-hero h1 { color: #fff; font-size: 40px; font-weight: 800; margin: 8px 0 16px; }
.ob-page-hero .ob-lead { color: rgba(255,255,255,.86); }
.ob-page-hero .ob-hero-cta { margin-top: 26px; }
.ob-ghost-onlight { background: rgba(255,255,255,.10); color: #fff; border-color: rgba(255,255,255,.30); }
.ob-ghost-onlight:hover { background: rgba(255,255,255,.18); }

/* ---- Module / industry / deployment detail cards ---- */
.ob-grid-2 { grid-template-columns: repeat(2, 1fr); }
.ob-modcard { display: flex; flex-direction: column; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 26px 24px; box-shadow: var(--sh-1); }
.ob-modcard h3 { font-size: 18px; margin-bottom: 6px; }
.ob-modcard-benefit { color: var(--rs-text); font-size: 14px; line-height: 1.55; margin: 0 0 14px; }
.ob-modcard-list { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 8px; }
.ob-modcard-list li { display: flex; align-items: flex-start; gap: 9px; font-size: 13.5px; color: var(--rs-muted); }
.ob-modcard-list svg { color: var(--rs-green-accent); flex: 0 0 auto; margin-top: 2px; }
.ob-modcard .ob-journey-link { margin-top: auto; }

/* ---- Flexible pricing block ---- */
.ob-eyebrow-light { color: var(--rs-blue-deep); background: var(--info-bg); border-color: var(--info-ring); }
.ob-lead-dark { color: var(--rs-muted); margin: 12px auto 24px; }
.ob-center-cta { justify-content: center; }

/* ---- Footer logo panel (official PNG on light chip for dark footer) ---- */
.ob-footer-logo { display: inline-flex; align-self: flex-start; background: #fff; padding: 12px 16px; border-radius: 12px; box-shadow: var(--sh-1); }
.ob-footer-logo img { height: 44px; width: auto; display: block; }
.ob-footer-company { font-size: 13px; color: rgba(255,255,255,.72); margin: 2px 0 0; }
.ob-footer-company strong { color: #fff; }

/* ---- D28.1 Contact / Book Demo page ---- */
.ob-contact-grid { display: grid; grid-template-columns: 1.55fr 1fr; gap: 32px; align-items: start; }
.ob-contact-main { min-width: 0; }
.ob-contact-aside { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 90px; }
.ob-contact-card { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 22px 22px; box-shadow: var(--sh-1); }
.ob-contact-card h3 { font-size: 16px; margin-bottom: 12px; }
.ob-contact-card .ob-modcard-list { margin-bottom: 0; }
.ob-contact-line { display: flex; align-items: center; gap: 10px; margin: 8px 0; font-size: 14px; color: var(--rs-text); }
.ob-contact-ic { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 9px; color: var(--rs-blue-deep); background: var(--info-bg); flex: 0 0 auto; }
.ob-contact-trial { background: var(--rs-bg); border-style: dashed; }
.ob-contact-trial .btn { margin-top: 10px; }

/* ---- Light hero variant (D28.1A mockup) ---- */
.ob-hero-light { background: #fff; background-image: radial-gradient(900px 460px at 88% -10%, rgba(43,182,198,.10), transparent 60%); color: var(--rs-text); }
.ob-hero-light .ob-hero-bgmark { opacity: .05; }
.ob-hero-light .ob-eyebrow { color: var(--rs-green-accent); background: #e9f7ef; border-color: #cdeedd; text-transform: uppercase; }
.ob-hero-light .ob-hero-copy h1 { color: var(--rs-navy); font-size: 56px; line-height: 1.03; }
.ob-hero-subtag { display: flex; align-items: center; gap: 11px; font-size: 17px; font-weight: 700; color: var(--rs-navy); margin: 0 0 16px; letter-spacing: -.01em; }
.ob-subtag-bar { width: 4px; height: 22px; border-radius: 3px; background: var(--rs-grad); flex: 0 0 auto; }
.ob-hero-light .ob-lead { color: var(--rs-muted); }
.ob-hero-light .ob-hero-cta .btn-ghost { background: #fff; color: var(--rs-navy); border-color: var(--rs-border-strong); }
.ob-hero-light .ob-hero-cta .btn-ghost:hover { background: var(--rs-bg); }
.ob-hero-light .ob-hero-points li { color: var(--rs-text); font-weight: 600; }
.ob-hero-light .ob-hero-points svg { color: var(--rs-green-accent); }

/* ---- Stats band ("Built for businesses that aim higher") ---- */
.ob-stats { background: var(--rs-navy); background-image: linear-gradient(160deg,#163C71,#0E274B); color: #fff; }
.ob-stats-inner { display: flex; align-items: center; gap: 22px 40px; padding: 26px 24px; flex-wrap: wrap; }
.ob-stats-head { font-size: 17px; font-weight: 800; letter-spacing: -.01em; max-width: 210px; line-height: 1.25; }
.ob-stats-items { display: flex; gap: 26px 44px; flex-wrap: wrap; margin-left: auto; }
.ob-stat { display: flex; align-items: center; gap: 12px; }
.ob-stat-ic { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 12px; color: #7fe3d0; background: rgba(255,255,255,.08); box-shadow: inset 0 0 0 1px rgba(255,255,255,.14); flex: 0 0 auto; }
.ob-stat-txt { display: flex; flex-direction: column; line-height: 1.15; }
.ob-stat-txt b { font-size: 22px; font-weight: 800; letter-spacing: -.02em; }
.ob-stat-txt i { font-style: normal; font-size: 12px; color: rgba(255,255,255,.72); max-width: 150px; }

/* ---- Module tiles (One platform. Every core operation.) ---- */
.ob-modrow { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.ob-modtile { display: flex; flex-direction: column; background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-md); padding: 18px 16px; box-shadow: var(--sh-1); transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.ob-modtile:hover { transform: translateY(-2px); box-shadow: var(--sh-2); border-color: var(--info-ring); }
.ob-modtile-ic { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 11px; margin-bottom: 12px; }
.ob-modtile-ic.ic-blue { background: var(--info-bg); color: var(--rs-blue); }
.ob-modtile-ic.ic-teal { background: var(--trial-bg); color: var(--rs-teal); }
.ob-modtile-ic.ic-green { background: var(--ok-bg); color: var(--ok); }
.ob-modtile-ic.ic-warn { background: var(--warn-bg); color: var(--warn); }
.ob-modtile h3 { font-size: 15px; margin-bottom: 5px; }
.ob-modtile p { font-size: 12.5px; color: var(--rs-muted); line-height: 1.5; margin: 0 0 12px; }
.ob-modtile .ob-journey-link { margin-top: auto; font-size: 13px; }

/* ---- Industries + Deployment combined band ---- */
.ob-band2 { display: grid; grid-template-columns: 1.35fr 1fr; gap: 20px; }
.ob-band2-panel { background: var(--rs-surface); border: 1px solid var(--rs-border); border-radius: var(--r-lg); padding: 26px 24px; box-shadow: var(--sh-1); }
.ob-band2-panel h3 { font-size: 19px; margin-bottom: 18px; }
.ob-chips { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.ob-chip { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px; padding: 14px 8px; border: 1px solid var(--rs-border); border-radius: var(--r-md); font-size: 11.5px; font-weight: 600; color: var(--rs-navy); background: var(--rs-surface-2); }
.ob-chip svg { color: var(--rs-teal-logo); }
.ob-chip-more { color: var(--rs-blue-deep); }
.ob-chip-more:hover { text-decoration: none; border-color: var(--info-ring); background: var(--info-bg); }
.ob-deploy { display: flex; flex-direction: column; gap: 12px; }
.ob-deploy-card { display: grid; grid-template-columns: auto 1fr; column-gap: 12px; align-items: center; padding: 14px 16px; border: 1px solid var(--rs-border); border-radius: var(--r-md); background: var(--rs-surface-2); }
.ob-deploy-card:hover { text-decoration: none; border-color: var(--info-ring); box-shadow: var(--sh-1); }
.ob-deploy-ic { grid-row: span 2; display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 11px; background: var(--info-bg); color: var(--rs-blue); }
.ob-deploy-card b { font-size: 14px; color: var(--rs-navy); }
.ob-deploy-card i { font-style: normal; font-size: 12px; color: var(--rs-muted); }

/* ---- Responsive ---- */
@media (max-width: 1080px) {
    .ob-footer-grid { grid-template-columns: 1fr 1fr; }
    .ob-contact-grid { grid-template-columns: 1fr; }
    .ob-contact-aside { position: static; flex-direction: row; flex-wrap: wrap; }
    .ob-contact-aside .ob-contact-card { flex: 1 1 260px; }
    .ob-modrow { grid-template-columns: repeat(3, 1fr); }
    .ob-band2 { grid-template-columns: 1fr; }
}
@media (max-width: 920px) {
    .ob-hero-inner { grid-template-columns: 1fr; gap: 30px; padding: 56px 0 64px; }
    .ob-hero-art { order: -1; min-height: 300px; margin-inline: auto; }
    .ob-hero-copy h1, .ob-hero-light .ob-hero-copy h1 { font-size: 42px; }
    .ob-page-hero h1 { font-size: 32px; }
    .ob-grid-3, .ob-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .ob-hero-bgmark { display: none; }
    .ob-dash { max-width: 500px; }
    .ob-float-glance { right: 0; bottom: -14px; }
    .ob-float-mark { right: 0; }
    .ob-stats-items { margin-left: 0; }
    .ob-trust-strip { justify-content: flex-start; gap: 14px 22px; }
    .ob-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px) {
    .ob-nav { gap: 10px; }
    .ob-nav > a:not(.ob-nav-cta):not(.ob-nav-demo) { display: none; }
    .ob-nav-demo { display: none; }
    .ob-form-row, .ob-form-row-3 { grid-template-columns: 1fr; }
    .ob-grid-2, .ob-grid-3, .ob-grid-4 { grid-template-columns: 1fr; }
    .ob-modrow { grid-template-columns: repeat(2, 1fr); }
    .ob-chips { grid-template-columns: repeat(2, 1fr); }
    .ob-footer-grid { grid-template-columns: 1fr; }
    .ob-hero-copy h1, .ob-hero-light .ob-hero-copy h1 { font-size: 34px; }
    .ob-hero-art { min-height: 0; }
    .ob-float, .ob-float-mark { display: none; }   /* keep the phone hero clean */
    .ob-hero-cta .btn { flex: 1 1 100%; text-align: center; }
    .ob-trust-strip { flex-direction: column; align-items: flex-start; gap: 14px; }
    .ob-stats-inner { gap: 18px; }
    .ob-cta-inner { flex-direction: column; align-items: flex-start; }
    .ob-cta-actions { width: 100%; }
    .ob-cta-actions .btn { flex: 1 1 auto; text-align: center; }
}
