:root {
  --navy: #062b73;
  --navy2: #0b1f4d;
  --green: #10b76f;
  --fresh: #7ed957;
  --mint: #dff6ec;
  --pale: #f5f7fa;
  --ink: #1d2b4f;
  --muted: #66758f;
  --line: #d8e6e4;
  --white: #fff;
  --shadow: 0 20px 44px rgba(6, 43, 115, .12);
  font-family: "Noto Sans JP", "Yu Gothic", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: white; font-weight: 700; letter-spacing: 0; padding-bottom: 88px; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
[hidden] { display: none !important; }

@media (prefers-reduced-motion: no-preference) {
  .anim-fade-up { opacity: 0; transform: translate3d(0, 16px, 0); transition: opacity .65s cubic-bezier(.16,.84,.44,1), transform .65s cubic-bezier(.16,.84,.44,1); will-change: opacity, transform; }
  .anim-fade-up.is-in { opacity: 1; transform: none; }
  .anim-stagger > * { opacity: 0; transform: translate3d(0, 14px, 0); transition: opacity .55s ease-out, transform .55s ease-out; }
  .anim-stagger.is-in > * { opacity: 1; transform: none; }
  .anim-stagger.is-in > *:nth-child(1) { transition-delay: 0ms; }
  .anim-stagger.is-in > *:nth-child(2) { transition-delay: 70ms; }
  .anim-stagger.is-in > *:nth-child(3) { transition-delay: 140ms; }
  .anim-stagger.is-in > *:nth-child(4) { transition-delay: 210ms; }
  .anim-stagger.is-in > *:nth-child(5) { transition-delay: 280ms; }
  .anim-stagger.is-in > *:nth-child(6) { transition-delay: 350ms; }
  .anim-stagger.is-in > *:nth-child(7) { transition-delay: 420ms; }
}

.header {
  position: fixed; z-index: 50; top: 22px; left: 50%; transform: translateX(-50%);
  width: min(1280px, calc(100% - 96px)); height: 78px; padding: 0 26px;
  display: flex; align-items: center; gap: 28px; background: rgba(255,255,255,.96);
  border: 1px solid rgba(207,225,223,.9); border-radius: 10px; box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.logo { display: flex; align-items: center; width: 190px; height: 48px; }
.logo img { width: auto; height: 48px; object-fit: contain; }
.nav { margin-left: auto; display: flex; gap: 26px; font-size: 15px; color: var(--ink); }
.nav a { white-space: nowrap; }
.header-cta { display: flex; gap: 10px; }
.btn { height: 46px; display: inline-flex; align-items: center; justify-content: center; padding: 0 20px; border-radius: 999px; color: white; font-weight: 900; font-size: 14px; white-space: nowrap; }
.btn-green { background: var(--green); }
.btn-dark { background: var(--navy2); }
.menu { display: none; }

.hero {
  min-height: 860px; position: relative; overflow: hidden; background: white;
}
.hero-bg {
  position: absolute; inset: 0;
  background-color: #fff;
  background-image: url("assets/generated/hero-org-img2.png");
  background-repeat: no-repeat;
  background-size: auto 82%;
  background-position: calc(50% + 220px) center;
}
.hero-bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,.96) 36%, rgba(255,255,255,.5) 48%, rgba(255,255,255,0) 62%);
  pointer-events: none;
}
.hero-inner { position: relative; width: min(1220px, calc(100% - 120px)); margin: 0 auto; padding-top: 168px; }
.hero-copy { width: min(610px, 100%); }
.eyebrow { margin: 0 0 22px; font-size: 15px; color: var(--green); letter-spacing: .04em; font-weight: 950; }
.eyebrow.navy { color: var(--green); }
.hero h1 { margin: 0; font-size: 60px; line-height: 1.25; font-weight: 950; letter-spacing: 0; color: var(--navy2); }
.hero h1 span, .section-head h2 span, .compare h2 span, .scope h2 span, .system h2 span, .features h2 span, .contact h2 span { color: var(--green); }
.lead { margin: 26px 0 0; font-size: 19px; line-height: 1.95; color: var(--ink); }
.hero-actions { margin-top: 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: end; width: min(760px, 100%); }

.mega-btn { position: relative; display: flex; align-items: center; justify-content: center; min-height: 78px; border-radius: 999px; padding: 18px 72px 14px 42px; box-shadow: var(--shadow); }
.mega-btn small { position: absolute; top: -22px; left: 50%; transform: translateX(-50%); min-width: 250px; height: 38px; border: 2px solid currentColor; border-radius: 999px; background: white; display: grid; place-items: center; font-size: 13px; color: inherit; }
.mega-btn small::after { content: ""; position: absolute; bottom: -8px; width: 14px; height: 14px; background: white; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg); }
.mega-btn b { font-size: 21px; letter-spacing: 0; white-space: nowrap; }
.mega-btn em { position: absolute; right: 28px; font-size: 34px; font-style: normal; line-height: 1; }
.mega-btn.green { background: var(--green); color: white; }
.mega-btn.green small { color: var(--green); }
.mega-btn.white { background: white; color: var(--navy); border: 2px solid var(--navy); }

.proof-strip { width: min(1280px, calc(100% - 96px)); margin: -40px auto 0; position: relative; z-index: 2; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; background: white; border: 1px solid var(--line); border-radius: 12px; padding: 22px; box-shadow: var(--shadow); }
.proof-strip div { padding: 14px 20px; border-right: 1px solid var(--line); }
.proof-strip div:last-child { border-right: 0; }
.proof-strip b { display: block; color: var(--green); font-size: 24px; margin-bottom: 6px; }
.proof-strip span { color: var(--ink); }

.orgchart { padding: 96px 0 80px; background: white; }
.orgchart-figure { width: min(1180px, calc(100% - 60px)); margin: 0 auto; background: white; border: 1px solid var(--line); border-radius: 18px; padding: 18px; box-shadow: 0 24px 50px rgba(6,43,115,.08); }
.orgchart-figure img { width: 100%; height: auto; display: block; border-radius: 10px; }

.section-head { width: min(1120px, calc(100% - 80px)); margin: 0 auto 58px; text-align: center; }
.section-head h2, .compare h2, .scope h2, .system h2, .contact h2 { margin: 0 0 18px; font-size: 42px; line-height: 1.45; font-weight: 950; }
.section-head p:not(.eyebrow), .compare-copy p:not(.eyebrow), .scope-copy p, .system p, .contact p { color: var(--muted); line-height: 1.9; font-size: 18px; margin: 0; }

.problem { padding: 118px 0 110px; background: var(--mint); clip-path: polygon(0 0, 100% 0, 100% 92%, 50% 100%, 0 92%); }
.flow-compare { width: min(1120px, calc(100% - 80px)); margin: 0 auto 38px; display: grid; gap: 14px; }
.flow-row { background: white; border: 1px solid var(--line); border-radius: 14px; padding: 22px 26px; display: grid; grid-template-columns: 188px 1fr; gap: 26px; align-items: center; box-shadow: 0 12px 24px rgba(6,43,115,.06); }
.flow-row.before { background: #f8fafc; }
.flow-row.after { border-color: rgba(16,183,111,.35); background: #f6fff9; }
.flow-label { margin: 0; font-size: 22px; font-weight: 950; color: var(--navy); letter-spacing: .04em; display: grid; }
.flow-label span { display: block; margin-top: 4px; font-size: 13px; font-weight: 700; color: var(--muted); letter-spacing: 0; }
.flow-row.after .flow-label { color: var(--green); }
.flow-steps { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: center; gap: 8px; }
.fstep { display: grid; place-items: center; gap: 8px; padding: 14px 10px; border-radius: 10px; background: white; border: 1px solid var(--line); color: var(--navy); font-size: 14px; text-align: center; min-height: 86px; }
.fstep svg { width: 32px; height: 32px; color: var(--muted); }
.fstep svg circle, .fstep svg line, .fstep svg path { vector-effect: non-scaling-stroke; }
.fstep.stuck { border-color: #f3c2c0; background: #fff5f4; color: #b03b35; }
.fstep.stuck svg { color: #c84a44; }
.fstep.ok { border-color: rgba(16,183,111,.4); background: white; color: var(--navy); }
.fstep.ok svg { color: var(--green); }
.farrow { font-style: normal; font-size: 22px; color: var(--muted); font-weight: 950; }
.farrow.ok { color: var(--green); }
.problem-grid { width: min(1120px, calc(100% - 80px)); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.problem-grid article { min-height: 230px; background: white; border-radius: 14px; padding: 34px; box-shadow: var(--shadow); border: 1px solid var(--line); }
.problem-grid i { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 50%; background: var(--navy); color: white; font-style: normal; font-size: 18px; margin-bottom: 22px; }
.problem-grid h3 { font-size: 24px; line-height: 1.45; margin: 0 0 14px; }
.problem-grid p { color: var(--muted); line-height: 1.85; margin: 0; }
.message-line { width: min(980px, calc(100% - 80px)); margin: 54px auto 0; padding: 22px 28px; border-radius: 999px; background: white; border: 1px solid var(--line); box-shadow: var(--shadow); text-align: center; font-size: 28px; color: var(--navy); }
.message-line span { color: var(--green); }

.compare { width: min(1180px, calc(100% - 80px)); margin: 0 auto; padding: 112px 0 92px; display: grid; grid-template-columns: .9fr 1fr; gap: 52px; align-items: center; }
.compare-heading { font-size: 38px !important; line-height: 1.4 !important; word-break: keep-all; overflow-wrap: break-word; }
.compare-box { position: relative; display: grid; grid-template-columns: 1fr 64px 1fr; align-items: stretch; }
.compare-box article { border-radius: 14px; padding: 30px; border: 2px solid var(--line); background: white; box-shadow: var(--shadow); }
.compare-box .active { border-color: var(--green); background: #effff7; transform: translateY(-8px); }
.compare-box .muted { background: #f8fafc; color: #5c6c86; }
.compare-label { width: fit-content; margin: 0 0 20px; padding: 8px 14px; border-radius: 999px; background: #e7edf5; color: var(--navy); font-size: 14px; font-weight: 950; }
.compare-box .active .compare-label { background: var(--green); color: white; }
.compare-box ul { margin: 0 0 24px; padding: 0; list-style: none; display: grid; gap: 12px; }
.compare-box li { min-height: 48px; display: flex; align-items: center; padding: 10px 12px 10px 38px; position: relative; background: white; border: 1px solid #dce7ea; border-radius: 9px; }
.compare-box li::before { content: ""; position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 12px; height: 12px; border-radius: 50%; background: #aab6c8; }
.compare-box .active li { border-color: #bdebd8; color: var(--navy); }
.compare-box .active li::before { background: var(--green); box-shadow: 0 0 0 5px rgba(16,183,111,.12); }
.compare-box strong { display: block; padding: 16px 14px; border-radius: 10px; background: var(--navy); color: white; text-align: center; font-size: 20px; }
.compare-box .active strong { background: var(--green); }
.compare-vs { align-self: center; justify-self: center; width: 52px; height: 52px; display: grid; place-items: center; border-radius: 50%; background: var(--navy); color: white; font-weight: 950; box-shadow: 0 12px 22px rgba(6, 43, 115, .18); z-index: 2; }

.scope { position: relative; padding: 104px 0 92px; background: var(--pale); overflow: hidden; }
.scope-copy { width: min(1120px, calc(100% - 80px)); margin: 0 auto 56px; }
.scope-copy h2 { max-width: 780px; }
.scope-copy p { max-width: 760px; }
.scope-copy p b { color: var(--green); font-weight: 950; }
.deliverables { width: min(1280px, calc(100% - 48px)); min-height: 560px; margin: -120px auto 0; background-image: linear-gradient(90deg, rgba(245,247,250,.98) 0%, rgba(245,247,250,.9) 31%, rgba(245,247,250,.18) 58%, rgba(245,247,250,0) 100%), url("assets/generated/what-we-do-flow-bg.png"); background-size: cover; background-position: center; box-shadow: 0 28px 50px rgba(6,43,115,.1); }

.scope-timeline { position: relative; width: min(1080px, calc(100% - 60px)); margin: 0 auto; }
.scope-timeline::before { content: ""; position: absolute; left: 47px; top: 70px; bottom: 70px; width: 3px; background: var(--green); border-radius: 4px; }
.scope-step { position: relative; display: grid; grid-template-columns: 96px 1fr; gap: 40px; padding: 0 0 56px; }
.scope-step:last-child { padding-bottom: 0; }
.scope-step-marker { display: grid; grid-template-rows: 96px auto; gap: 14px; place-items: center; position: relative; z-index: 1; }
.scope-step-num { width: 96px; height: 96px; border-radius: 50%; background: white; border: 3px solid var(--green); display: grid; place-items: center; color: var(--green); font-size: 32px; font-weight: 950; letter-spacing: -.02em; box-shadow: 0 12px 26px rgba(16,183,111,.2); }
.scope-step-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--mint); color: var(--green); display: grid; place-items: center; }
.scope-step-icon svg { width: 26px; height: 26px; }
.scope-step.is-decision .scope-step-num { background: var(--green); color: white; }
.scope-step.is-decision .scope-step-icon { background: var(--green); color: white; }
.scope-step-content { padding-top: 10px; }
.scope-step-content h3 { margin: 12px 0 16px; font-size: 28px; line-height: 1.5; color: var(--navy); font-weight: 950; }
.scope-step-content > p { margin: 0 0 18px; color: var(--muted); line-height: 1.9; font-size: 16px; }
.scope-tag { display: inline-block; padding: 6px 14px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 13px; font-weight: 950; letter-spacing: .06em; margin: 0; }
.scope-step.is-decision .scope-tag { background: var(--green); color: white; }
.scope-bullets { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.scope-bullets li { position: relative; padding: 12px 16px 12px 38px; border: 1px solid var(--line); background: white; border-radius: 10px; color: var(--navy); font-size: 14.5px; font-weight: 700; box-shadow: 0 6px 12px rgba(6,43,115,.04); }
.scope-bullets li::before { content: ""; position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 10px; height: 10px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 4px rgba(16,183,111,.14); }

.scope-cycle { position: relative; width: min(1080px, calc(100% - 60px)); margin: 64px auto 0; padding: 44px 48px; background: white; border-radius: 24px; border: 1px solid var(--line); display: grid; grid-template-columns: 1fr 1.05fr; gap: 48px; align-items: center; box-shadow: 0 24px 48px rgba(6,43,115,.06); }
.scope-cycle-head .cycle-eyebrow { margin: 0 0 14px; color: var(--green); font-size: 13px; font-weight: 950; letter-spacing: .14em; }
.scope-cycle-head h3 { margin: 0 0 16px; font-size: 28px; line-height: 1.55; color: var(--navy); font-weight: 950; }
.scope-cycle-head h3 span { color: var(--green); }
.scope-cycle-head p { margin: 0; color: var(--muted); line-height: 1.9; font-size: 15px; }

.scope-cycle-branches { display: grid; gap: 16px; }
.cycle-branch { position: relative; background: var(--pale); border: 1px solid var(--line); border-radius: 14px; padding: 22px 26px; }
.branch-tag { margin: 0 0 8px; display: inline-block; padding: 4px 12px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 950; letter-spacing: .08em; }
.cycle-branch.pivot .branch-tag { background: #fff4dd; color: #b45309; }
.branch-route { margin: 0 0 8px; font-size: 17px; font-weight: 950; color: var(--navy); letter-spacing: .02em; }
.branch-route em { font-style: normal; color: var(--green); margin: 0 4px; }
.cycle-branch.pivot .branch-route em { color: #f59e0b; }
.branch-desc { margin: 0; color: var(--muted); font-size: 13.5px; line-height: 1.8; font-weight: 600; }

.scope-emph { position: relative; width: min(1080px, calc(100% - 60px)); margin: 38px auto 0; padding: 22px 28px; border-radius: 14px; background: white; border: 1px solid var(--line); text-align: center; color: var(--navy); font-size: 22px; font-weight: 950; letter-spacing: .02em; box-shadow: 0 12px 24px rgba(6,43,115,.05); }
.scope-emph span { color: var(--green); }

.system { padding: 96px 0; background: white; }
.system-grid { width: min(1120px, calc(100% - 80px)); margin: 0 auto; display: grid; grid-template-columns: .8fr 1fr; gap: 52px; align-items: center; }
.system-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 18px; }
.system-list li { display: grid; grid-template-columns: 190px 1fr; gap: 22px; align-items: center; padding: 24px 28px; border: 1px solid rgba(16,183,111,.25); background: #f7fffb; border-radius: 12px; }
.system-list b { color: var(--green); font-size: 24px; }
.system-list span { color: var(--ink); line-height: 1.7; }

.ecosystem { width: min(1180px, calc(100% - 60px)); margin: 60px auto 0; padding: 40px 40px 36px; border-radius: 18px; background: var(--pale); border: 1px solid var(--line); position: relative; overflow: hidden; }
.ecosystem-head { position: relative; max-width: 880px; margin-bottom: 36px; }
.ecosystem-head h3 { margin: 0 0 12px; font-size: 30px; line-height: 1.5; color: var(--navy); font-weight: 950; letter-spacing: 0; }
.ecosystem-head h3 span { color: var(--green); }
.ecosystem-head p { margin: 0; color: var(--muted); line-height: 1.9; font-size: 15px; }
.ecosystem-grid { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.eco-col { background: white; border: 1px solid var(--line); border-radius: 12px; padding: 22px 18px 20px; box-shadow: 0 8px 18px rgba(6,43,115,.05); }
.eco-cat { margin: 0 0 18px; display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 950; color: var(--navy); letter-spacing: .04em; }
.eco-cat .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--green); }
.eco-cat .dot.ai { background: var(--green); }
.eco-cat .dot.dev { background: #2563eb; }
.eco-cat .dot.knowledge { background: #f59e0b; }
.eco-cat .dot.analytics { background: #8b5cf6; }
.eco-col ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.eco-col li { display: flex; align-items: center; gap: 10px; padding: 8px 10px; background: var(--pale); border: 1px solid transparent; border-radius: 8px; transition: transform .2s ease, border-color .2s ease, background .2s ease; }
.eco-col li:hover { transform: translateY(-2px); border-color: var(--line); background: white; }
.eco-col li img { width: 22px; height: 22px; flex: none; object-fit: contain; }
.eco-col li img.mono { color: #0a0a0a; }
.eco-col li img.mono.blue { color: #4285F4; }
.eco-col li img.mono.red { color: #EA4B71; }
.eco-col li span { font-size: 13.5px; color: var(--navy); font-weight: 700; }
.ecosystem-foot { margin: 28px 0 0; padding: 0; color: var(--navy); font-size: 15.5px; line-height: 1.75; text-align: center; }
.ecosystem-foot span { color: var(--green); font-weight: 950; }

.process { padding: 104px 0 90px; background: white; }
.process-steps { width: min(1180px, calc(100% - 60px)); margin: 0 auto; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; counter-reset: pstep; }
.process-steps li { position: relative; padding: 26px 18px 22px; background: white; border-top: 4px solid var(--green); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.process-steps li:first-child { border-left: 1px solid var(--line); border-top-left-radius: 12px; border-bottom-left-radius: 12px; }
.process-steps li:last-child { border-top-right-radius: 12px; border-bottom-right-radius: 12px; }
.process-steps li::after { content: ""; position: absolute; right: -10px; top: 50%; width: 20px; height: 20px; background: white; border-top: 2px solid var(--green); border-right: 2px solid var(--green); transform: translateY(-50%) rotate(45deg); z-index: 2; }
.process-steps li:last-child::after { display: none; }
.pnum { display: inline-block; padding: 4px 10px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 950; letter-spacing: .06em; }
.picon { margin: 14px 0 10px; width: 64px; height: 64px; border-radius: 50%; overflow: hidden; display: grid; place-items: center; background: var(--mint); }
.picon img { width: 100%; height: 100%; object-fit: cover; display: block; }
.picon svg { width: 26px; height: 26px; color: var(--green); }
.process-steps h3 { margin: 0 0 6px; font-size: 16px; line-height: 1.5; color: var(--navy); }
.process-steps p { margin: 0; color: var(--muted); font-size: 12.5px; line-height: 1.75; }
.process-foot { width: min(1120px, calc(100% - 80px)); margin: 40px auto 0; text-align: center; font-size: 22px; font-weight: 950; color: var(--navy); }
.process-foot span { color: var(--green); }
.method { padding: 96px 0 88px; background: white; }
.method .section-head h2 { letter-spacing: 0; }
.pmf-flow { width: min(1200px, calc(100% - 60px)); margin: 0 auto; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; counter-reset: pmf; }
.pmf-flow li { position: relative; padding: 24px 18px 22px; background: white; border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 10px 20px rgba(6,43,115,.05); }
.pmf-flow li::after { content: ""; position: absolute; right: -10px; top: 50%; width: 18px; height: 18px; background: white; border-top: 2px solid var(--green); border-right: 2px solid var(--green); transform: translateY(-50%) rotate(45deg); z-index: 2; }
.pmf-flow li:last-child::after { display: none; }
.pmf-num { display: inline-block; padding: 6px 12px; border-radius: 8px; background: var(--navy); color: white; font-size: 13px; font-weight: 950; letter-spacing: .08em; margin-bottom: 12px; }
.pmf-flow li:nth-child(5) .pmf-num { background: var(--green); }
.pmf-flow h3 { margin: 0 0 8px; font-size: 16px; line-height: 1.5; color: var(--navy); }
.pmf-flow > li > p { margin: 0 0 12px; color: var(--muted); font-size: 13px; line-height: 1.75; }
.pmf-accel { display: block; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; line-height: 1.65; font-weight: 700; letter-spacing: .02em; }
.cases { background: var(--pale); padding: 100px 0; overflow: hidden; }
.cases-visual { width: min(1280px, calc(100% - 48px)); min-height: 480px; margin: 0 auto 56px; background-image: linear-gradient(90deg, rgba(245,247,250,.98) 0%, rgba(245,247,250,.78) 28%, rgba(245,247,250,.15) 62%, rgba(245,247,250,0) 100%), url("assets/generated/venture-themes-bg.png"); background-size: cover; background-position: center; box-shadow: 0 28px 50px rgba(6,43,115,.1); }
.cases-rail { position: relative; margin: 0 0 36px; padding: 0; }
.cases-track { display: flex; gap: 26px; padding: 12px 8vw 36px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.cases-track::-webkit-scrollbar { height: 8px; }
.cases-track::-webkit-scrollbar-track { background: transparent; }
.cases-track::-webkit-scrollbar-thumb { background: rgba(16,183,111,.32); border-radius: 999px; }
.product-card { flex: 0 0 min(520px, 82vw); scroll-snap-align: start; display: grid; grid-template-rows: auto 1fr; background: white; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; box-shadow: 0 18px 36px rgba(6,43,115,.07); transition: transform .25s ease, box-shadow .25s ease; }
.product-card:hover { transform: translateY(-4px); box-shadow: 0 28px 52px rgba(6,43,115,.12); }
.product-figure { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--pale); border-bottom: 1px solid var(--line); margin: 0; }
.product-figure img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.product-card:hover .product-figure img { transform: scale(1.03); }
.product-meta { padding: 22px 24px 24px; }
.product-tags { margin: 0 0 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.product-tags span { display: inline-block; padding: 5px 11px; border-radius: 999px; font-size: 11.5px; font-weight: 950; letter-spacing: .04em; }
.ptag-domain { background: var(--mint); color: var(--green); }
.ptag-role.full { background: var(--navy); color: white; }
.ptag-role.dev { background: white; color: var(--navy); border: 1px solid var(--navy); }
.product-meta h3 { margin: 0 0 6px; font-size: 22px; color: var(--navy); }
.product-tagline { margin: 0 0 12px; color: var(--navy); font-size: 14.5px; font-weight: 900; line-height: 1.6; }
.product-meta > p:not(.product-tagline):not(.product-tags):not(.product-link) { margin: 0 0 14px; color: var(--muted); font-size: 13.5px; line-height: 1.85; font-weight: 600; }
.product-link { margin: 0 !important; font-size: 13px; font-weight: 950; }
.product-link a { color: var(--green); }
.cases-rail-controls { position: absolute; top: 38%; left: 0; right: 0; display: flex; justify-content: space-between; padding: 0 2vw; pointer-events: none; }
.rail-arrow { width: 52px; height: 52px; border-radius: 50%; background: white; border: 1px solid var(--line); box-shadow: 0 8px 18px rgba(6,43,115,.18); color: var(--navy); font-size: 28px; font-weight: 950; cursor: pointer; pointer-events: auto; display: grid; place-items: center; transition: transform .2s ease, color .2s ease; }
.rail-arrow:hover { transform: scale(1.08); color: var(--green); }
.case-numbers { width: min(1120px, calc(100% - 80px)); margin: 0 auto 40px; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.case-numbers li { background: white; border: 1px solid var(--line); border-radius: 14px; padding: 28px 22px 22px; text-align: center; box-shadow: 0 12px 24px rgba(6,43,115,.06); }
.case-numbers b { display: block; font-size: 48px; font-weight: 950; color: var(--green); line-height: 1; letter-spacing: -.02em; }
.case-numbers b span { font-size: 18px; color: var(--navy); margin-left: 6px; letter-spacing: 0; }
.case-numbers p { margin: 10px 0 0; color: var(--navy); font-size: 13.5px; font-weight: 700; }
.case-teasers { width: min(1120px, calc(100% - 80px)); margin: 0 auto 36px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.teaser { background: white; border: 1px solid var(--line); border-radius: 14px; padding: 26px; box-shadow: 0 14px 28px rgba(6,43,115,.06); }
.teaser-tag { margin: 0 0 12px; display: inline-block; padding: 5px 12px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 950; letter-spacing: .06em; }
.case-teasers h3 { margin: 0 0 10px; font-size: 18px; line-height: 1.55; color: var(--navy); }
.case-teasers p { margin: 0; color: var(--muted); font-size: 13.5px; line-height: 1.85; }
.case-cta { width: min(1120px, calc(100% - 80px)); margin: 32px auto 0; padding: 36px 44px; border-radius: 18px; background: white; border: 1px solid rgba(16,183,111,.18); display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap; box-shadow: 0 18px 36px rgba(6,43,115,.06); position: relative; overflow: hidden; }
.case-cta-body { position: relative; display: grid; gap: 6px; }
.case-cta-lead { margin: 0; color: var(--navy); font-size: 22px; font-weight: 950; line-height: 1.5; letter-spacing: 0; }
.case-cta-lead b { color: var(--green); font-weight: 950; }
.case-cta-sub { margin: 0; color: var(--muted); font-size: 14.5px; font-weight: 700; line-height: 1.7; }
.case-cta .btn-pill { position: relative; }
.btn-pill { display: inline-flex; align-items: center; gap: 10px; padding: 14px 26px; border-radius: 999px; font-weight: 950; font-size: 15px; text-decoration: none; transition: transform .2s ease; }
.btn-pill.green { background: var(--green); color: white; box-shadow: 0 10px 22px rgba(16,183,111,.28); }
.btn-pill.green:hover { transform: translateY(-2px); }
.btn-pill em { font-style: normal; font-size: 18px; }
.showcase { position: relative; margin: 0 0 44px; padding: 0 0 12px; }
.showcase-track { display: flex; gap: 28px; padding: 12px 8vw 44px; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: thin; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; }
.showcase-track::-webkit-scrollbar { height: 8px; }
.showcase-track::-webkit-scrollbar-track { background: transparent; }
.showcase-track::-webkit-scrollbar-thumb { background: rgba(16,183,111,.32); border-radius: 999px; }
.show-item { flex: 0 0 min(720px, 78vw); scroll-snap-align: center; background: white; border: 1px solid var(--line); border-radius: 18px; overflow: hidden; box-shadow: 0 24px 50px rgba(6,43,115,.12); transition: transform .4s ease, box-shadow .4s ease; transform: scale(.96); opacity: .82; }
.show-item.is-active { transform: scale(1); opacity: 1; box-shadow: 0 32px 60px rgba(6,43,115,.18); }
.show-item figure { margin: 0; aspect-ratio: 16/10; overflow: hidden; background: var(--mint); }
.show-item figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.show-meta { padding: 22px 28px 26px; display: grid; gap: 8px; }
.show-tag { display: inline-block; align-self: start; margin: 0; padding: 4px 12px; border-radius: 999px; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 950; letter-spacing: .08em; }
.show-meta h3 { margin: 4px 0 0; font-size: 22px; line-height: 1.5; color: var(--navy); }
.show-meta p { margin: 0; color: var(--muted); line-height: 1.85; font-size: 14.5px; }
.showcase-controls { position: absolute; top: 38%; left: 0; right: 0; display: flex; justify-content: space-between; padding: 0 2vw; pointer-events: none; }
.show-arrow { width: 52px; height: 52px; border-radius: 50%; background: white; border: 1px solid var(--line); box-shadow: 0 8px 18px rgba(6,43,115,.18); color: var(--navy); font-size: 28px; font-weight: 950; cursor: pointer; pointer-events: auto; display: grid; place-items: center; transition: transform .2s ease; }
.show-arrow:hover { transform: scale(1.08); color: var(--green); }
.theme-tags { width: min(1120px, calc(100% - 80px)); margin: 0 auto; display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }
.theme-tags span { display: inline-flex; align-items: center; min-height: 46px; padding: 0 18px; border: 1px solid rgba(16,183,111,.34); border-radius: 999px; background: white; color: var(--navy); box-shadow: 0 8px 18px rgba(6,43,115,.06); }

.pricing { width: min(1180px, calc(100% - 80px)); margin: 96px auto 0; padding: 0; background: transparent; box-shadow: none; border: 0; }
.pricing .section-head { margin-bottom: 36px; }
.price-card { background: white; border: 1px solid var(--line); border-radius: 18px; padding: 40px 44px 36px; box-shadow: 0 24px 50px rgba(6,43,115,.08); max-width: 920px; margin: 0 auto; }
.price-headline { display: flex; align-items: baseline; gap: 14px; justify-content: center; flex-wrap: wrap; }
.price-from { font-size: 16px; color: var(--muted); font-weight: 700; letter-spacing: .08em; }
.price-num { font-size: 76px; font-weight: 950; color: var(--navy); letter-spacing: -.02em; line-height: 1; }
.price-unit { font-size: 18px; color: var(--navy); font-weight: 900; }
.price-meta { text-align: center; margin: 10px 0 28px; color: var(--muted); font-size: 14.5px; font-weight: 700; }
.price-includes { margin: 0 0 22px; padding: 24px 28px; list-style: none; background: var(--pale); border-radius: 12px; border: 1px solid var(--line); display: grid; grid-template-columns: 1fr 1fr; gap: 12px 28px; }
.price-includes li { position: relative; padding-left: 30px; color: var(--navy); font-size: 14.5px; line-height: 1.65; font-weight: 700; }
.price-includes li::before { content: ""; position: absolute; left: 0; top: 4px; width: 18px; height: 18px; border-radius: 50%; background: var(--green); }
.price-includes li::after { content: ""; position: absolute; left: 5px; top: 8px; width: 8px; height: 4px; border-left: 2px solid white; border-bottom: 2px solid white; transform: rotate(-45deg); }
.price-not-incl { margin: -8px 0 14px; text-align: center; color: var(--muted); font-size: 12.5px; font-weight: 600; line-height: 1.7; }
.price-note { margin: 0; text-align: center; color: var(--muted); font-size: 13.5px; font-weight: 600; line-height: 1.7; }
.price-note b { color: var(--green); font-weight: 950; }

.features { padding: 104px 0; background: white; }
.feature-list { width: min(1120px, calc(100% - 80px)); margin: 0 auto; display: grid; gap: 22px; }
.feature-list article { display: grid; grid-template-columns: 90px .8fr 1fr; gap: 26px; align-items: center; padding: 30px 34px; border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 12px 24px rgba(6,43,115,.07); }
.feature-list b { color: #dfeceb; font-size: 64px; line-height: 1; }
.feature-list h3 { margin: 0; font-size: 25px; line-height: 1.5; color: var(--navy); }
.feature-list p { margin: 0; color: var(--muted); line-height: 1.85; }

.contact { padding: 100px 0; color: white; background: var(--navy); position: relative; overflow: hidden; }
.contact::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(6,43,115,.95), rgba(6,43,115,.82) 42%, rgba(6,43,115,.45)), url("assets/generated/cta-background.png"); background-size: cover; background-position: center; }
.contact-inner { position: relative; width: min(1180px, calc(100% - 80px)); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.05fr; gap: 60px; align-items: start; }
.contact-copy { color: white; }
.contact-copy .eyebrow { color: var(--fresh); margin-bottom: 18px; }
.contact h2 { margin: 0 0 18px; color: white; font-size: 38px; line-height: 1.45; }
.contact h2 span { color: var(--fresh); }
.contact-copy > p { color: #d8efe8; line-height: 1.95; font-size: 15.5px; margin: 0 0 28px; }
.contact-points { margin: 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.contact-points li { padding: 14px 18px 14px 44px; position: relative; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.16); border-radius: 10px; color: #e7f3ed; font-size: 14.5px; font-weight: 700; }
.contact-points li::before { content: "✓"; position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--fresh); font-size: 16px; font-weight: 950; }
.contact-points b { color: white; font-weight: 950; }
.contact-form { background: white; color: var(--navy); border-radius: 18px; padding: 32px 32px 28px; box-shadow: 0 24px 50px rgba(0,0,0,.22); display: grid; gap: 16px; }
.contact-form .field { display: grid; gap: 6px; }
.contact-form label { font-size: 13.5px; font-weight: 950; color: var(--navy); display: flex; align-items: center; gap: 10px; }
.contact-form label .req { color: var(--green); font-size: 11px; padding: 2px 8px; border-radius: 4px; background: var(--mint); }
.contact-form label .opt { color: var(--muted); font-size: 11px; padding: 2px 8px; border-radius: 4px; background: #eef3f8; }
.contact-form input, .contact-form textarea { width: 100%; padding: 14px 16px; border: 1px solid var(--line); border-radius: 10px; background: white; color: var(--navy); font-size: 15px; font-family: inherit; font-weight: 700; transition: border-color .15s ease, box-shadow .15s ease; }
.contact-form input:focus, .contact-form textarea:focus { outline: 0; border-color: var(--green); box-shadow: 0 0 0 4px rgba(16,183,111,.18); }
.contact-form textarea { resize: vertical; min-height: 88px; line-height: 1.7; }
.form-submit { margin-top: 6px; display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 18px 28px; border-radius: 999px; background: var(--green); color: white; font-size: 17px; font-weight: 950; border: 0; cursor: pointer; box-shadow: 0 14px 28px rgba(16,183,111,.32); transition: transform .2s ease; }
.form-submit:hover { transform: translateY(-2px); }
.form-submit em { font-style: normal; font-size: 20px; }
.form-note { margin: 4px 0 0; color: var(--muted); font-size: 12.5px; font-weight: 600; line-height: 1.7; text-align: center; }
.form-error { margin: 8px 0 0; padding: 12px 14px; background: #fff1f0; border: 1px solid #f3c2c0; border-radius: 8px; color: #b03b35; font-size: 13px; font-weight: 700; line-height: 1.7; text-align: center; }
.form-error a { color: #b03b35; text-decoration: underline; }
.form-submit:disabled { opacity: .6; cursor: progress; transform: none; }
.contact-thanks { background: white; color: var(--navy); border-radius: 18px; padding: 48px 36px; box-shadow: 0 24px 50px rgba(0,0,0,.22); display: grid; gap: 16px; place-items: center; text-align: center; }
.contact-thanks-icon { width: 72px; height: 72px; border-radius: 50%; background: var(--mint); color: var(--green); display: grid; place-items: center; }
.contact-thanks-icon svg { width: 36px; height: 36px; }
.contact-thanks h3 { margin: 0; font-size: 24px; font-weight: 950; color: var(--navy); }
.contact-thanks p { margin: 0; color: var(--muted); font-size: 14.5px; line-height: 1.85; font-weight: 700; }
.contact-thanks p b { color: var(--navy); }
.contact-thanks p a { color: var(--green); font-weight: 950; }

.faq { background: white; padding: 100px 0; }
.faq-box { width: min(1040px, calc(100% - 80px)); margin: 0 auto; border: 1px solid var(--line); padding: 34px 54px; background: white; box-shadow: var(--shadow); border-radius: 14px; }
details { border-bottom: 1px solid var(--line); }
details:last-child { border-bottom: 0; }
summary { list-style: none; cursor: pointer; padding: 26px 58px 26px 58px; position: relative; font-size: 20px; font-weight: 950; }
summary::-webkit-details-marker { display: none; }
summary::before { content: "Q"; position: absolute; left: 0; color: var(--green); font-size: 30px; }
summary::after { content: "+"; position: absolute; right: 0; top: 22px; color: var(--green); font-size: 38px; }
details[open] summary::after { content: "-"; }
details p { margin: 0; padding: 0 58px 26px; line-height: 1.9; color: var(--muted); font-weight: 600; }

.sticky-cta { position: fixed; left: 0; right: 0; bottom: 0; height: 88px; z-index: 40; background: rgba(255,255,255,.94); display: flex; justify-content: center; gap: 24px; align-items: center; box-shadow: 0 -8px 22px rgba(6,43,115,.08); }
.sticky-cta a { height: 54px; min-width: 310px; display: grid; place-items: center; border: 2px solid var(--green); border-radius: 999px; color: var(--navy); background: white; font-size: 18px; font-weight: 950; }
.sticky-cta a:first-child { color: white; background: var(--green); }
.footer { background: var(--navy2); color: white; padding: 80px 0 100px; }
.footer-inner { width: min(1180px, calc(100% - 80px)); margin: 0 auto; display: grid; grid-template-columns: 1.2fr 2fr; gap: 56px; align-items: start; }
.footer img { width: 190px; filter: brightness(0) invert(1); margin-bottom: 22px; }
.footer-brand p { margin: 0 0 8px; color: white; font-size: 16px; font-weight: 900; }
.footer-brand small { color: #afbdd5; line-height: 1.7; }
.footer-cols { display: grid; grid-template-columns: 1fr 1.3fr; gap: 40px; }
.footer-col h4 { margin: 0 0 14px; font-size: 13px; color: var(--fresh); letter-spacing: .12em; font-weight: 950; }
.footer-col ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.footer-col a { color: #d8e4f5; font-weight: 700; font-size: 14px; }
.footer-col a:hover { color: white; }
.company-info { font-size: 13px; line-height: 1.7; color: #afbdd5; font-weight: 600; }
.company-info b { color: white; font-size: 16px; font-weight: 950; display: block; margin-bottom: 4px; }
.company-info a { color: var(--fresh); font-weight: 700; }
.copyright { grid-column: 1 / -1; padding-top: 40px; margin-top: 8px; border-top: 1px solid rgba(255,255,255,.12); color: #afbdd5; }

/* company.html */
.company-page { padding-top: 140px; }
.company-hero { width: min(960px, calc(100% - 60px)); margin: 0 auto 64px; text-align: center; }
.company-hero h1 { margin: 12px 0 18px; font-size: 48px; line-height: 1.35; color: var(--navy); font-weight: 950; }
.company-hero p { margin: 0; color: var(--muted); font-size: 17px; line-height: 1.9; }
.company-hero p b { color: var(--navy); font-weight: 950; }
.company-section { width: min(960px, calc(100% - 60px)); margin: 0 auto 60px; }
.company-section h2 { margin: 0 0 22px; font-size: 26px; color: var(--navy); padding-bottom: 14px; border-bottom: 2px solid var(--green); }
.company-table { display: grid; grid-template-columns: 180px 1fr; gap: 14px 28px; margin: 0; }
.company-table dt { color: var(--green); font-weight: 950; font-size: 14px; padding-top: 4px; letter-spacing: .04em; }
.company-table dd { margin: 0; color: var(--ink); line-height: 1.85; font-weight: 700; font-size: 15px; }
.company-table dd ul { margin: 0; padding: 0 0 0 20px; }
.company-table dd a { color: var(--green); }
.ceo-card { background: var(--pale); border: 1px solid var(--line); border-radius: 14px; padding: 32px; box-shadow: 0 14px 28px rgba(6,43,115,.06); display: grid; grid-template-columns: 160px 1fr; gap: 28px; align-items: start; }
.ceo-photo { margin: 0; width: 160px; height: 160px; border-radius: 50%; overflow: hidden; background: white; border: 4px solid var(--mint); box-shadow: 0 14px 28px rgba(6,43,115,.10); }
.ceo-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ceo-title { margin: 0 0 6px; color: var(--green); font-size: 13px; font-weight: 950; letter-spacing: .08em; }
.ceo-name { margin: 0 0 18px; font-size: 26px; color: var(--navy); font-weight: 950; }
.ceo-name small { font-size: 14px; color: var(--muted); font-weight: 600; margin-left: 8px; }
.ceo-body p { margin: 0 0 14px; color: var(--ink); line-height: 1.95; font-weight: 700; font-size: 15px; }
.ceo-body p:last-child { margin: 0; color: var(--muted); font-size: 13.5px; }
.company-cta { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 24px; }
.btn-pill.outline { background: white; color: var(--navy); border: 2px solid var(--navy); }

@media (max-width: 980px) {
  .company-page { padding-top: 100px; }
  .company-hero h1 { font-size: 30px; }
  .company-table { grid-template-columns: 1fr; gap: 4px 0; }
  .company-table dt { padding-top: 14px; }
  .ceo-card { padding: 22px; grid-template-columns: 1fr; gap: 16px; justify-items: center; text-align: left; }
  .ceo-photo { width: 120px; height: 120px; }
}

@media (max-width: 980px) {
  body { padding-bottom: 0; }
  .header { width: calc(100% - 24px); top: 12px; height: 64px; padding: 0 16px; }
  .logo { width: 150px; }
  .logo img { height: 38px; }
  .nav, .header-cta { display: none; }
  .menu { display: grid; gap: 5px; margin-left: auto; border: 0; background: transparent; padding: 0; }
  .menu span { display: block; width: 28px; height: 3px; background: var(--ink); }
  .hero { min-height: 860px; }
  .hero-bg { background-image: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,.98) 48%, rgba(255,255,255,.62) 66%, rgba(255,255,255,.12) 100%), url("assets/generated/hero-org-new.png"); background-size: auto 620px; background-repeat: no-repeat; background-position: 63% bottom; }
  .hero-inner { width: calc(100% - 30px); padding-top: 112px; }
  .hero h1 { font-size: 38px; }
  .lead { font-size: 16px; }
  .hero-actions { margin-top: 44px; grid-template-columns: 1fr; gap: 48px; width: 100%; }
  .mega-btn { min-height: 74px; padding: 18px 46px 14px; }
  .mega-btn b { font-size: 20px; }
  .mega-btn small { min-width: 246px; font-size: 12px; }
  .proof-strip { grid-template-columns: 1fr; width: calc(100% - 30px); margin-top: -34px; padding: 18px; }
  .proof-strip div { border-right: 0; border-bottom: 1px solid var(--line); }
  .proof-strip div:last-child { border-bottom: 0; }
  .section-head, .problem-grid, .compare, .compare-box, .scope-copy, .system-grid, .feature-list, .cta-pair, .pricing, .contact-inner { grid-template-columns: 1fr; width: calc(100% - 30px); }
  .contact h2 { font-size: 26px; }
  .contact-form { padding: 22px; }
  .section-head h2, .compare h2, .scope h2, .system h2, .contact h2 { font-size: 30px; }
  .problem { padding: 82px 0 96px; }
  .problem-grid { gap: 18px; }
  .flow-compare { width: calc(100% - 30px); }
  .flow-row { grid-template-columns: 1fr; gap: 14px; padding: 18px; }
  .flow-steps { grid-template-columns: 1fr; gap: 6px; }
  .fstep { min-height: auto; padding: 12px; }
  .farrow { transform: rotate(90deg); justify-self: center; }
  .message-line { width: calc(100% - 30px); border-radius: 14px; font-size: 22px; line-height: 1.6; }
  .compare { gap: 28px; padding: 82px 0; }
  .compare-box { gap: 14px; }
  .compare-vs { margin: -2px auto; }
  .scope { padding: 82px 0; }
  .deliverables { width: 100%; min-height: 520px; margin: 18px 0 0; background-image: linear-gradient(180deg, rgba(245,247,250,.98) 0%, rgba(245,247,250,.86) 30%, rgba(245,247,250,.16) 66%, rgba(245,247,250,0) 100%), url("assets/generated/what-we-do-flow-bg.png"); background-position: 66% center; }
  .scope-cards { grid-template-columns: 1fr; width: calc(100% - 30px); gap: 14px; }
  .scope-copy { margin-bottom: 36px; width: calc(100% - 30px); }
  .scope-timeline { width: calc(100% - 30px); }
  .scope-timeline::before { left: 33px; top: 60px; bottom: 60px; width: 2px; }
  .scope-step { grid-template-columns: 68px 1fr; gap: 22px; padding-bottom: 36px; }
  .scope-step-marker { grid-template-rows: 68px auto; gap: 10px; }
  .scope-step-num { width: 68px; height: 68px; font-size: 24px; border-width: 2px; }
  .scope-step-icon { width: 36px; height: 36px; }
  .scope-step-icon svg { width: 20px; height: 20px; }
  .scope-step-content { padding-top: 4px; }
  .scope-step-content h3 { font-size: 22px; }
  .scope-cycle { width: calc(100% - 30px); padding: 28px 22px; grid-template-columns: 1fr; gap: 24px; }
  .scope-cycle-head h3 { font-size: 22px; }
  .cycle-branch { padding: 18px 20px; }
  .scope-emph { font-size: 17px; line-height: 1.7; width: calc(100% - 30px); padding: 18px; }
  .system-grid { gap: 28px; }
  .system-list li { grid-template-columns: 1fr; gap: 8px; padding: 22px; }
  .ecosystem { width: calc(100% - 30px); padding: 28px 18px; }
  .ecosystem-head h3 { font-size: 22px; }
  .ecosystem-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .eco-col { padding: 16px 14px; }
  .ecosystem-foot { padding: 0; font-size: 14px; text-align: left; }
  .process { padding: 82px 0; }
  .process-steps { grid-template-columns: 1fr 1fr; width: calc(100% - 30px); border-radius: 12px; overflow: hidden; }
  .process-steps li { border-radius: 0 !important; border: 1px solid var(--line); border-top: 4px solid var(--green); }
  .process-steps li::after { display: none; }
  .process-foot { font-size: 17px; padding: 0 14px; }
  .method { padding: 76px 0; }
  .pmf-flow { grid-template-columns: 1fr; width: calc(100% - 30px); gap: 12px; }
  .pmf-flow li::after { display: none; }
  .cases-visual { width: 100%; min-height: 420px; background-image: linear-gradient(180deg, rgba(245,247,250,.98) 0%, rgba(245,247,250,.78) 30%, rgba(245,247,250,.08) 72%, rgba(245,247,250,0) 100%), url("assets/generated/venture-themes-bg.png"); background-position: 64% center; }
  .theme-tags { width: calc(100% - 30px); justify-content: flex-start; }
  .cases-track { gap: 14px; padding: 8px 6vw 28px; }
  .product-card { flex: 0 0 min(320px, 84vw); }
  .product-meta { padding: 16px 18px 20px; }
  .product-meta h3 { font-size: 18px; }
  .cases-rail-controls { display: none; }
  .case-numbers { width: calc(100% - 30px); grid-template-columns: 1fr 1fr; gap: 12px; }
  .case-numbers li { padding: 20px 14px 16px; }
  .case-numbers b { font-size: 34px; }
  .case-teasers { width: calc(100% - 30px); grid-template-columns: 1fr; gap: 14px; }
  .case-cta { width: calc(100% - 30px); flex-direction: column; align-items: stretch; text-align: center; padding: 24px 20px; }
  .case-cta-lead { font-size: 18px; }
  .case-cta-body { text-align: left; }
  .showcase-track { gap: 14px; padding: 8px 6vw 36px; }
  .show-item { flex: 0 0 min(320px, 84vw); border-radius: 14px; }
  .show-meta { padding: 16px 18px 20px; }
  .show-meta h3 { font-size: 18px; }
  .showcase-controls { display: none; }
  .pricing { margin-top: 64px; padding: 0; width: calc(100% - 30px); }
  .price-card { padding: 28px 22px; }
  .price-num { font-size: 52px; }
  .price-includes { grid-template-columns: 1fr; padding: 20px; gap: 10px; }
  .feature-list article { grid-template-columns: 1fr; gap: 12px; padding: 26px; }
  .feature-list b { font-size: 48px; }
  .faq-box { width: calc(100% - 30px); padding: 20px; }
  summary { padding-right: 42px; font-size: 17px; }
  details p { padding-right: 0; }
  .footer-inner { grid-template-columns: 1fr; width: calc(100% - 30px); gap: 32px; }
  .footer-cols { grid-template-columns: 1fr; gap: 28px; }
  .orgchart { padding: 72px 0; }
  .sticky-cta { display: none; }
}
