@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root{--harbor_surface:#ffffff;--harbor_surface-alt:#e8f1ff;--harbor_bg:#f5f9ff;--harbor_dark:#101b2c;--harbor_accent-soft:rgb(219,234,254);--harbor_accent:#2563eb;--harbor_text:#1a3154;--harbor_muted:#587198;--harbor_line:#c6d6ef}
body[data-theme='dark']{--harbor_accent-soft:rgba(255,255,255,.06);--harbor_accent:#2563eb;--harbor_line:#304155;--harbor_muted:#c6d0e4;--harbor_bg:var(--harbor_dark);--harbor_surface:#17212f;--harbor_surface-alt:#1f2b3c;--harbor_text:#f7f7fb}
*{box-sizing:border-box}html{scroll-behavior:smooth}body.hb-body{margin:0;color:var(--harbor_text);background:var(--harbor_bg);font-family:'Inter',sans-serif;pointer-events:auto;visibility:visible;isolation:auto}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.hb-wrap{margin:0 auto;width:min(1180px,calc(100% - 30px))}.hb-shell{padding:0 0 56px}.hb-kicker{letter-spacing:.12em;text-transform:uppercase;margin:0 0 10px;font-size:.84rem;font-weight:800;color:var(--harbor_accent)}.hb-lead,.hb-rich p,.hb-card p,.hb-listitem p,.hb-faq p{line-height:1.8;color:var(--harbor_muted)}
.hb-mast{top:0;backdrop-filter:blur(12px);background:color-mix(in srgb,var(--harbor_bg) 86%, transparent);border-bottom:1px solid var(--harbor_line);z-index:10;position:sticky}.hb-mast__inner{align-items:center;gap:18px;display:flex;justify-content:space-between;min-height:76px}.hb-mast__inner--split{padding:12px 0;display:grid;gap:10px;grid-template-columns:1fr}.hb-mast__row{grid-template-columns:auto 1fr auto;display:grid;align-items:center;gap:16px}.hb-eyebrow{color:var(--harbor_muted);font-size:.88rem;display:flex;gap:12px;justify-content:space-between}.hb-brand{font-weight:800;gap:10px;display:flex;align-items:center}.hb-brand img{max-height:38px;object-fit:contain;width:auto;max-width:180px}.hb-brand-square{background:#fff;border-radius:10px;width:32px;padding:4px;height:32px;border:1px solid var(--harbor_line)}.hb-nav{gap:10px 14px;display:flex;flex-wrap:wrap;justify-content:center}.hb-nav a{border-radius:999px;color:var(--harbor_muted);padding:8px 12px}.hb-nav a:hover,.hb-nav a[aria-current='page']{color:var(--harbor_text);background:var(--harbor_accent-soft)}.hb-toggle{cursor:pointer;border-radius:999px;background:var(--harbor_surface);border:1px solid var(--harbor_line);height:42px;color:var(--harbor_text);width:42px}
.hb-home,.hb-page{padding-top:24px;gap:28px;display:grid}.hb-hero{gap:18px;display:grid;border:1px solid var(--harbor_line);border-radius:30px;background:linear-gradient(180deg,var(--harbor_surface) 0%,var(--harbor_surface-alt) 100%);padding:28px}.hb-hero--manifest .hb-hero__main{display:grid;gap:10px}.hb-hero--alt .hb-hero__band{display:grid;gap:10px}.hb-hero__main h1,.hb-hero__band h1{letter-spacing:-.05em;font-size:clamp(2.5rem,5.4vw,4.8rem);line-height:1.02;margin:0;max-width:12ch}.hb-hero__side,.hb-hero__deck{gap:16px;display:grid}.hb-hero__actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.hb-button{padding:13px 18px;gap:8px;align-items:center;display:inline-flex;font-weight:700;justify-content:center;border-radius:999px}.hb-button--solid{background:var(--harbor_accent);color:rgb(255,255,255)}.hb-button--ghost{border:1px solid var(--harbor_line);background:transparent;color:var(--harbor_text)}.hb-chiprow{display:flex;flex-wrap:wrap;gap:10px}.hb-chiprow a,.hb-chiprow span{background:var(--harbor_accent-soft);color:var(--harbor_text);border-radius:999px;font-size:.92rem;padding:9px 12px}.hb-hero__media img,.hb-card--media img,.hb-bannerstrip img{width:100%;object-fit:cover;border-radius:22px;height:100%}.hb-bannerstrip{gap:12px;grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.hb-statstack,.hb-statband{gap:12px;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.hb-statcard{padding:16px;background:var(--harbor_surface);border-radius:22px;border:1px solid var(--harbor_line)}.hb-statcard strong{display:block;font-size:1.32rem}
.hb-section{display:grid;gap:16px}.hb-split{display:grid;gap:18px;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr)}.hb-section__head{align-items:end;justify-content:space-between;gap:16px;display:flex}.hb-section__head h2{margin:0;font-size:clamp(1.5rem,2.4vw,2.3rem)}.hb-grid{gap:16px;display:grid}.hb-grid--features,.hb-grid--catalog,.hb-grid--quotes{grid-template-columns:repeat(3,minmax(0,1fr))}.hb-grid--duo,.hb-grid--faq{grid-template-columns:repeat(2,minmax(0,1fr))}.hb-mediawall{gap:16px;grid-template-columns:1.15fr .85fr;display:grid}.hb-listboard{gap:14px;display:grid}.hb-listitem{gap:14px;align-items:start;display:grid;border:1px solid var(--harbor_line);border-radius:24px;grid-template-columns:auto 1fr;background:var(--harbor_surface);padding:18px}.hb-listitem__mark{height:42px;background:var(--harbor_accent-soft);display:grid;min-width:42px;border-radius:14px;font-weight:800;place-items:center;color:var(--harbor_accent)}
.hb-card{background:var(--harbor_surface);box-shadow:0 12px 30px rgba(15,23,42,.04);border:1px solid var(--harbor_line);padding:20px;border-radius:26px}.hb-card h2,.hb-card h3{margin:0 0 8px}.hb-card--story{padding:26px}.hb-card--rail{display:grid;align-content:start;background:var(--harbor_surface-alt);gap:12px}.hb-card--quote footer{justify-content:space-between;gap:12px;display:flex;color:var(--harbor_muted)}.hb-card--catalog small{color:var(--harbor_accent);font-weight:700}.hb-rail-link{border:1px solid var(--harbor_line);background:var(--harbor_surface);gap:4px;border-radius:18px;padding:14px 16px;display:grid}.hb-rail-link span{font-size:.9rem;color:var(--harbor_muted)}
.hb-faq{gap:12px;display:grid}.hb-faq__item{border:1px solid var(--harbor_line);overflow:hidden;padding:0;border-radius:22px;background:var(--harbor_surface)}.hb-faq__item summary{list-style:none;cursor:pointer;font-weight:700;padding:18px 20px}.hb-faq__item p{padding:0 20px 18px;margin:0}.hb-faq__item--open{border-color:var(--harbor_accent)}
.hb-convert{gap:16px;display:grid;border:1px solid var(--harbor_line);background:linear-gradient(135deg,var(--harbor_surface) 0%,var(--harbor_accent-soft) 100%);border-radius:28px;padding:24px}.hb-convert--v1{align-items:end;grid-template-columns:minmax(200px,1fr) minmax(min-content,44%)}.hb-convert--v2{align-items:center;grid-template-columns:1fr auto}.hb-convert__frame{gap:8px;display:grid}.hb-convert__actions{display:grid;justify-items:end;gap:8px}.hb-convert h2{font-size:clamp(1.6rem,2.8vw,2.5rem);margin:0}.hb-convert__hint{font-size:.9rem;color:var(--harbor_muted)}
.hb-footer{border-top:1px solid var(--harbor_line);padding:18px 0 28px}.hb-footer__grid{display:grid;gap:18px;grid-template-columns:1.1fr .9fr .8fr;align-items:start}.hb-footer__bar{gap:16px;display:grid;align-items:center;grid-template-columns:1fr 1fr auto}.hb-footer__nav,.hb-linkstack{flex-wrap:wrap;display:flex;gap:10px 14px}.hb-footer p,.hb-footer__meta{color:var(--harbor_muted)}
.hb-family-b .hb-hero{border-radius:34px}.hb-family-b .hb-card{border-radius:30px}.hb-family-b .hb-split{grid-template-columns:.92fr 1.08fr}.hb-family-b .hb-grid--features{grid-template-columns:repeat(2,minmax(0,1fr))}.hb-family-b .hb-mediawall{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:960px){.hb-grid--features,.hb-grid--catalog,.hb-grid--quotes,.hb-grid--duo,.hb-grid--faq,.hb-footer__grid,.hb-footer__bar,.hb-convert--v1,.hb-convert--v2{grid-template-columns:1fr}.hb-split,.hb-mast__row,.hb-mediawall{grid-template-columns:1fr}.hb-hero__main h1,.hb-hero__band h1{max-width:none}.hb-bannerstrip{grid-template-columns:1fr}}
@media (max-width:720px){.hb-mast__inner{flex-direction:column;padding:10px 0;align-items:flex-start;min-height:auto}.hb-nav{display:none}.hb-hero{padding:22px}.hb-wrap{width:min(100%,calc(100% - 22px))}.hb-button{width:100%}.hb-hero__actions{display:grid}.hb-eyebrow{display:grid}}

/* siteforge-mobile-safety: common overflow + mobile guardrails */
html,body{overflow-x:hidden}
img{max-width:100%;height:auto}
:where(p,li,dd,dt,blockquote,figcaption,small,span,strong,em,a){word-break:break-word;overflow-wrap:break-word}
:where(h1,h2,h3,h4,h5,h6){hyphens:none;overflow-wrap:break-word;word-break:normal}
:where(main,section,article,aside,nav,header,footer,div,[class*='hero'],[class*='card'],[class*='panel'],[class*='grid'],[class*='split'],[class*='rail'],[class*='footer']){min-width:0}
:where([class*='rich'],[class*='lead'],[class*='copy'],[class*='content'],[class*='summary'],[class*='deck'],[class*='meta'],[class*='rail'],[class*='card'],[class*='panel'])>*{max-width:100%}
:where(pre,code,kbd,samp){white-space:pre-wrap;word-break:break-word}
.sf-footer-outbound,.sf-footer-outbound *,.sf-footer-outbound a{overflow-wrap:anywhere;word-break:break-word}
@media (max-width:760px){
  :where([class*='hero'],[class*='pagehero'],[class*='pagehead'],[class*='overview'],[class*='split'],[class*='twoaxis'],[class*='convert'],[class*='callout'],[class*='dashboard'],[class*='workspace'],[class*='footer__strip'],[class*='mediawall'],[class*='bannerstrip'],[class*='gallery'],[class*='ribbon'],[class*='hero__body'],[class*='hero__deck'],[class*='hero__split']){grid-template-columns:1fr !important}
  :where([class*='hero__actions'],[class*='actions'])>*{width:100%;max-width:100%}
  :where([class*='footer__lead'],[class*='footer__summary'],[class*='brandcard'],[class*='row']){flex-direction:column;align-items:flex-start}
  :where([class*='nav__logo'] img,[class*='footer__logo'],[class*='footer__logo'] img){max-width:min(100%,160px);max-height:40px;height:auto;width:auto}
  :where([class*='hero__logo'],[class*='pagehero__logo'],[class*='hero__seal'],[class*='footer__brand'],[class*='brand__square']){max-width:min(100%,96px);max-height:96px}
  :where([class*='hero__media'],[class*='hero__frame'],[class*='inline-media'],[class*='gallery__item'],[class*='mediawall__item'],[class*='banner'],[class*='monitor']){max-width:100%;overflow:hidden}
}

/* siteforge-square-logo-sizing: keep square brand marks visible across themes */
:where([class*='hero__logo'],[class*='pagehero__logo'],[class*='hero__seal'],[class*='brand__square']){overflow:visible !important;background:transparent !important;box-shadow:none !important;height:clamp(110px,16vw,160px) !important;padding:6px !important;border:none !important;width:clamp(110px,16vw,160px) !important}
:where([class*='footer__brand']){background:transparent !important;height:clamp(96px,12vw,130px) !important;padding:5px !important;box-shadow:none !important;overflow:visible !important;border:none !important;width:clamp(96px,12vw,130px) !important}
:where([class*='hero__logo'] img,[class*='pagehero__logo'] img,[class*='hero__seal'] img,[class*='brand__square'] img,[class*='footer__brand'] img){height:100% !important;max-width:none !important;max-height:none !important;object-fit:contain !important;width:100% !important}
@media (max-width:760px){
  :where([class*='hero__logo'],[class*='pagehero__logo'],[class*='hero__seal'],[class*='brand__square']){max-height:none !important;height:clamp(88px,26vw,120px) !important;max-width:none !important;width:clamp(88px,26vw,120px) !important}
  :where([class*='footer__brand']){max-width:none !important;max-height:none !important;height:clamp(80px,22vw,110px) !important;width:clamp(80px,22vw,110px) !important}
}


/* siteforge-sticky-cta: persistent floating action for platform/login access */
.sf-sticky-cta{background:rgba(10,15,27,.88);border:1px solid rgba(255,255,255,.14);gap:12px;align-items:center;bottom:16px;right:16px;box-shadow:0 18px 45px rgba(0,0,0,.3);position:fixed;padding:12px 14px;max-width:min(420px,calc(100vw - 24px));z-index:95;display:flex;border-radius:18px;backdrop-filter:blur(14px)}
.sf-sticky-cta__meta{color:#f0f4ff;display:grid;gap:2px;min-width:0}
.sf-sticky-cta__meta strong{font-size:.95rem;line-height:1.1}
.sf-sticky-cta__meta span{opacity:.72;overflow:hidden;text-overflow:ellipsis;font-size:.78rem;white-space:nowrap}
.sf-sticky-cta__button{white-space:nowrap;text-align:center;line-height:1.25;overflow:hidden;padding:.9rem 1.15rem;border-radius:14px;font-weight:800;max-width:260px;background:linear-gradient(135deg,#2dd4bf,#60a5fa);display:inline-flex;box-shadow:0 10px 24px rgba(96,165,250,.26);align-items:center;justify-content:center;text-overflow:ellipsis;color:#04111f !important}
.sf-sticky-cta__button:hover,.sf-sticky-cta__button:focus-visible{transform:translateY(-1px);filter:saturate(1.08)}
.sf-sticky-cta__button:focus-visible{outline-offset:2px;outline:2px solid rgba(255,255,255,.8)}
@media (min-width:761px){.sf-sticky-cta{padding:10px 12px}.sf-sticky-cta__meta span{display:none}}
@media (max-width:760px){.sf-has-sticky-cta .hb-shell{padding-bottom:calc(128px + env(safe-area-inset-bottom,0px))}.sf-sticky-cta{right:12px;border-radius:16px;padding:10px 10px 10px 12px;max-width:none;bottom:max(12px,env(safe-area-inset-bottom,0px));left:12px}.sf-sticky-cta__meta{flex:1}.sf-sticky-cta__button{min-width:0;padding:.95rem 1rem;flex:1}}

/* siteforge-theme-refresh-harbor: dock structure + stronger action contrast */
:root{--harbor_ghost_text:#15346c;--harbor_ghost_bg:#ffffff;--harbor_ghost_border:rgba(29,78,216,1);--harbor_button_shadow:0 16px 34px rgba(15,52,113,.28);--harbor_panel:rgba(237,244,255,1);--harbor_sticky_bg:rgba(9,24,45,.95);--harbor_footer_bg:#10233d;--harbor_footer_text:rgb(215,229,255)}
body[data-theme='dark']{--harbor_ghost_bg:rgba(255,255,255,.06);--harbor_panel:#13243d;--harbor_ghost_text:#eff6ff;--harbor_ghost_border:#93c5fd;--harbor_footer_text:#dbeafe;--harbor_footer_bg:#0a1526;--harbor_sticky_bg:rgba(5,14,27,.97)}
.hb-home,.hb-page{gap:24px}.hb-grid{gap:14px}.hb-card{border-radius:22px}
.hb-mast__row--dock{grid-template-columns:auto minmax(0,1fr) auto;gap:18px}
.hb-eyebrow--dock{border:1px solid color-mix(in srgb,var(--harbor_accent) 18%, var(--harbor_line));border-radius:16px;background:color-mix(in srgb,var(--harbor_surface) 78%, var(--harbor_accent-soft));font-weight:600;padding:10px 14px}
.hb-nav--dock{justify-content:flex-start}.hb-mast__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;align-items:center}
.hb-button{min-height:48px;letter-spacing:.01em}
.hb-button--solid{background:linear-gradient(135deg,#15346c,#2563eb);color:#ffffff;box-shadow:var(--harbor_button_shadow)}
.hb-button--solid:hover,.hb-button--solid:focus-visible{transform:translateY(-1px);filter:brightness(1.04)}
.hb-button--ghost{border:1.5px solid var(--harbor_ghost_border);background:var(--harbor_ghost_bg);box-shadow:0 8px 20px rgba(21,52,108,.08);color:var(--harbor_ghost_text)}
.hb-button--ghost:hover,.hb-button--ghost:focus-visible{border-color:#2563eb;color:#102a57;background:color-mix(in srgb,var(--harbor_accent-soft) 80%, white)}
.hb-hero--dock{padding:30px;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);border-radius:28px;gap:20px;align-items:stretch;background:linear-gradient(135deg,#fff 0%,#f3f8ff 45%,#e5f0ff 100%)}
.hb-hero__main--dock{gap:14px;display:grid;align-content:start}
.hb-chiprow--dock a{font-weight:600;border:1px solid color-mix(in srgb,var(--harbor_accent) 22%, var(--harbor_line));background:#fff;color:#12396d}
.hb-hero__side--dock{display:grid;grid-template-rows:auto 1fr;gap:14px}
.hb-card--dockpanel{border:1px solid color-mix(in srgb,var(--harbor_accent) 24%, var(--harbor_line));background:var(--harbor_panel);gap:14px;display:grid}
.hb-statstack--dock{grid-template-columns:repeat(3,minmax(0,1fr))}
.hb-hero--dock-alt{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:stretch}
.hb-hero__band--dock,.hb-hero__deck--dock{align-content:start;gap:14px;display:grid}
.hb-bannerstrip--dock{grid-template-columns:1.35fr .8fr .8fr}
.hb-convert--dock{align-items:stretch;background:linear-gradient(135deg,#f8fbff 0%,#e2edff 100%);grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr)}
.hb-linkstack--dock a{padding:10px 12px;background:#fff;border:1px solid color-mix(in srgb,var(--harbor_accent) 18%, var(--harbor_line));border-radius:14px}
.hb-convert__actions--dock{justify-items:stretch;align-content:center}
.hb-footer--dock{border-top:none;color:var(--harbor_footer_text);padding:28px 0 34px;background:var(--harbor_footer_bg)}
.hb-footer--dock .hb-kicker{color:rgba(147,197,253,1)}
.hb-footer--dock p,.hb-footer--dock a,.hb-footer--dock .hb-footer__meta{color:var(--harbor_footer_text)}
.hb-footer__grid--dock{grid-template-columns:1.2fr .85fr .85fr .8fr}
.hb-footer--dock .hb-linkstack a{padding:8px 0;border-bottom:1px solid rgba(147,197,253,.12)}
.hb-footer--dock .hb-button--ghost{border-color:#93c5fd;color:rgba(239,246,255,1);background:rgba(255,255,255,.08)}
.sf-sticky-cta{background:var(--harbor_sticky_bg);border-color:rgba(147,197,253,.26);color:rgba(239,246,255,1)}
.sf-sticky-cta__meta strong{color:rgba(255,255,255,1)}.sf-sticky-cta__meta span{color:rgba(219,234,254,.84);opacity:1}
.sf-sticky-cta__button{box-shadow:0 12px 26px rgba(37,99,235,.3);color:#fff !important;background:linear-gradient(135deg,#1d4ed8,#2563eb)}
@media (max-width:960px){.hb-hero--dock,.hb-hero--dock-alt,.hb-convert--dock,.hb-footer__grid--dock{grid-template-columns:1fr}.hb-statstack--dock{grid-template-columns:1fr}.hb-bannerstrip--dock{grid-template-columns:1fr}.hb-mast__row--dock{grid-template-columns:1fr}}
.hb-family-a,.hb-mast--v1,.hb-footer--v1,.hb-footer__brand,.hb-footer__brandblock,.hb-footer__logo,.hb-hero__actions--dock,.hb-section--pagebody{}

/* siteforge-footer-overlap-guard: stable mobile footer layout + sticky CTA clearance */
:where(footer,[class*='-footer']){z-index:1;overflow:visible;position:relative}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){min-width:0}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar'])>*{max-width:100%;min-width:0}
:where([class*='footer__brandblock'],[class*='footer__summary'],[class*='footer__meta'],[class*='footer__copy'],[class*='footer__warn'],[class*='linkstack']){overflow-wrap:anywhere;word-break:break-word}
@media(max-width:760px){
  .sf-has-sticky-cta :where([class*='-shell']),.sf-has-sticky-cta main{padding-bottom:calc(140px + env(safe-area-inset-bottom,0px)) !important}
  .sf-has-sticky-cta main~footer,.sf-has-sticky-cta :where(footer,[class$='-footer']){padding-bottom:calc(112px + env(safe-area-inset-bottom,0px)) !important}
  :where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){grid-template-columns:1fr !important;gap:16px !important;align-items:start !important;display:grid !important}
  :where([class*='footer__summary'],[class*='footer__bottom']){gap:10px;align-items:flex-start;display:flex;text-align:left;flex-direction:column}
  :where([class*='footer__brand']){clear:both;margin-bottom:12px;max-height:110px;float:none !important;max-width:110px}
}
