:root {
  --ink: #07111f;
  --ink-soft: #13243a;
  --blue: #2563eb;
  --cyan: #38bdf8;
  --paper: #f5f7fb;
  --white: #fff;
  --text: #172033;
  --muted: #657085;
  --line: #dfe5ee;
  --shadow: 0 30px 80px rgba(7, 17, 31, .12);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { min-width: 320px; overflow-x: hidden; color: var(--text); background: var(--white); font-family: "DM Sans", Arial, sans-serif; line-height: 1.65; -webkit-font-smoothing: antialiased; }
body.menu-open { overflow: hidden; }
a { color: inherit; }
img { display: block; max-width: 100%; }
button { font: inherit; }
:focus-visible { outline: 3px solid rgba(56, 189, 248, .7); outline-offset: 4px; }
.shell { width: min(1160px, calc(100% - 48px)); margin-inline: auto; }
h1, h2, h3, .brand { font-family: "Manrope", Arial, sans-serif; }
h1, h2 { letter-spacing: -.045em; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--blue); font-size: .75rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow::before { width: 28px; height: 2px; background: currentColor; content: ""; }
.button { display: inline-flex; min-height: 52px; align-items: center; justify-content: center; gap: 9px; padding: 0 24px; border: 1px solid transparent; border-radius: 999px; font-weight: 700; text-decoration: none; transition: transform .2s, background .2s, box-shadow .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: white; background: var(--blue); box-shadow: 0 15px 34px rgba(37,99,235,.3); }
.button-primary:hover { background: #1d4ed8; }
.button-light { color: var(--ink); background: #7dd3fc; }
.button-light:hover { background: #bae6fd; }
.skip-link { position: fixed; z-index: 999; top: 10px; left: 10px; padding: 9px 13px; color: white; background: var(--blue); transform: translateY(-150%); }
.skip-link:focus { transform: none; }

.site-header { position: absolute; z-index: 20; top: 0; width: 100%; border-bottom: 1px solid rgba(255,255,255,.1); color: white; }
.nav { display: flex; height: 78px; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 12px; font-size: 1rem; font-weight: 800; text-decoration: none; }
.brand-mark { display: grid; width: 38px; height: 38px; place-items: center; border-radius: 11px; color: white; background: linear-gradient(145deg,var(--cyan),var(--blue)); box-shadow: 0 8px 20px rgba(37,99,235,.35); font-size: .84rem; letter-spacing: -.06em; }
.nav-links { display: flex; align-items: center; gap: 32px; list-style: none; }
.nav-links a { color: rgba(255,255,255,.78); font-size: .91rem; font-weight: 600; text-decoration: none; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: white; }
.nav-cta { padding: 10px 18px; border: 1px solid rgba(255,255,255,.27); border-radius: 999px; }
.menu-button { display: none; width: 44px; height: 44px; border: 0; border-radius: 12px; color: white; background: rgba(255,255,255,.1); cursor: pointer; }
.menu-button span, .menu-button::before, .menu-button::after { display: block; width: 20px; height: 2px; margin: 5px auto; border-radius: 2px; background: currentColor; content: ""; transition: transform .2s, opacity .2s; }
.menu-button.active span { opacity: 0; }
.menu-button.active::before { transform: translateY(7px) rotate(45deg); }
.menu-button.active::after { transform: translateY(-7px) rotate(-45deg); }

.page-hero { position: relative; overflow: hidden; padding: 178px 0 105px; color: white; background: var(--ink); }
.page-hero::before { position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%,rgba(56,189,248,.18),transparent 30%),radial-gradient(circle at 10% 100%,rgba(37,99,235,.26),transparent 35%); content: ""; }
.page-hero::after { position: absolute; inset: 0; opacity: .16; background-image: linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px); background-size: 70px 70px; mask-image: linear-gradient(to bottom,black,transparent); content: ""; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 80px; }
.page-hero .eyebrow { color: #7dd3fc; }
.page-hero h1 { max-width: 760px; margin-top: 22px; font-size: clamp(3.2rem,6vw,5.6rem); line-height: 1; }
.hero-summary { max-width: 640px; margin-top: 25px; color: #aebdd1; font-size: 1.12rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-image { position: relative; }
.hero-image::before { position: absolute; inset: 24px -24px -24px 24px; border: 1px solid rgba(125,211,252,.28); border-radius: 24px; content: ""; }
.hero-image img { position: relative; width: 100%; aspect-ratio: 1.15; border-radius: 24px; box-shadow: 0 35px 80px rgba(0,0,0,.32); object-fit: cover; }

.breadcrumb { padding: 18px 0; border-bottom: 1px solid var(--line); color: var(--muted); background: white; font-size: .82rem; }
.breadcrumb a { color: var(--blue); text-decoration: none; }
.content-section { padding: 110px 0; }
.content-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 90px; align-items: start; }
.content-section h2, .other-services h2, .careers-intro h2, .positions h2 { color: var(--ink); font-size: clamp(2.15rem,4vw,3.5rem); line-height: 1.08; }
.lead { margin-top: 24px; color: var(--muted); font-size: 1.08rem; }
.feature-list { display: grid; gap: 14px; list-style: none; }
.feature-list li { display: flex; gap: 14px; padding: 19px 21px; border: 1px solid var(--line); border-radius: 14px; color: var(--ink-soft); background: white; font-weight: 600; box-shadow: 0 8px 28px rgba(7,17,31,.04); }
.feature-list li::before { display: grid; flex: 0 0 26px; height: 26px; place-items: center; border-radius: 50%; color: var(--blue); background: #e5edff; content: "\2713"; font-size: .75rem; }
.value-strip { padding: 34px 0; color: white; background: var(--blue); }
.value-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 35px; }
.value-item { padding-left: 22px; border-left: 2px solid rgba(255,255,255,.35); }
.value-item strong { display: block; font: 700 1.08rem "Manrope"; }
.value-item span { color: #dbeafe; font-size: .86rem; }
.service-detail { padding: 105px 0; background: white; }
.service-detail.alt { background: var(--paper); }
.detail-heading { max-width: 760px; margin-bottom: 42px; }
.detail-heading h2 { margin-top: 14px; color: var(--ink); font-size: clamp(2.15rem,4vw,3.5rem); line-height: 1.08; }
.detail-heading p { margin-top: 18px; color: var(--muted); font-size: 1.02rem; }
.technology-list { display: flex; flex-wrap: wrap; gap: 10px; }
.technology-list li { padding: 10px 14px; border: 1px solid #cddaf3; border-radius: 999px; color: var(--ink-soft); background: #f4f7fd; font-size: .82rem; font-weight: 700; list-style: none; }
.detail-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.detail-card { padding: 26px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: 0 10px 32px rgba(7,17,31,.05); }
.detail-card small { color: var(--blue); font-size: .7rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.detail-card h3 { margin-top: 18px; color: var(--ink); font-size: 1.12rem; }
.detail-card p { margin-top: 9px; color: var(--muted); font-size: .88rem; }
.example-panel { display: grid; grid-template-columns: .75fr 1.25fr; gap: 65px; align-items: start; padding: 42px; border-radius: 24px; color: white; background: linear-gradient(125deg,#08172a,#0b2b57); }
.example-panel .eyebrow { color: #7dd3fc; }
.example-panel h2 { margin-top: 15px; color: white; font-size: clamp(2rem,3.5vw,3rem); line-height: 1.08; }
.example-content p { color: #b5c4d7; }
.example-content p + p { margin-top: 15px; }
.example-outcomes { display: grid; gap: 10px; margin-top: 24px; list-style: none; }
.example-outcomes li { display: flex; gap: 10px; color: #e0eaf6; font-size: .88rem; }
.example-outcomes li::before { color: #7dd3fc; content: "\2713"; font-weight: 800; }
.other-services { padding: 100px 0; background: var(--paper); }
.section-copy { max-width: 650px; margin-top: 18px; color: var(--muted); }
.service-links { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 45px; }
.service-link { padding: 24px; border: 1px solid var(--line); border-radius: 17px; background: white; text-decoration: none; transition: transform .2s,box-shadow .2s,border-color .2s; }
.service-link:hover { transform: translateY(-4px); border-color: #aec4f6; box-shadow: 0 18px 40px rgba(7,17,31,.09); }
.service-link small { color: var(--blue); font-weight: 700; letter-spacing: .1em; }
.service-link h3 { margin-top: 25px; color: var(--ink); font-size: 1.1rem; }
.service-link p { margin-top: 7px; color: var(--muted); font-size: .86rem; }
.cta { padding: 95px 0; color: white; background: linear-gradient(125deg,#08172a,#0b2b57); text-align: center; }
.cta h2 { max-width: 760px; margin-inline: auto; font-size: clamp(2.2rem,4vw,3.8rem); line-height: 1.08; }
.cta p { max-width: 620px; margin: 20px auto 30px; color: #a9b9ce; }

.careers-intro { padding: 100px 0; text-align: center; }
.careers-intro p { max-width: 760px; margin: 22px auto 0; color: var(--muted); font-size: 1.08rem; }
.benefits { padding: 100px 0; background: var(--paper); }
.benefit-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 45px; }
.benefit { padding: 28px; border: 1px solid var(--line); border-radius: 18px; background: white; }
.benefit-number { color: var(--blue); font: 700 .74rem "Manrope"; letter-spacing: .1em; }
.benefit h3 { margin-top: 25px; color: var(--ink); font-size: 1.08rem; }
.benefit p { margin-top: 8px; color: var(--muted); font-size: .87rem; }
.positions { padding: 105px 0; }
.jobs { display: grid; gap: 14px; margin-top: 45px; }
.job { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 35px; padding: 25px 28px; border: 1px solid var(--line); border-radius: 17px; transition: transform .2s,border-color .2s,box-shadow .2s; }
.job:hover { transform: translateY(-3px); border-color: #adc4f7; box-shadow: 0 18px 42px rgba(7,17,31,.08); }
.job h3 { color: var(--ink); font-size: 1.08rem; }
.job-meta { color: var(--muted); font-size: .86rem; }
.job a { color: var(--blue); font-size: .86rem; font-weight: 700; text-decoration: none; white-space: nowrap; }

.contact-section { padding: 105px 0; }
.contact-page { min-height: 100vh; padding: 150px 0 90px; color: white; background: linear-gradient(145deg,#07111f 0%,#0a213e 58%,#0b2b57 100%); }
.contact-experience .contact-panel { position: relative; overflow: hidden; padding: 0; color: white; }
.contact-experience .contact-panel::before { position: absolute; top: -190px; right: -150px; width: 500px; height: 500px; border: 1px solid rgba(125,211,252,.2); border-radius: 50%; box-shadow: 0 0 0 75px rgba(125,211,252,.04),0 0 0 150px rgba(125,211,252,.025); content: ""; }
.contact-experience .contact-panel::after { position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px); background-size: 72px 72px; mask-image: linear-gradient(110deg,black,transparent 65%); content: ""; }
.contact-heading { position: relative; z-index: 1; max-width: 850px; padding-bottom: 52px; }
.contact-heading h1 { margin-top: 20px; font-size: clamp(3.2rem,6vw,5.7rem); line-height: .98; }
.contact-heading p { max-width: 650px; margin-top: 22px; color: #aebdd1; font-size: 1.08rem; }
.contact-layout { position: relative; z-index: 1; display: grid; grid-template-columns: .86fr 1.14fr; gap: 64px; align-items: stretch; padding: 52px 0; border-top: 1px solid rgba(255,255,255,.13); }
.contact-layout > *, .footer-grid > *, .contact-card > * { min-width: 0; }
.contact-layout > div:first-child { display: flex; flex-direction: column; }
.contact-experience .eyebrow { color: #7dd3fc; }
.contact-layout h2 { color: white; font-size: clamp(2.15rem,4vw,3.5rem); line-height: 1.08; }
.contact-experience .lead { color: #a9b9ce; }
.contact-points { display: grid; gap: 10px; margin-top: 25px; color: #c7d6e8; font-size: .84rem; font-weight: 600; }
.contact-points span { display: flex; align-items: center; gap: 9px; }
.contact-points span::before { color: #7dd3fc; content: "\2713"; }
.contact-cards { display: grid; gap: 10px; margin-top: 28px; }
.contact-card { display: grid; grid-template-columns: 42px 1fr; align-items: center; gap: 14px; padding: 13px 15px; border: 1px solid rgba(255,255,255,.12); border-radius: 14px; color: inherit; background: rgba(255,255,255,.055); text-decoration: none; transition: border-color .2s,background .2s,transform .2s; }
.contact-card:hover { transform: translateX(3px); border-color: rgba(125,211,252,.4); background: rgba(255,255,255,.085); }
.contact-icon { display: grid; width: 42px; height: 42px; place-items: center; border-radius: 12px; color: #7dd3fc; background: rgba(56,189,248,.12); font-weight: 800; }
.contact-card small { display: block; color: #8297b2; font-size: .67rem; text-transform: uppercase; letter-spacing: .1em; }
.contact-card strong { display: block; margin-top: 2px; color: white; font: 700 .86rem "Manrope"; }
.contact-card strong, .footer-links li { overflow-wrap: anywhere; }
.message-panel { padding: 32px; border: 1px solid rgba(255,255,255,.16); border-radius: 22px; background: rgba(255,255,255,.075); box-shadow: 0 28px 65px rgba(0,0,0,.22); backdrop-filter: blur(14px); }
.form-kicker { color: #7dd3fc; font: 700 .72rem "Manrope"; letter-spacing: .13em; text-transform: uppercase; }
.message-panel h3 { margin-top: 8px; color: white; font-size: 1.65rem; }
.message-panel > p { margin-top: 7px; color: #9fb0c6; font-size: .88rem; }
.contact-action-panel .eyebrow { margin-bottom: 14px; }
.contact-action-panel .button { margin-top: 28px; }
.contact-guidance { padding-top: 25px; border-top: 1px solid var(--line); }
.privacy-link { display: inline-block; margin-top: 15px; color: var(--blue); font-size: .86rem; font-weight: 700; text-decoration: none; }
.message-form { display: grid; grid-template-columns: 1fr 1fr; gap: 11px 14px; margin-top: 18px; }
.form-field { display: grid; gap: 7px; }
.form-field.full, .form-status, .form-actions { grid-column: 1 / -1; }
.form-field label { color: #c4d0df; font-size: .75rem; font-weight: 700; }
.form-field input, .form-field select, .form-field textarea { width: 100%; border: 1px solid rgba(255,255,255,.16); border-radius: 11px; color: white; background: rgba(255,255,255,.07); outline: 0; transition: border-color .2s,background .2s,box-shadow .2s; }
.form-field input { height: 44px; padding: 0 13px; }
.form-field select { height: 44px; padding: 0 38px 0 13px; }
.form-field textarea { min-height: 102px; padding: 11px 13px; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: #7dd3fc; background: rgba(255,255,255,.1); box-shadow: 0 0 0 4px rgba(56,189,248,.1); }
.form-field select option { color: var(--ink); background: white; }
.form-field textarea::placeholder { color: #7f92aa; }
.form-field label span, .form-field small { color: #8194ad; font-weight: 400; }
.form-field small { justify-self: end; font-size: .7rem; }
.consent-field { display: flex; align-items: flex-start; gap: 9px; color: #9fb0c6; font-size: .73rem; line-height: 1.45; }
.consent-field input { flex: 0 0 auto; width: 17px; height: 17px; margin-top: 2px; accent-color: var(--blue); }
.consent-field a { color: #7dd3fc; }
.form-actions { display: flex; align-items: center; gap: 13px; }
.submit-button { min-height: 46px; padding: 0 22px; border: 0; border-radius: 999px; color: var(--ink); background: #7dd3fc; box-shadow: 0 14px 30px rgba(56,189,248,.2); font-weight: 800; cursor: pointer; transition: background .2s,transform .2s; }
.submit-button:hover { transform: translateY(-2px); background: #bae6fd; }
.submit-button:disabled { cursor: wait; opacity: .65; }
.form-status { display: none; padding: 12px 14px; border-radius: 10px; font-size: .86rem; font-weight: 600; }
.form-status.visible { display: block; }
.form-status.success { color: #166534; background: #dcfce7; }
.form-status.error { color: #991b1b; background: #fee2e2; }
.form-note { color: #8295af; font-size: .68rem; line-height: 1.4; }
.honeypot { position: absolute !important; left: -9999px !important; }
.contact-office { position: relative; z-index: 1; display: grid; grid-template-columns: .72fr 1.28fr; gap: 48px; align-items: center; padding-top: 52px; border-top: 1px solid rgba(255,255,255,.13); }
.office-copy h2 { margin-top: 10px; color: white; font-size: clamp(2rem,3vw,3rem); }
.office-copy p { margin-top: 15px; color: #9fb0c6; }
.office-link { display: inline-block; margin-top: 24px; color: #7dd3fc; font-weight: 700; text-decoration: none; }
.office-map { overflow: hidden; border: 1px solid rgba(255,255,255,.16); border-radius: 20px; box-shadow: 0 24px 60px rgba(0,0,0,.22); }
.office-map iframe { display: block; width: 100%; height: 320px; border: 0; filter: saturate(.82) contrast(.96); }
.map-section { padding: 0 0 105px; background: white; }
.map-header { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 30px; }
.map-header h2 { color: var(--ink); font-size: clamp(2rem,3vw,3rem); }
.map-link { color: var(--blue); font-weight: 700; text-decoration: none; white-space: nowrap; }
.map-frame { overflow: hidden; border: 1px solid var(--line); border-radius: 22px; box-shadow: var(--shadow); }
.map-frame iframe { display: block; width: 100%; height: 470px; border: 0; }
.legal-section { padding: 95px 0; }
.legal-content { max-width: 820px; }
.legal-content h2 { margin-top: 42px; color: var(--ink); font-size: 1.45rem; letter-spacing: -.025em; }
.legal-content h2:first-child { margin-top: 0; }
.legal-content p, .legal-content li { color: var(--muted); }
.legal-content p { margin-top: 13px; }
.legal-content ul { display: grid; gap: 8px; margin: 14px 0 0 21px; }
.legal-content a { color: var(--blue); }
.notice-box { margin: 25px 0; padding: 20px 22px; border: 1px solid #c8d7f5; border-radius: 14px; color: var(--ink-soft); background: #f3f7ff; }
.error-page { display: grid; min-height: 100vh; place-items: center; padding: 40px 0; color: white; background: var(--ink); text-align: center; }
.error-code { color: #7dd3fc; font: 800 clamp(5rem,20vw,10rem) "Manrope"; line-height: .9; }
.error-page h1 { margin-top: 20px; font-size: clamp(2rem,5vw,3.5rem); }
.error-page p { max-width: 560px; margin: 16px auto 28px; color: #aebdd1; }

footer { padding: 50px 0 28px; color: #97a8bd; background: #050c16; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 60px; padding-bottom: 38px; }
.footer-brand p { max-width: 390px; margin-top: 16px; font-size: .88rem; }
.footer-title { margin-bottom: 14px; color: white; font: 700 .78rem "Manrope"; letter-spacing: .1em; text-transform: uppercase; }
.footer-links { display: grid; gap: 8px; list-style: none; }
.footer-links a { font-size: .87rem; text-decoration: none; }
.footer-links a:hover { color: white; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.08); font-size: .77rem; }

@media (max-width: 900px) {
  .hero-grid, .content-grid, .contact-layout, .example-panel { grid-template-columns: 1fr; gap: 55px; }
  .contact-office { grid-template-columns: 1fr; gap: 30px; }
  .hero-image { max-width: 620px; }
  .service-links, .benefit-grid, .detail-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  .shell { width: min(100% - 32px,1160px); }
  .menu-button { position: relative; z-index: 2; display: block; flex: 0 0 44px; }
  .nav-links { position: fixed; inset: 78px 0 auto; display: grid; gap: 0; padding: 15px 16px 24px; border-bottom: 1px solid rgba(255,255,255,.12); background: rgba(7,17,31,.98); transform: translateY(-130%); transition: transform .25s; }
  .nav-links.active { transform: none; }
  .nav-links a { display: block; padding: 13px 10px; }
  .nav-cta { margin-top: 8px; text-align: center; }
  .page-hero { padding: 145px 0 82px; }
  .page-hero h1 { font-size: clamp(2.7rem,13vw,4rem); }
  .hero-image { display: none; }
  .content-section, .other-services, .benefits, .positions { padding: 78px 0; }
  .value-grid, .service-links, .benefit-grid, .detail-grid { grid-template-columns: 1fr; }
  .service-detail { padding: 78px 0; }
  .example-panel { padding: 30px 22px; }
  .job { grid-template-columns: 1fr; gap: 8px; }
  .job a { margin-top: 10px; }
  .contact-section { padding: 78px 0; }
  .contact-page { padding: 130px 0 70px; }
  .contact-heading { padding-bottom: 40px; }
  .contact-heading h1 { font-size: clamp(2.8rem,13vw,4rem); }
  .contact-layout { padding: 40px 0; }
  .contact-office { padding-top: 40px; }
  .office-map iframe { height: 300px; }
  .message-panel { padding: 26px 20px; }
  .message-form { grid-template-columns: 1fr; }
  .form-field.full, .form-status, .form-actions { grid-column: auto; }
  .form-actions, .map-header { align-items: flex-start; flex-direction: column; }
  .map-frame iframe { height: 390px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 35px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { transition-duration: .01ms !important; }
}
