:root { color: #0a2540; background: #f6f9fc; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; --ink: #0a2540; --muted: #425466; --blue: #635bff; --cyan: #00d4ff; --line: #d6e0ea; --surface: #ffffff; --green: #00a876; --navy: #0a2540; --shadow: 0 24px 60px rgb(10 37 64 / 10%); }
      * { box-sizing: border-box; }
      body { margin: 0; min-width: 320px; color: var(--ink); background: #f6f9fc; line-height: 1.62; overflow-x: hidden; }
      main, header, footer, section, table, .answer, .private, .readiness, .summary-grid, .evidence, .evidence-grid, .next-actions, .status-rail { min-width: 0; max-width: 100%; }
      body::before { content: ""; position: absolute; inset: 0 0 auto; z-index: -1; height: 360px; background: linear-gradient(180deg, #ffffff, #eef3ff 70%, transparent); }
      a { color: inherit; }
      .skip-link { position: fixed; left: 18px; top: 18px; z-index: 10; transform: translateY(-140%); border-radius: 999px; background: var(--navy); color: #fff; padding: 10px 14px; }
      .skip-link:focus { transform: translateY(0); }
      :focus-visible { outline: 3px solid var(--cyan); outline-offset: 4px; }
      header, main, footer { width: 100%; max-width: 1120px; margin: 0 auto; padding: 28px; }
      .site-header { position: sticky; top: 0; z-index: 5; padding-top: 18px; padding-bottom: 18px; backdrop-filter: blur(18px); }
      .header-shell { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 18px; align-items: center; border: 1px solid rgb(214 224 234 / 72%); border-radius: 18px; background: rgb(255 255 255 / 82%); padding: 10px; box-shadow: 0 14px 44px rgb(10 37 64 / 8%); }
      .brand { display: inline-flex; align-items: center; gap: 10px; min-width: max-content; color: var(--navy); font-weight: 900; text-decoration: none; }
      .brand img { width: 34px; height: 34px; border-radius: 10px; box-shadow: 0 10px 24px rgb(0 212 255 / 18%); }
      nav { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; justify-content: center; min-width: 0; overflow: visible; }
      nav::-webkit-scrollbar { display: none; }
      nav a, .pill { display: inline-flex; align-items: center; justify-content: center; min-height: 40px; border-radius: 999px; padding: 0 12px; color: #0a2540; font-size: .92rem; font-weight: 800; text-decoration: none; white-space: nowrap; }
      nav a:hover, .header-actions a:hover, .summary-grid a:hover, .evidence-grid a:hover { transform: translateY(-1px); }
      .header-actions { display: flex; gap: 8px; align-items: center; justify-content: flex-end; min-width: max-content; }
      .header-actions a, .hero-actions a { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; border-radius: 999px; padding: 0 16px; font-weight: 900; text-decoration: none; white-space: nowrap; transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease; }
      .header-actions .login { color: var(--navy); }
      .header-actions .secondary-cta, .hero-actions .secondary-cta { color: var(--blue); background: #fff; box-shadow: inset 0 0 0 1px rgb(99 91 255 / 22%); }
      .header-actions .cta, .hero-actions .cta { color: #fff; background: var(--navy); box-shadow: 0 14px 28px rgb(10 37 64 / 18%); }
      .hero { padding: clamp(34px, 6vw, 78px) 0 28px; }
      h1 { max-width: 18ch; margin: 0 0 22px; font-size: clamp(2.65rem, 5vw, 4.4rem); line-height: 1; letter-spacing: 0; overflow-wrap: normal; word-break: normal; }
      h2 { margin-top: 2.6rem; color: #0a2540; font-size: clamp(1.7rem, 3vw, 2.5rem); line-height: 1.05; letter-spacing: 0; }
      h2, h3, p, li, strong, td, th, a { overflow-wrap: anywhere; }
      p, li { color: var(--muted); }
      .meta { max-width: 840px; color: rgb(10 37 64 / 72%); font-weight: 750; }
      .hero-lede { max-width: 760px; font-size: clamp(1.08rem, 2vw, 1.28rem); color: var(--muted); }
      .hero-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 26px 0 18px; }
      .proof-strip { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; max-width: 850px; margin: 0 0 26px; padding: 0; list-style: none; }
      .proof-strip li { display: inline-flex; align-items: center; min-height: 34px; border: 1px solid rgb(214 224 234 / 78%); border-radius: 999px; background: rgb(255 255 255 / 82%); padding: 0 11px; color: var(--navy); font-size: .86rem; font-weight: 850; }
      .proof-strip li::before { content: ""; width: 7px; height: 7px; margin-right: 8px; border-radius: 999px; background: var(--green); box-shadow: 0 0 0 4px rgb(0 168 118 / 12%); }
      .status-rail { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; margin: 22px 0 34px; overflow: hidden; border: 1px solid rgb(214 224 234 / 76%); border-radius: 18px; background: var(--line); box-shadow: var(--shadow); }
      .status-rail div { min-height: 92px; background: rgb(255 255 255 / 94%); padding: 16px; }
      .status-rail span, .eyebrow { display: block; color: var(--blue); font-size: .76rem; font-weight: 900; text-transform: uppercase; }
      .status-rail strong { display: block; margin-top: 6px; color: var(--navy); line-height: 1.2; }
      .answer, .private, .readiness, .evidence, .next-actions, table, .summary-grid a { border: 1px solid rgb(214 224 234 / 76%); border-radius: 18px; background: rgb(255 255 255 / 92%); box-shadow: var(--shadow); }
      .answer, .private, .readiness, .evidence, .next-actions { padding: 24px; }
      .answer { background: linear-gradient(180deg, rgb(255 255 255 / 96%), rgb(246 249 252 / 96%)); }
      .decision-panel { display: grid; gap: 20px; margin: 28px 0; border: 1px solid rgb(214 224 234 / 76%); border-radius: 24px; background: linear-gradient(180deg, rgb(255 255 255 / 96%), rgb(246 249 252 / 94%)); padding: clamp(22px, 4vw, 34px); box-shadow: var(--shadow); }
      .decision-panel h2 { max-width: 14ch; margin-top: 0; }
      .package-grid, .control-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
      .package-grid article, .control-grid article, .architecture-map div, .decision-steps div { border: 1px solid rgb(214 224 234 / 78%); border-radius: 16px; background: #fff; padding: 16px; }
      .package-grid article:nth-child(2) { border-color: rgb(99 91 255 / 34%); box-shadow: 0 18px 38px rgb(99 91 255 / 10%); }
      .package-grid span, .architecture-map span { color: var(--blue); font-size: .78rem; font-weight: 900; text-transform: uppercase; }
      .package-grid h3, .control-grid h3 { margin: 8px 0; color: var(--navy); line-height: 1.12; }
      .package-grid ul { margin: 12px 0 0; padding-left: 18px; }
      .decision-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
      .decision-steps strong { display: inline-grid; width: 32px; height: 32px; place-items: center; border-radius: 999px; background: var(--navy); color: white; }
      .decision-steps span { display: block; margin-top: 10px; color: var(--navy); font-weight: 900; }
      .architecture-map { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; align-items: stretch; }
      .architecture-map div { position: relative; min-height: 112px; background: linear-gradient(180deg, #fff, #f6f9fc); }
      .architecture-map div:not(:last-child)::after { content: "→"; position: absolute; right: -10px; top: 42%; z-index: 2; color: var(--blue); font-weight: 900; }
      .architecture-map strong { display: block; margin-top: 8px; color: var(--navy); line-height: 1.15; }
      .control-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
      .access-decision { grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr); align-items: center; }
      .access-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
      .access-grid article { min-height: 172px; border: 1px solid rgb(214 224 234 / 78%); border-radius: 18px; background: linear-gradient(180deg, #fff, #f6f9fc); padding: 18px; box-shadow: 0 16px 34px rgb(10 37 64 / 7%); }
      .access-grid span { color: var(--blue); font-size: .76rem; font-weight: 900; text-transform: uppercase; }
      .access-grid strong { display: block; margin: 10px 0 8px; color: var(--navy); font-size: 1.04rem; line-height: 1.14; }
      .access-grid p { margin: 0; font-size: .95rem; }
      .category-grid, .comparison-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
      .category-grid article, .comparison-grid article { min-height: 176px; border: 1px solid rgb(214 224 234 / 78%); border-radius: 18px; background: linear-gradient(180deg, #fff, #f6f9fc); padding: 18px; box-shadow: 0 16px 34px rgb(10 37 64 / 7%); }
      .comparison-grid article:nth-child(2), .category-grid article:nth-child(2) { border-color: rgb(99 91 255 / 32%); box-shadow: 0 18px 38px rgb(99 91 255 / 10%); }
      .category-grid span, .comparison-grid span { color: var(--blue); font-size: .76rem; font-weight: 900; text-transform: uppercase; }
      .category-grid strong, .comparison-grid strong { display: block; margin: 10px 0 8px; color: var(--navy); font-size: 1.05rem; line-height: 1.14; }
      .category-grid p, .comparison-grid p { margin: 0; font-size: .95rem; }
      .product-surface { display: grid; grid-template-columns: minmax(0, .82fr) minmax(340px, 1.18fr); gap: 22px; align-items: stretch; margin: 30px 0; border: 1px solid rgb(214 224 234 / 76%); border-radius: 26px; background: linear-gradient(135deg, #ffffff, #f3f7fb); padding: clamp(22px, 4vw, 34px); box-shadow: var(--shadow); }
      .product-surface h2 { margin-top: 0; max-width: 15ch; }
      .product-workspace { overflow: hidden; border: 1px solid rgb(214 224 234 / 78%); border-radius: 20px; background: #0a2540; box-shadow: 0 22px 46px rgb(10 37 64 / 18%); }
      .workspace-topbar { display: flex; justify-content: space-between; gap: 12px; align-items: center; min-height: 48px; border-bottom: 1px solid rgb(255 255 255 / 10%); padding: 0 16px; color: white; }
      .workspace-topbar span { font-weight: 900; }
      .workspace-topbar strong { color: #9ee8ff; font-size: .82rem; text-transform: uppercase; }
      .workspace-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px; background: rgb(255 255 255 / 10%); }
      .workspace-grid article { min-height: 204px; background: linear-gradient(180deg, #102f55, #0a2540); padding: 18px; }
      .workspace-grid article span { color: #9ee8ff; font-size: .76rem; font-weight: 900; text-transform: uppercase; }
      .workspace-grid article strong { display: block; margin: 12px 0 8px; color: white; font-size: 1.05rem; line-height: 1.14; }
      .workspace-grid article p { color: rgb(255 255 255 / 76%); font-size: .92rem; }
      .workspace-meter { height: 8px; margin-top: 18px; overflow: hidden; border-radius: 999px; background: rgb(255 255 255 / 12%); }
      .workspace-meter i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #00d4ff, #635bff); }
      .private { background: linear-gradient(135deg, #0a2540, #253a80); }
      .private h2, .private p { color: white; }
      .evidence { display: grid; grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr); gap: 24px; align-items: start; margin-top: 28px; }
      .evidence h2, .next-actions h2 { margin-top: 0; }
      .evidence-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
      .evidence-grid a { display: flex; align-items: center; justify-content: space-between; gap: 10px; min-height: 48px; border: 1px solid rgb(214 224 234 / 84%); border-radius: 12px; background: #fff; padding: 10px 12px; color: var(--navy); font-weight: 850; text-decoration: none; }
      .evidence-grid span { color: var(--blue); font-size: 1.2rem; }
      .next-actions { margin-top: 28px; }
      .next-actions ol { margin-bottom: 0; }
      table { display: block; width: 100%; overflow-x: auto; border-collapse: collapse; }
      th, td { border-top: 1px solid var(--line); padding: 12px; text-align: left; vertical-align: top; }
      th { border-top: 0; color: #0a2540; }
      .summary-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 32px; }
      .summary-grid a { min-height: 88px; padding: 16px; color: #0a2540; font-weight: 850; text-decoration: none; }
      footer { display: flex; justify-content: space-between; gap: 18px; border-top: 1px solid var(--line); }
      footer a { display: inline-flex; align-items: center; min-height: 44px; }
      @media (max-width: 760px) { header, main, footer { padding: 20px; } nav { gap: 10px; } nav a, .pill { max-width: 100%; padding: 0 12px; } h1 { max-width: 100%; font-size: clamp(2.35rem, 10vw, 3rem); } h2 { font-size: clamp(1.55rem, 7vw, 2rem); } .status-rail, .evidence, .evidence-grid, .summary-grid { grid-template-columns: 1fr; } .answer, .private, .readiness, .evidence, .next-actions { padding: 20px; } footer { flex-direction: column; } }
