
:root {
  --navy: #0E1A2A;
  --navy-2: #142438;
  --teal: #1F6D73;
  --teal-soft: #E8F3F4;
  --slate: #5B6573;
  --ink-soft: #35465A;
  --mist: #F5F7FA;
  --white: #FFFFFF;
  --line: #D7E2E4;
  --line-strong: #C8D5D9;
  --success: #2A7C63;
  --gold: #B27B32;
  --shadow-card: 0 22px 40px rgba(14, 26, 42, 0.06);
  --shadow-soft: 0 12px 28px rgba(14, 26, 42, 0.05);
  --max: 1440px;
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 14px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--navy);
  background:
    radial-gradient(circle at 88% 10%, rgba(31, 109, 115, 0.07), transparent 0 18%),
    radial-gradient(circle at 16% 92%, rgba(31, 109, 115, 0.05), transparent 0 16%),
    linear-gradient(180deg, #FAFCFC 0%, #F3F7F8 100%);
  min-height: 100vh;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
.site-header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(16px);
  background: rgba(250, 252, 252, 0.88);
  border-bottom: 1px solid rgba(215, 226, 228, 0.72);
}
.container, .site-header .inner, .hero-shell, section, .footer-inner, .narrow-page {
  width: min(calc(100% - 48px), var(--max)); margin: 0 auto;
}
.narrow-page { max-width: 900px; }
.site-header .inner {
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:32px; padding:18px 0;
}
.wordmark { display:inline-flex; align-items:center; gap:14px; font-weight:800; font-size:24px; letter-spacing:-0.02em; color:var(--navy); }
.wordmark img, .wordmark svg { width:34px; height:34px; flex:0 0 auto; }
.wordmark.large img, .wordmark.large svg { width:44px; height:44px; }
.nav-links { display:flex; justify-content:center; gap:42px; color:var(--slate); font-weight:600; font-size:16px; }
.nav-links a { position:relative; }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-10px; width:100%; height:2px; background:var(--teal); transform:scaleX(0); transform-origin:left; transition:transform .2s ease; }
.nav-links a:hover::after, .nav-links a:focus-visible::after { transform:scaleX(1); }
.header-actions { display:flex; align-items:center; gap:12px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:56px; padding:0 26px; border-radius:18px; font-weight:700; font-size:17px; letter-spacing:-0.01em; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease; cursor:pointer; border:1px solid transparent; }
.btn:hover, .btn:focus-visible { transform:translateY(-1px); }
.btn-primary { background:var(--navy); color:var(--white); box-shadow:var(--shadow-soft); }
.btn-primary:hover, .btn-primary:focus-visible { box-shadow:0 18px 34px rgba(14, 26, 42, 0.12); }
.btn-secondary { background:rgba(255,255,255,0.94); color:var(--navy); border-color:var(--line); }
.btn-ghost { background:transparent; color:var(--navy); border-color:var(--line); }
.skip-link { position:absolute; left:16px; top:-48px; background:var(--navy); color:#fff; padding:10px 14px; border-radius:10px; z-index:100; }
.skip-link:focus { top:16px; }
.nav-toggle { display:none; background:transparent; border:1px solid var(--line); width:54px; height:54px; border-radius:16px; align-items:center; justify-content:center; }
.bars, .bars::before, .bars::after { display:block; width:20px; height:2px; background:var(--navy); border-radius:999px; position:relative; transition:.25s ease; }
.bars::before, .bars::after { content:""; position:absolute; left:0; }
.bars::before { top:-6px; }
.bars::after { top:6px; }
.nav-open .bars { background:transparent; }
.nav-open .bars::before { top:0; transform:rotate(45deg); }
.nav-open .bars::after { top:0; transform:rotate(-45deg); }
.mobile-nav-overlay { position:fixed; inset:0; background:rgba(14,26,42,.38); opacity:0; pointer-events:none; transition:.25s ease; z-index:45; }
.mobile-nav-shell { position:fixed; top:0; right:0; width:min(88vw, 420px); height:100dvh; background:rgba(250,252,252,0.98); border-left:1px solid var(--line); box-shadow:-18px 0 40px rgba(14,26,42,.12); transform:translateX(100%); transition:.28s ease; z-index:46; display:flex; flex-direction:column; gap:24px; padding:18px 18px 26px; }
.mobile-nav-top { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.mobile-nav-links { display:flex; flex-direction:column; gap:6px; }
.mobile-nav-links a { padding:14px 6px; border-bottom:1px solid rgba(215,226,228,.75); font-weight:700; }
.mobile-nav-note { padding:16px 18px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.8); color:var(--slate); line-height:1.55; font-size:14px; }
body.mobile-open { overflow:hidden; }
body.mobile-open .mobile-nav-shell { transform:translateX(0); }
body.mobile-open .mobile-nav-overlay { opacity:1; pointer-events:auto; }
.hero-shell { padding:44px 0 28px; }
.hero { display:grid; grid-template-columns:minmax(0,1.04fr) minmax(540px,0.96fr); gap:54px; align-items:center; }
.pill { display:inline-flex; align-items:center; gap:12px; padding:8px 16px; border-radius:999px; background:rgba(255,255,255,0.88); border:1px solid var(--line); color:var(--slate); font-size:13px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; }
.pill .dot { width:10px; height:10px; border-radius:999px; background:var(--teal); }
.hero h1 { margin:22px 0 24px; font-size:clamp(54px,7vw,82px); line-height:.96; letter-spacing:-0.055em; font-weight:780; max-width:720px; }
.hero-copy { font-size:clamp(22px,2.15vw,25px); line-height:1.5; color:var(--ink-soft); max-width:760px; margin:0 0 34px; }
.hero-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:28px; }
.hero-meta { max-width:780px; color:var(--slate); font-size:14px; line-height:1.8; }
.hero-meta strong { display:block; margin-bottom:8px; color:var(--slate); font-size:12px; letter-spacing:0.11em; text-transform:uppercase; }
.hero-meta span { font-size:15px; font-weight:700; color:var(--navy); }
.hero-visual-shell { padding:22px; border-radius:var(--radius-xl); background:rgba(255,255,255,0.54); border:1px solid rgba(215,226,228,0.8); box-shadow:var(--shadow-card); }
.hero-visual { border-radius:28px; overflow:hidden; }
.proof-strip { margin-top:28px; display:flex; align-items:center; justify-content:center; gap:26px; padding:24px 28px; border-radius:28px; background:rgba(255,255,255,0.7); border:1px solid var(--line); box-shadow:var(--shadow-soft); }
.proof-item { font-size:15px; font-weight:700; color:var(--navy); }
.proof-dot { width:8px; height:8px; border-radius:999px; background:var(--teal); flex:0 0 auto; }
section { padding:76px 0; }
section + section { border-top:1px solid rgba(215,226,228,0.42); }
.section-head { display:grid; grid-template-columns:minmax(0,1fr) minmax(320px,430px); gap:32px; align-items:end; margin-bottom:34px; }
.eyebrow { font-size:12px; letter-spacing:0.12em; text-transform:uppercase; font-weight:800; color:var(--teal); margin-bottom:10px; }
.section-head h2, .legal-hero h1 { margin:0; font-size:clamp(34px,4vw,50px); line-height:1.06; letter-spacing:-0.04em; }
.section-summary { color:var(--ink-soft); font-size:18px; line-height:1.65; }
.card, .position-card, .metric-card, .contact-card { background:rgba(255,255,255,0.82); border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow-soft); }
.problem-layout, .solution-band, .outcomes-shell { display:grid; gap:28px; }
.problem-layout { grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr); }
.fragment-list { display:grid; gap:16px; }
.fragment { padding:22px 24px; border-radius:20px; background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(245,247,250,.82)); border:1px solid var(--line); }
.fragment-label { font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--teal); font-weight:800; margin-bottom:8px; }
.fragment p, .ops-question p, .solution-copy p, .bridge-card p, .step-card p, .use-card p, .position-card p, .story-item, .contact-list div, .legal-body p, .legal-body li { margin:0; color:var(--ink-soft); line-height:1.72; font-size:16px; }
.ops-question { padding:30px; border-radius:28px; background:linear-gradient(180deg, var(--navy), var(--navy-2)); color:#fff; box-shadow:var(--shadow-card); }
.ops-question h3, .kpi-story h3, .contact-card strong, .bridge-card strong, .step-card h3, .use-card h3, .position-card h3, .metric-card .value { margin:0 0 12px; }
.ops-question h3, .kpi-story h3, .contact-card strong, .bridge-card strong, .step-card h3, .use-card h3, .position-card h3 { font-size:28px; line-height:1.14; letter-spacing:-0.03em; }
.pulse-grid { display:grid; gap:14px; margin-top:24px; }
.pulse { padding:18px 18px 16px; border-radius:20px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); }
.pulse strong { display:block; font-size:15px; margin-bottom:6px; }
.pulse span { color:rgba(255,255,255,.84); font-size:15px; line-height:1.55; }
.solution-band { grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr); align-items:stretch; }
.solution-copy { padding:30px; }
.logic-note { margin-top:22px; padding:18px 20px; border-radius:20px; background:var(--teal-soft); border:1px solid rgba(31,109,115,.14); color:var(--ink-soft); line-height:1.6; }
.logic-note strong { display:block; margin-bottom:4px; font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:var(--teal); }
.diagram-shell { padding:30px; background:rgba(255,255,255,.72); border:1px solid var(--line); border-radius:28px; }
.diagram-row { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:18px; }
.mini-pill { padding:10px 16px; border-radius:999px; border:1px solid var(--line); background:#fff; color:var(--slate); font-size:12px; text-transform:uppercase; letter-spacing:.08em; font-weight:800; }
.bridge { display:grid; grid-template-columns:minmax(0,1fr) 52px minmax(0,1fr); align-items:center; gap:12px; }
.bridge-card { padding:24px; border-radius:24px; border:1px solid var(--line); background:rgba(255,255,255,.9); min-height:220px; }
.bridge-card strong { display:block; font-size:20px; color:var(--navy); }
.flow-arrow { height:3px; border-radius:999px; background:linear-gradient(90deg, rgba(31,109,115,.18), rgba(31,109,115,.82), rgba(31,109,115,.18)); position:relative; }
.flow-arrow::after { content:""; position:absolute; right:-4px; top:-5px; width:13px; height:13px; border-top:3px solid var(--teal); border-right:3px solid var(--teal); transform:rotate(45deg); }
.three-cards, .use-case-grid, .position-grid, .metric-grid, .story-list { display:grid; gap:22px; }
.three-cards { grid-template-columns:repeat(3, minmax(0,1fr)); }
.step-card, .use-card, .position-card { padding:28px; }
.step-num { display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:14px; background:var(--teal-soft); color:var(--teal); font-weight:800; letter-spacing:.04em; margin-bottom:22px; }
.step-card h3, .use-card h3 { font-size:30px; }
.micro-list { margin-top:20px; display:grid; gap:10px; }
.micro-item { padding:12px 14px; border-radius:14px; background:rgba(245,247,250,.86); border:1px solid var(--line); font-size:14px; font-weight:600; color:var(--slate); }
.use-case-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
.tag-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.tag { padding:8px 12px; border-radius:999px; background:#fff; border:1px solid var(--line); color:var(--slate); font-size:12px; letter-spacing:.06em; text-transform:uppercase; font-weight:800; }
.outcomes-shell { grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr); align-items:start; }
.metric-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
.metric-card { padding:26px; min-height:240px; }
.metric-card .label { font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--slate); font-weight:800; margin-bottom:16px; }
.metric-card .value { font-size:54px; line-height:1; letter-spacing:-0.05em; margin-bottom:18px; }
.metric-card.teal .value { color:var(--teal); }
.metric-card.blue .value { color:var(--navy); }
.metric-card.green .value { color:var(--success); }
.metric-card.gold .value { color:var(--gold); }
.benchmark-note { margin-top:18px; padding:18px 22px; border-radius:18px; background:#fff; border:1px solid var(--line); color:var(--slate); line-height:1.6; }
.kpi-story { padding:30px; border-radius:28px; background:linear-gradient(180deg, var(--navy), var(--navy-2)); box-shadow:var(--shadow-card); color:#fff; }
.kpi-story p { color:rgba(255,255,255,.84); line-height:1.72; }
.story-list { margin-top:22px; }
.story-item { padding:18px; border-radius:18px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.84); }
.story-item strong { color:#fff; }
.position-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
.position-card { padding:28px; }
.position-card h3 { font-size:30px; }
.position-card ul, .legal-body ul { margin:18px 0 0 18px; padding:0; color:var(--ink-soft); line-height:1.8; }
.position-card.highlight { background:linear-gradient(180deg, rgba(31,109,115,.10), rgba(255,255,255,.96)); border-color:rgba(31,109,115,.18); }
.cta-shell { display:grid; grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr); gap:28px; padding:38px; border-radius:34px; background:linear-gradient(180deg, var(--navy), var(--navy-2)); box-shadow:var(--shadow-card); color:#fff; }
.cta-shell h2 { margin:0 0 16px; font-size:clamp(38px,4vw,54px); line-height:1.03; letter-spacing:-0.045em; }
.cta-shell p { color:rgba(255,255,255,.84); font-size:18px; line-height:1.72; }
.cta-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:24px; }
.contact-card { padding:28px; color:var(--navy); }
.contact-card strong { display:block; color:var(--navy); font-size:28px; }
.contact-list { display:grid; gap:18px; margin-top:14px; }
.form-grid { display:grid; gap:14px; margin-top:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.input { width:100%; border:1px solid var(--line); border-radius:16px; background:#fff; min-height:54px; padding:14px 16px; color:var(--navy); }
textarea.input { min-height:120px; resize:vertical; }
.input:focus { outline:2px solid rgba(31,109,115,.28); outline-offset:0; border-color:rgba(31,109,115,.35); }
.field-help { font-size:13px; color:var(--slate); line-height:1.5; }
.footer { padding:28px 0 44px; }
.footer-inner { display:flex; justify-content:space-between; gap:24px; padding-top:26px; border-top:1px solid rgba(215,226,228,.8); color:var(--slate); }
.footer-brand { max-width:620px; display:grid; gap:8px; font-size:14px; line-height:1.7; }
.footer-links { display:flex; flex-wrap:wrap; justify-content:flex-end; gap:16px 22px; font-size:14px; font-weight:600; }
.reveal { opacity:0; transform:translateY(24px); transition:opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.legal-hero { padding:64px 0 24px; }
.legal-hero p { font-size:19px; color:var(--ink-soft); max-width:800px; line-height:1.65; }
.legal-body { padding:20px 0 80px; display:grid; gap:22px; }
.legal-card { padding:28px; background:rgba(255,255,255,.82); border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow-soft); }
.legal-card h2 { margin:0 0 12px; font-size:28px; letter-spacing:-.03em; }
.legal-card h3 { margin:18px 0 10px; font-size:18px; }
.small-meta { color:var(--slate); font-size:14px; }
@media (max-width: 1140px) {
  .hero, .problem-layout, .solution-band, .outcomes-shell, .cta-shell { grid-template-columns:1fr; }
  .three-cards, .position-grid, .metric-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
  .bridge { grid-template-columns:1fr; }
  .flow-arrow { width:100%; min-height:34px; background:transparent; }
  .flow-arrow::after { left:50%; right:auto; top:12px; transform:translateX(-50%) rotate(135deg); }
}
@media (max-width: 940px) {
  .site-header .inner { grid-template-columns:auto auto; }
  .nav-links { display:none; }
  .nav-toggle { display:inline-flex; }
  .three-cards, .use-case-grid, .position-grid, .metric-grid, .form-row, .section-head { grid-template-columns:1fr; }
  .proof-strip { flex-direction:column; gap:14px; }
  .proof-dot { display:none; }
  section, .hero-shell, .legal-hero, .legal-body { padding-left:0; padding-right:0; }
  .mobile-only { display:inline-flex !important; }
}
@media (max-width: 720px) {
  .site-header .inner, .hero-shell, section, .footer-inner, .narrow-page { width:min(calc(100% - 28px), var(--max)); }
  .hero-shell { padding-top:28px; }
  .hero h1 { font-size: clamp(44px, 18vw, 62px); }
  .hero-copy { font-size: 18px; }
  .hero-visual-shell, .cta-shell { padding:16px; }
  .btn { min-height:52px; width:100%; }
  .hero-actions .btn, .cta-actions .btn { width:100%; }
  .metric-card .value { font-size:44px; }
  .contact-card, .position-card, .step-card, .use-card, .metric-card, .ops-question, .solution-copy, .legal-card { padding:22px; }
  .footer-inner { flex-direction:column; }
  .footer-links { justify-content:flex-start; }
}
