:root {
  --blue: #1165ff;
  --blue-dark: #014de7;
  --ink: #07143e;
  --muted: #43527a;
  --line: #dbe4f5;
  --soft: #f5f9ff;
  --white: #ffffff;
  --teal: #08b5b6;
  --shadow: 0 18px 44px rgba(7, 20, 62, .10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  color: var(--ink);
  background: #fff;
  font-size: 16px;
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
.container { width: min(1160px, calc(100% - 64px)); margin: 0 auto; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav { height: 67px; display: flex; align-items: center; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 12px; font-size: 24px; font-weight: 800; letter-spacing: 0; }
.brand-mark { width: 28px; height: 28px; display: inline-flex; flex: 0 0 auto; }
.brand-mark svg { width: 100%; height: 100%; fill: none; stroke: var(--blue); stroke-width: 2.8; stroke-linejoin: round; }
.brand-mark svg path + path { stroke-width: 2.3; }
.nav-links { flex: 1; display: flex; justify-content: center; gap: 29px; font-size: 14px; font-weight: 600; color: #12204c; }
.nav-links a { white-space: nowrap; }
.nav-actions { display: flex; align-items: center; gap: 16px; }
.lang { border: 0; border-left: 1px solid var(--line); background: transparent; padding: 0 0 0 18px; color: #07143e; font-weight: 800; cursor: pointer; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 44px;
  padding: 0 24px;
  border: 1px solid var(--blue);
  border-radius: 5px;
  background: var(--blue);
  color: #fff;
  font-weight: 800;
  font-size: 15px;
  box-shadow: 0 10px 22px rgba(17,101,255,.22);
  cursor: pointer;
}
.button-small { min-height: 40px; padding: 0 18px; }
.button-secondary { background: #fff; border-color: #bcc9df; color: #172349; box-shadow: none; min-width: 178px; }

.section-band {
  background:
    radial-gradient(circle at 62% 52%, rgba(17,101,255,.10), transparent 27%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%);
  border-bottom: 1px solid var(--line);
}
.hero-grid {
  display: grid;
  grid-template-columns: 47% 53%;
  min-height: 432px;
  align-items: center;
  gap: 8px;
}
.hero-copy { padding: 28px 0 18px; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-size: 37px; line-height: 1.17; margin-bottom: 22px; letter-spacing: 0; color: #060b19; }
h1 span { color: var(--blue); display: block; }
.hero-copy p { max-width: 540px; font-size: 19px; color: #273960; margin-bottom: 30px; }
.hero-buttons { display: flex; gap: 30px; align-items: center; margin-bottom: 34px; }
.trust-list { list-style: none; display: flex; gap: 32px; padding: 0; margin: 0; color: #15224b; font-weight: 600; font-size: 14px; }
.trust-list li { display: flex; align-items: center; gap: 9px; white-space: nowrap; }
.check-icon { width: 25px; height: 25px; border: 2px solid var(--blue); border-radius: 50%; display: inline-block; position: relative; flex: 0 0 auto; }
.check-icon:after { content: ""; position: absolute; left: 7px; top: 5px; width: 7px; height: 11px; border-right: 2px solid var(--blue); border-bottom: 2px solid var(--blue); transform: rotate(45deg); }
.check-icon.cog:before { content: "✣"; position: absolute; left: 4px; top: 1px; color: var(--blue); font-size: 15px; }
.check-icon.cog:after { display: none; }

.hero-visual { position: relative; min-height: 405px; perspective: 900px; }
.laptop { position: absolute; right: 70px; top: 33px; width: 330px; transform: rotateX(7deg) rotateY(-6deg) rotateZ(4deg); filter: drop-shadow(0 34px 34px rgba(14,31,69,.25)); }
.screen { min-height: 245px; padding: 18px; border: 11px solid #07080c; border-radius: 12px 12px 4px 4px; background: #f8fbff; box-shadow: inset 0 0 0 1px #cdd7e8; }
.keyboard { width: 370px; height: 74px; margin-left: -20px; background: linear-gradient(180deg, #d8dde7, #b9c0cc); border-radius: 6px 6px 28px 28px; transform: perspective(300px) rotateX(46deg); margin-top: -5px; }
.dashboard-top { display: grid; grid-template-columns: 92px 1fr; gap: 12px; }
.score, .speed, .growth, .modules { background: #fff; border: 1px solid #dce5f4; border-radius: 7px; padding: 12px; }
.score { text-align: center; }
.score span, .speed span, .growth span, .modules span { display: block; font-size: 9px; font-weight: 800; margin-bottom: 9px; color: #1a2957; }
.score strong { display: grid; place-items: center; margin: 0 auto 3px; width: 58px; height: 58px; border: 7px solid var(--teal); border-left-color: var(--blue); border-radius: 50%; font-size: 22px; }
.score small, .growth small { color: var(--muted); font-size: 9px; }
.speed strong { display: block; font-size: 15px; margin-bottom: 10px; }
.speed svg, .systems svg { width: 100%; height: 40px; fill: none; stroke: var(--blue); stroke-width: 3; }
.dashboard-bottom { display: grid; grid-template-columns: 104px 1fr; gap: 12px; margin-top: 12px; }
.growth strong { display: block; font-size: 24px; margin-bottom: 3px; }
.modules p { display: flex; align-items: center; justify-content: space-between; margin: 7px 0; font-size: 11px; font-weight: 700; }
.modules i { width: 11px; height: 11px; background: var(--blue); border-radius: 3px; }
.modules p:after { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #0db981; }
.float-card { position: absolute; background: #fff; border: 1px solid #dfe7f4; border-radius: 8px; box-shadow: var(--shadow); padding: 15px; transform: rotate(5deg); }
.float-card strong { display: block; font-size: 12px; margin-bottom: 11px; }
.systems { width: 128px; left: 70px; top: 70px; transform: rotate(5deg); }
.systems p { display: flex; gap: 7px; align-items: center; margin: 7px 0; font-size: 10px; font-weight: 700; color: #263864; }
.systems span { width: 7px; height: 7px; border: 1px solid #6e7e9f; border-radius: 50%; }
.integrations { width: 145px; right: 4px; top: 115px; min-height: 136px; transform: rotate(7deg); }
.nodes { display: grid; grid-template-columns: repeat(3, 35px); grid-template-rows: repeat(2, 35px); place-items: center; }
.nodes span { width: 28px; height: 28px; display: grid; place-items: center; color: #fff; background: var(--blue); border-radius: 7px; font-size: 10px; font-weight: 900; }
.nodes span:nth-child(1) { grid-column: 2; }
.nodes span:nth-child(2) { grid-column: 1; grid-row: 2; }
.nodes span:nth-child(3) { grid-column: 2; grid-row: 2; }
.nodes span:nth-child(4) { grid-column: 3; grid-row: 2; }
.analytics { width: 145px; left: 27px; bottom: 61px; transform: rotate(10deg); }
.mini-chart { display: flex; align-items: end; gap: 7px; height: 58px; padding-left: 49px; position: relative; }
.mini-chart:before { content: ""; position: absolute; left: 0; top: 3px; width: 45px; height: 45px; border-radius: 50%; background: conic-gradient(var(--blue) 0 45%, var(--teal) 45% 72%, #dfe9f9 72%); }
.mini-chart span { width: 9px; background: var(--blue); border-radius: 2px 2px 0 0; }
.mini-chart span:nth-child(1) { height: 16px; opacity: .35; }
.mini-chart span:nth-child(2) { height: 25px; opacity: .55; }
.mini-chart span:nth-child(3) { height: 31px; opacity: .7; }
.mini-chart span:nth-child(4) { height: 42px; }
.mini-chart span:nth-child(5) { height: 51px; }
.flow { width: 167px; right: 20px; bottom: 24px; transform: rotate(8deg); }
.flow b { display: block; font-size: 24px; margin-bottom: 3px; }
.bars { height: 55px; display: flex; align-items: end; gap: 8px; justify-content: flex-end; }
.bars span { width: 12px; background: var(--blue); border-radius: 3px 3px 0 0; }
.bars span:nth-child(1) { height: 18px; opacity: .4; }
.bars span:nth-child(2) { height: 29px; opacity: .65; }
.bars span:nth-child(3) { height: 43px; opacity: .85; }
.bars span:nth-child(4) { height: 55px; }

.services, .process, .offers, .projects, .contact { padding: 42px 0; }
.services { padding-top: 46px; }
.process { padding-top: 30px; }
.offers { padding-top: 42px; }
.projects { padding-top: 34px; }
.contact { padding-top: 34px; }
.eyebrow { margin: 0 0 10px; text-align: center; color: var(--blue); font-size: 13px; font-weight: 900; text-transform: uppercase; }
h2 { text-align: center; font-size: 27px; line-height: 1.25; margin-bottom: 30px; }
.card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  box-shadow: 0 8px 24px rgba(7,20,62,.04);
}
.service-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; }
.service-grid-compact { grid-template-columns: repeat(4, 1fr); max-width: 1060px; margin: 0 auto; gap: 28px; }
.service-card { min-height: 268px; padding: 36px 26px 28px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.icon { width: 49px; height: 49px; border-radius: 50%; background: #eaf2ff; display: inline-block; margin-bottom: 19px; position: relative; color: var(--blue); }
.icon:before, .icon:after, .chat-icon:before, .chat-icon:after { content: ""; position: absolute; }
.search:before { width: 20px; height: 20px; border: 4px solid var(--blue); border-radius: 50%; left: 11px; top: 10px; }
.search:after { width: 16px; height: 4px; background: var(--blue); transform: rotate(45deg); right: 8px; bottom: 12px; border-radius: 2px; }
.gear:before { content: "⚙"; color: var(--blue); font-size: 31px; line-height: 49px; inset: 0; text-align: center; }
.monitor:before { width: 26px; height: 17px; border: 3px solid var(--blue); left: 10px; top: 11px; border-radius: 2px; }
.monitor:after { width: 22px; height: 3px; background: var(--blue); left: 13px; top: 33px; box-shadow: 8px -4px 0 -1px var(--blue); }
.cloud:before { content: "☁"; color: var(--blue); font-size: 34px; line-height: 48px; inset: 0; text-align: center; }
.headset:before { width: 25px; height: 22px; border: 4px solid var(--blue); border-bottom: 0; border-radius: 18px 18px 0 0; left: 10px; top: 12px; }
.headset:after { width: 7px; height: 16px; background: var(--blue); left: 10px; top: 27px; box-shadow: 21px 0 0 var(--blue); border-radius: 3px; }
.bars-icon:before, .growth-icon:before { width: 5px; height: 24px; background: var(--blue); left: 13px; top: 14px; box-shadow: 10px -8px 0 var(--blue), 20px -15px 0 var(--blue); border-radius: 2px; }
.sitemap:before { width: 7px; height: 7px; background: var(--blue); left: 21px; top: 10px; box-shadow: -14px 18px 0 var(--blue), 14px 18px 0 var(--blue); border-radius: 2px; }
.sitemap:after { width: 31px; height: 17px; border: 3px solid var(--blue); border-top: 0; left: 8px; top: 17px; }
.rocket:before { content: "↗"; color: var(--blue); font-size: 39px; line-height: 47px; inset: 0; text-align: center; font-weight: 900; }
.service-card h3 { font-size: 18px; line-height: 1.3; margin-bottom: 13px; }
.service-card p { color: var(--muted); font-size: 15px; line-height: 1.5; margin-bottom: 20px; max-width: 235px; }
.service-card a, .offer-card a, .project-card a { margin-top: auto; color: var(--blue); font-size: 14px; font-weight: 900; }
.offer-card a.button { color: #fff; }
.offer-card a.button:hover { color: #fff; }

.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 44px; margin-top: 10px; }
.process-card { position: relative; min-height: 128px; border: 1px solid var(--line); border-radius: 7px; padding: 26px 22px 22px 30px; display: flex; align-items: center; gap: 20px; background: #fff; }
.process-card:not(:last-child):after { content: "→"; position: absolute; right: -33px; color: var(--blue); font-size: 30px; top: 40px; }
.process-card b { position: absolute; left: 26px; top: 16px; width: 20px; height: 20px; border-radius: 50%; background: var(--blue); color: #fff; display: grid; place-items: center; font-size: 12px; }
.process-card .icon { margin: 0 0 0 32px; flex: 0 0 auto; }
.process-card h3 { font-size: 15px; line-height: 1.3; margin-bottom: 7px; }
.process-card p { color: var(--muted); margin: 0; font-size: 14px; line-height: 1.45; }

.offer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; max-width: 980px; margin: 8px auto 0; }
.offer-card { min-height: 315px; padding: 34px 38px; position: relative; }
.offer-card.featured { border: 2px solid var(--blue); box-shadow: 0 17px 35px rgba(17,101,255,.12); }
.offer-card h3 { text-align: center; font-size: 24px; line-height: 1.2; margin-bottom: 16px; }
.price { color: #273960; font-size: 18px; margin-bottom: 16px; }
.price strong { color: var(--blue); font-size: 34px; margin-left: 8px; }
.offer-card ul { margin: 0 0 22px; padding: 0; list-style: none; color: #1b2a53; font-size: 14px; line-height: 1.45; }
.offer-card li { margin: 8px 0; padding-left: 26px; position: relative; }
.offer-card li:before { content: "✓"; position: absolute; left: 0; top: 0; width: 14px; height: 14px; border: 1px solid #52617f; border-radius: 50%; display: grid; place-items: center; font-size: 9px; color: #213760; }
.offer-card.featured .button { width: 100%; min-height: 44px; font-size: 14px; }
.ribbon { position: absolute; right: -1px; top: -1px; width: 47px; height: 47px; background: var(--blue); color: #fff; display: grid; place-items: start end; padding: 8px 9px; clip-path: polygon(0 0, 100% 0, 100% 100%); }

.project-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 19px; }
.project-card { padding: 18px; min-height: 292px; text-align: center; }
.thumb { height: 105px; border-radius: 5px; margin-bottom: 15px; overflow: hidden; border: 1px solid #d9e3f2; }
.office { background: linear-gradient(120deg, rgba(5,13,34,.12), rgba(5,13,34,.02)), url("samogisoft_dizainas_v3.png") 6% 67% / 410% auto no-repeat; }
.flow-thumb { background:
  radial-gradient(circle at 50% 50%, #fff 0 14px, transparent 15px),
  linear-gradient(90deg, transparent 0 17%, #1165ff 17% 19%, transparent 19% 49%, #1165ff 49% 51%, transparent 51% 82%, #1165ff 82% 84%, transparent 84%),
  linear-gradient(#eef5ff, #fff); position: relative; }
.flow-thumb:before { content: ""; display: block; width: 100%; height: 100%; background: radial-gradient(circle at 18% 50%, #1165ff 0 13px, transparent 14px), radial-gradient(circle at 50% 35%, #1165ff 0 13px, transparent 14px), radial-gradient(circle at 82% 50%, #1165ff 0 13px, transparent 14px); }
.app-thumb { background: linear-gradient(90deg, #f7fbff 0 49%, #e8f1ff 49% 51%, #fff 51%), repeating-linear-gradient(0deg, transparent 0 18px, rgba(17,101,255,.12) 18px 19px); }
.dark-thumb { background: radial-gradient(circle at 72% 40%, rgba(14,181,182,.28), transparent 23%), linear-gradient(135deg, #09152b, #172447); position: relative; }
.dark-thumb:after { content: ""; display: block; height: 100%; background: linear-gradient(90deg, transparent 0 8%, #23e0a3 8% 9%, transparent 9% 30%, #f3b23b 30% 31%, transparent 31% 60%, #1165ff 60% 61%, transparent 61%), linear-gradient(180deg, transparent 70%, rgba(255,255,255,.18) 71%, transparent 72%); }
.project-card h3 { min-height: 50px; font-size: 18px; line-height: 1.25; margin-bottom: 14px; }
.metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; margin-bottom: 14px; }
.metrics span { color: #273960; font-size: 12px; line-height: 1.25; }
.metrics strong { display: block; color: #07143e; font-size: 20px; margin-bottom: 4px; }

.contact-panel { border: 1px solid var(--line); border-radius: 8px; display: grid; grid-template-columns: 47% 53%; overflow: hidden; }
.contact-copy { display: flex; gap: 26px; align-items: center; padding: 38px 46px; background: #fbfdff; }
.chat-icon { width: 100px; height: 100px; border-radius: 50%; background: #eaf2ff; position: relative; flex: 0 0 auto; }
.chat-icon:before { width: 46px; height: 33px; border: 4px solid var(--blue); border-radius: 6px; left: 27px; top: 29px; }
.chat-icon:after { width: 13px; height: 13px; border-left: 4px solid var(--blue); border-bottom: 4px solid var(--blue); left: 34px; top: 57px; transform: skew(-18deg); }
.contact-copy h2 { text-align: left; font-size: 28px; margin-bottom: 12px; }
.contact-copy p { color: var(--muted); font-size: 15px; margin: 0; }
.contact-form { padding: 16px 26px 18px; display: flex; flex-direction: column; gap: 8px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
input, textarea {
  width: 100%;
  border: 1px solid #cfd9ea;
  border-radius: 4px;
  padding: 10px 14px;
  font: inherit;
  color: var(--ink);
  outline-color: var(--blue);
}
textarea { min-height: 64px; resize: vertical; }
.contact-form .button { align-self: flex-start; min-height: 37px; font-size: 12px; }
.form-note { min-height: 18px; margin: 0; color: var(--blue); font-weight: 800; font-size: 12px; }

.site-footer { border-top: 1px solid var(--line); padding-top: 20px; }
.footer-grid { display: grid; grid-template-columns: 1.15fr .8fr 1fr 1fr; gap: 36px; padding-bottom: 20px; }
.footer-brand { font-size: 19px; margin-bottom: 14px; }
.site-footer p, .site-footer a { color: #33446d; font-size: 14px; line-height: 1.45; }
.site-footer h3 { font-size: 16px; margin-bottom: 12px; }
.site-footer a { display: block; margin: 7px 0; }
.socials { display: flex; gap: 10px; margin-top: 14px; }
.socials a { width: 18px; height: 18px; display: grid; place-items: center; border-radius: 4px; background: var(--blue); color: #fff; font-size: 11px; font-weight: 900; }
.contact-line { margin: 10px 0; }
.footer-bottom { border-top: 1px solid var(--line); padding: 14px 0; display: flex; justify-content: space-between; color: #586987; font-size: 13px; }
.footer-bottom span:last-child { display: flex; gap: 40px; }

.service-hero { padding: 58px 0 50px; border-bottom: 1px solid var(--line); }
.service-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 56px; align-items: center; }
.service-hero h1 { max-width: 720px; margin-bottom: 18px; }
.service-hero p:not(.eyebrow) { max-width: 730px; color: #273960; font-size: 19px; line-height: 1.6; margin-bottom: 28px; }
.service-eyebrow { text-align: left; }
.service-visual-card { min-height: 360px; padding: 26px; display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; }
.service-visual-card h2 { text-align: left; font-size: 24px; line-height: 1.3; margin: 22px 0 0; }
.service-graphic { position: relative; min-height: 205px; border-radius: 8px; background: linear-gradient(180deg, #f8fbff, #eef5ff); border: 1px solid #dbe6f8; overflow: hidden; }
.service-graphic:before, .service-graphic:after { content: ""; position: absolute; }
.service-graphic span { position: absolute; display: block; }
.audit-graphic:before { width: 95px; height: 95px; border: 12px solid var(--blue); border-right-color: var(--teal); border-radius: 50%; left: 42px; top: 42px; }
.audit-graphic:after { width: 76px; height: 12px; background: var(--blue); border-radius: 8px; transform: rotate(42deg); left: 119px; top: 124px; }
.audit-graphic span { height: 8px; border-radius: 8px; background: #b6c9ea; right: 32px; }
.audit-graphic span:nth-child(1) { width: 96px; top: 52px; background: var(--blue); }
.audit-graphic span:nth-child(2) { width: 74px; top: 82px; }
.audit-graphic span:nth-child(3) { width: 112px; top: 112px; }
.audit-graphic span:nth-child(4) { width: 64px; top: 142px; background: var(--teal); }
.audit-graphic span:nth-child(5) { width: 92px; top: 172px; }
.growth-graphic:before { left: 30px; right: 30px; bottom: 38px; height: 2px; background: #cbd9ef; }
.growth-graphic:after { left: 44px; top: 110px; width: 230px; height: 74px; background: linear-gradient(135deg, transparent 48%, var(--blue) 49% 52%, transparent 53%); }
.growth-graphic span { bottom: 40px; width: 34px; border-radius: 5px 5px 0 0; background: var(--blue); }
.growth-graphic span:nth-child(1) { left: 48px; height: 38px; opacity: .35; }
.growth-graphic span:nth-child(2) { left: 95px; height: 62px; opacity: .52; }
.growth-graphic span:nth-child(3) { left: 142px; height: 88px; opacity: .72; }
.growth-graphic span:nth-child(4) { left: 189px; height: 118px; }
.growth-graphic span:nth-child(5) { right: 35px; top: 38px; width: 42px; height: 42px; border-radius: 50%; background: var(--teal); }
.systems-graphic:before { left: 50%; top: 50%; width: 74px; height: 74px; margin: -37px 0 0 -37px; border-radius: 10px; background: var(--blue); box-shadow: 0 0 0 12px #dceaff; }
.systems-graphic:after { left: 71px; right: 71px; top: 102px; height: 3px; background: #97acd0; box-shadow: 0 -52px 0 #dce6f8, 0 52px 0 #dce6f8; }
.systems-graphic span { width: 46px; height: 46px; border-radius: 9px; background: #fff; border: 3px solid var(--blue); box-shadow: 0 10px 18px rgba(17,101,255,.12); }
.systems-graphic span:nth-child(1) { left: 38px; top: 34px; }
.systems-graphic span:nth-child(2) { right: 38px; top: 34px; }
.systems-graphic span:nth-child(3) { left: 38px; bottom: 34px; }
.systems-graphic span:nth-child(4) { right: 38px; bottom: 34px; }
.systems-graphic span:nth-child(5) { left: 50%; top: 50%; transform: translate(-50%, -50%); width: 24px; height: 24px; border: 0; background: #fff; border-radius: 6px; }
.analytics-graphic:before { left: 38px; top: 34px; width: 92px; height: 92px; border-radius: 50%; background: conic-gradient(var(--blue) 0 46%, var(--teal) 46% 73%, #d9e6f8 73%); }
.analytics-graphic:after { left: 61px; top: 57px; width: 46px; height: 46px; border-radius: 50%; background: #f8fbff; }
.analytics-graphic span { bottom: 36px; width: 22px; border-radius: 5px 5px 0 0; background: var(--blue); }
.analytics-graphic span:nth-child(1) { left: 166px; height: 42px; opacity: .35; }
.analytics-graphic span:nth-child(2) { left: 201px; height: 66px; opacity: .55; }
.analytics-graphic span:nth-child(3) { left: 236px; height: 96px; opacity: .78; }
.analytics-graphic span:nth-child(4) { left: 271px; height: 122px; }
.analytics-graphic span:nth-child(5) { left: 42px; bottom: 38px; width: 92px; height: 8px; border-radius: 8px; background: #b6c9ea; }
.automation-graphic:before { left: 46px; top: 56px; width: 58px; height: 58px; border-radius: 12px; background: #fff; border: 4px solid var(--blue); box-shadow: 144px 0 0 -4px #fff, 144px 0 0 0 var(--blue), 72px 82px 0 -4px #fff, 72px 82px 0 0 var(--teal); }
.automation-graphic:after { left: 104px; top: 83px; width: 144px; height: 86px; border: 4px solid #b7c9ea; border-top: 0; border-radius: 0 0 18px 18px; }
.automation-graphic span:nth-child(1) { left: 130px; top: 76px; width: 42px; height: 4px; border-radius: 4px; background: var(--blue); }
.automation-graphic span:nth-child(2) { left: 168px; top: 66px; width: 0; height: 0; border-top: 12px solid transparent; border-bottom: 12px solid transparent; border-left: 17px solid var(--blue); }
.automation-graphic span:nth-child(3) { left: 90px; top: 148px; width: 58px; height: 4px; border-radius: 4px; background: var(--teal); transform: rotate(33deg); }
.automation-graphic span:nth-child(4) { left: 199px; top: 148px; width: 58px; height: 4px; border-radius: 4px; background: var(--teal); transform: rotate(-33deg); }
.automation-graphic span:nth-child(5) { left: 50%; top: 92px; width: 34px; height: 34px; margin-left: -17px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 0 10px #dceaff; }
.service-intro { padding: 34px 0 10px; }
.service-intro-grid { display: grid; grid-template-columns: minmax(0, 1fr) 430px; gap: 32px; align-items: start; }
.service-intro h2 { text-align: left; margin-bottom: 14px; }
.service-intro p:not(.eyebrow) { color: var(--muted); font-size: 17px; line-height: 1.6; max-width: 720px; }
.service-stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.service-stat { padding: 18px 14px; min-height: 105px; }
.service-stat strong { display: block; color: var(--blue); font-size: 24px; line-height: 1.1; margin-bottom: 8px; }
.service-stat span { color: var(--muted); font-size: 14px; line-height: 1.35; font-weight: 700; }
.service-detail { padding: 24px 0 16px; }
.service-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
.detail-card { padding: 31px; }
.detail-card h2 { text-align: left; margin-bottom: 18px; }
.check-list { list-style: none; padding: 0; margin: 0; color: #1b2a53; }
.check-list li { position: relative; padding-left: 34px; margin: 14px 0; font-size: 16px; line-height: 1.45; }
.check-list li:before { content: "✓"; position: absolute; left: 0; top: 1px; width: 18px; height: 18px; border: 1px solid var(--blue); border-radius: 50%; display: grid; place-items: center; font-size: 11px; color: var(--blue); font-weight: 900; }
.service-workflow { padding: 18px 0; }
.workflow-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.workflow-card { position: relative; min-height: 150px; padding: 28px 20px 20px; border: 1px solid var(--line); border-radius: 7px; background: #fff; }
.workflow-card b { position: absolute; left: 18px; top: -13px; width: 28px; height: 28px; border-radius: 50%; background: var(--blue); color: #fff; display: grid; place-items: center; font-size: 13px; }
.workflow-card p { color: var(--muted); margin: 0; font-size: 15px; line-height: 1.5; }
.service-use-cases { padding: 16px 0 20px; }
.use-case-panel { display: grid; grid-template-columns: 310px minmax(0, 1fr); gap: 26px; padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: #fbfdff; }
.use-case-panel h2 { text-align: left; margin: 0; }
.use-case-list { list-style: none; display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 0; margin: 0; }
.use-case-list li { padding: 16px 18px; border: 1px solid #dbe6f8; border-radius: 6px; background: #fff; color: #1b2a53; font-weight: 700; font-size: 15px; line-height: 1.4; }
.current-service { border-color: var(--blue); box-shadow: 0 14px 30px rgba(17,101,255,.10); }

.offer-hero { padding: 58px 0 54px; border-bottom: 1px solid var(--line); }
.offer-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 410px; gap: 56px; align-items: center; }
.offer-hero h1 { max-width: 760px; margin-bottom: 14px; }
.offer-hero-copy > p:not(.eyebrow) { max-width: 740px; color: #273960; font-size: 18px; line-height: 1.62; margin-bottom: 18px; }
.offer-subtitle { color: var(--ink) !important; font-size: 22px !important; line-height: 1.35 !important; font-weight: 800; }
.offer-price-line { display: flex; align-items: baseline; gap: 12px; margin: 24px 0 26px; }
.offer-price-line span { color: #273960; font-size: 18px; }
.offer-price-line strong { color: var(--blue); font-size: 44px; line-height: 1; }
.offer-visual-card { padding: 24px; min-height: 420px; overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; }
.offer-graphic { position: relative; min-height: 250px; border-radius: 8px; border: 1px solid #dbe6f8; background: linear-gradient(180deg, #f8fbff, #eef5ff); overflow: hidden; }
.offer-graphic:before, .offer-graphic:after { content: ""; position: absolute; }
.offer-graphic span { position: absolute; display: block; }
.offer-audit-graphic:before { width: 112px; height: 112px; border: 14px solid var(--blue); border-right-color: var(--teal); border-radius: 50%; left: 48px; top: 48px; }
.offer-audit-graphic:after { width: 88px; height: 14px; background: var(--blue); border-radius: 9px; transform: rotate(42deg); left: 138px; top: 144px; }
.offer-audit-graphic span { right: 34px; height: 10px; border-radius: 10px; background: #b6c9ea; }
.offer-audit-graphic span:nth-child(1) { width: 118px; top: 54px; background: var(--blue); }
.offer-audit-graphic span:nth-child(2) { width: 90px; top: 91px; }
.offer-audit-graphic span:nth-child(3) { width: 132px; top: 128px; }
.offer-audit-graphic span:nth-child(4) { width: 74px; top: 165px; background: var(--teal); }
.offer-audit-graphic span:nth-child(5) { width: 112px; top: 202px; }
.offer-sprint-graphic:before { left: 34px; right: 34px; bottom: 45px; height: 3px; background: #cbd9ef; }
.offer-sprint-graphic:after { right: 42px; top: 40px; width: 72px; height: 72px; border-radius: 50%; background: var(--teal); box-shadow: 0 0 0 14px #dff7f7; }
.offer-sprint-graphic span { bottom: 47px; width: 38px; border-radius: 6px 6px 0 0; background: var(--blue); }
.offer-sprint-graphic span:nth-child(1) { left: 48px; height: 48px; opacity: .36; }
.offer-sprint-graphic span:nth-child(2) { left: 102px; height: 78px; opacity: .56; }
.offer-sprint-graphic span:nth-child(3) { left: 156px; height: 112px; opacity: .78; }
.offer-sprint-graphic span:nth-child(4) { left: 210px; height: 150px; }
.offer-sprint-graphic span:nth-child(5) { left: 60px; top: 74px; width: 198px; height: 5px; border-radius: 5px; background: var(--blue); transform: rotate(-18deg); transform-origin: left center; }
.offer-partner-graphic:before { left: 42px; top: 42px; width: 92px; height: 128px; border-radius: 10px; background: #fff; border: 3px solid #dbe6f8; box-shadow: 116px 0 0 #fff, 116px 0 0 3px #dbe6f8; }
.offer-partner-graphic:after { left: 136px; top: 72px; width: 108px; height: 76px; border: 4px solid var(--blue); border-left: 0; border-radius: 0 22px 22px 0; }
.offer-partner-graphic span:nth-child(1) { left: 62px; top: 67px; width: 52px; height: 8px; border-radius: 8px; background: var(--blue); box-shadow: 0 30px 0 #b6c9ea, 0 60px 0 #b6c9ea; }
.offer-partner-graphic span:nth-child(2) { left: 178px; top: 67px; width: 52px; height: 8px; border-radius: 8px; background: var(--teal); box-shadow: 0 30px 0 #b6c9ea, 0 60px 0 #b6c9ea; }
.offer-partner-graphic span:nth-child(3) { left: 50%; bottom: 34px; width: 68px; height: 68px; margin-left: -34px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 0 12px #dceaff; }
.offer-partner-graphic span:nth-child(4) { left: 50%; bottom: 57px; width: 30px; height: 16px; margin-left: -15px; border: 4px solid #fff; border-top: 0; border-radius: 0 0 16px 16px; }
.offer-partner-graphic span:nth-child(5) { left: 50%; bottom: 79px; width: 18px; height: 18px; margin-left: -9px; border-radius: 50%; background: #fff; }
.offer-mini-list { display: grid; gap: 10px; margin-top: 18px; }
.offer-mini-list p { margin: 0; padding: 11px 13px 11px 36px; border: 1px solid #dbe6f8; border-radius: 6px; background: #fff; color: #1b2a53; font-size: 14px; font-weight: 800; position: relative; }
.offer-mini-list p:before { content: "✓"; position: absolute; left: 13px; top: 12px; width: 16px; height: 16px; display: grid; place-items: center; border: 1px solid var(--blue); border-radius: 50%; color: var(--blue); font-size: 10px; }
.offer-outcomes { padding: 32px 0 14px; }
.outcome-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.outcome-card { padding: 26px 24px; min-height: 130px; }
.outcome-card strong { display: block; color: var(--blue); font-size: 36px; line-height: 1; margin-bottom: 12px; }
.outcome-card span { color: #1b2a53; font-size: 16px; line-height: 1.35; font-weight: 800; }
.offer-content { padding: 24px 0; }
.offer-content-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.offer-detail-card { padding: 34px; }
.offer-detail-card h2 { text-align: left; margin-bottom: 20px; }
.offer-roadmap { padding: 28px 0 34px; }
.roadmap-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 8px; }
.roadmap-card { position: relative; min-height: 148px; padding: 32px 20px 22px; border: 1px solid var(--line); border-radius: 7px; background: #fff; }
.roadmap-card b { position: absolute; top: -14px; left: 18px; width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: var(--blue); color: #fff; font-size: 14px; }
.roadmap-card p { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.5; }
.offer-related { padding-top: 34px; background: linear-gradient(180deg, #fff, #fbfdff); border-top: 1px solid var(--line); }

.admin-body { min-height: 100vh; background: linear-gradient(180deg, #f8fbff, #fff); }
.admin-shell { min-height: 100vh; display: grid; place-items: center; padding: 34px 18px; }
.admin-login-card { width: min(100%, 460px); padding: 38px; box-shadow: 0 24px 60px rgba(7,20,62,.11); }
.admin-brand { margin-bottom: 28px; }
.admin-login-card h1 { font-size: 34px; margin-bottom: 10px; }
.admin-muted { color: var(--muted); margin-bottom: 24px; }
.admin-error { padding: 12px 14px; border: 1px solid #ffc9c9; border-radius: 6px; background: #fff3f3; color: #9f1d1d; font-weight: 800; }
.admin-form { display: grid; gap: 16px; }
.admin-form label { display: grid; gap: 7px; color: #1b2a53; font-weight: 800; }
.admin-form .button { width: 100%; margin-top: 6px; }
.admin-dashboard { min-height: 100vh; }
.admin-topbar { height: 72px; display: flex; align-items: center; justify-content: space-between; padding: 0 42px; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.94); backdrop-filter: blur(14px); }
.admin-topnav { display: flex; align-items: center; gap: 16px; }
.admin-topnav a { color: #1b2a53; font-size: 14px; font-weight: 900; }
.admin-logout { min-height: 38px; padding: 0 18px; }
.admin-hero { padding: 58px 0; }
.admin-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 36px; align-items: center; }
.admin-hero p:not(.eyebrow) { max-width: 650px; color: var(--muted); font-size: 18px; line-height: 1.55; }
.admin-status-card { padding: 28px; min-height: 190px; display: flex; flex-direction: column; justify-content: center; }
.admin-status-card strong { color: var(--blue); font-size: 18px; margin-bottom: 12px; }
.admin-status-card span { font-size: 26px; font-weight: 900; line-height: 1.2; margin-bottom: 10px; }
.admin-status-card small { color: var(--muted); font-size: 14px; line-height: 1.4; }
.admin-modules { padding: 34px 0; }
.admin-module-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.admin-module-card { padding: 28px; min-height: 190px; }
.admin-module-card h2 { text-align: left; font-size: 22px; margin-bottom: 12px; }
.admin-module-card p { color: var(--muted); font-size: 15px; line-height: 1.5; }
.admin-module-card span { display: inline-flex; margin-top: 10px; padding: 7px 10px; border-radius: 999px; background: #eaf2ff; color: var(--blue); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.admin-module-links { margin-top: 22px; }
.admin-module-links a { color: inherit; }
.admin-monitor { padding: 34px 0 54px; }
.admin-notice { padding: 13px 16px; border: 1px solid #bbf1d2; border-radius: 7px; background: #f0fff6; color: #08733b; font-weight: 900; }
.admin-kpi-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; margin-bottom: 24px; }
.admin-kpi { padding: 24px; min-height: 126px; }
.admin-kpi span { display: block; color: var(--muted); font-size: 14px; font-weight: 800; margin-bottom: 12px; }
.admin-kpi strong { color: var(--blue); font-size: 38px; line-height: 1; }
.admin-danger-row { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin: 0 0 24px; padding: 16px 18px; border: 1px solid #ffd4b8; border-radius: 7px; background: #fff8f3; }
.admin-danger-row p { margin: 0; color: #6d3b15; font-weight: 800; font-size: 14px; }
.admin-danger-button { border-color: #e66b1a; color: #b9470e; background: #fff; }
.admin-grid-two { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; margin-top: 22px; }
.admin-panel { padding: 26px; }
.admin-panel h2 { text-align: left; font-size: 22px; margin-bottom: 18px; }
.admin-bars { display: grid; gap: 14px; }
.admin-bar-row { display: grid; grid-template-columns: minmax(0, 1fr) 42px; gap: 12px; align-items: center; }
.admin-bar-row span { color: #1b2a53; font-weight: 800; }
.admin-bar-row b { color: var(--blue); text-align: right; }
.admin-bar-row i { grid-column: 1 / -1; height: 9px; border-radius: 999px; background: linear-gradient(90deg, var(--blue) var(--bar), #e7eefb var(--bar)); }
.admin-day-chart { height: 225px; display: grid; grid-template-columns: repeat(7, 1fr); align-items: end; gap: 13px; padding-top: 14px; }
.admin-day-chart div { height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: end; gap: 9px; }
.admin-day-chart span { width: 100%; max-width: 36px; border-radius: 8px 8px 0 0; background: linear-gradient(180deg, var(--blue), var(--teal)); box-shadow: 0 12px 24px rgba(17,101,255,.18); }
.admin-day-chart b { color: var(--muted); font-size: 12px; }
.admin-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.admin-list li { display: flex; justify-content: space-between; gap: 16px; padding: 12px 0; border-bottom: 1px solid #e6eef9; }
.admin-list span { color: #1b2a53; font-weight: 700; overflow-wrap: anywhere; }
.admin-list b { color: var(--blue); white-space: nowrap; }
.admin-inquiries { display: grid; gap: 14px; }
.admin-inquiries section { padding: 15px; border: 1px solid #dbe6f8; border-radius: 7px; background: #fbfdff; }
.admin-inquiries h3 { display: flex; justify-content: space-between; gap: 12px; font-size: 16px; margin-bottom: 8px; }
.admin-inquiries h3 span { color: var(--muted); font-size: 12px; font-weight: 700; }
.admin-inquiries p { color: #1b2a53; margin-bottom: 7px; font-size: 14px; }
.admin-inquiries small { color: var(--muted); font-weight: 700; }
.admin-settings-form { display: grid; gap: 12px; }
.admin-toggle { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border: 1px solid #dbe6f8; border-radius: 7px; background: #fbfdff; font-weight: 800; color: #1b2a53; }
.admin-toggle input { width: 18px; height: 18px; accent-color: var(--blue); }
.admin-settings-form .button { margin-top: 6px; }
.admin-edit-list { display: grid; gap: 18px; margin: 18px 0 8px; }
.admin-edit-card { padding: 24px; display: grid; gap: 12px; }
.admin-edit-card.compact { padding: 20px; }
.admin-edit-card select {
  width: 100%;
  border: 1px solid #cfd9ea;
  border-radius: 4px;
  padding: 10px 14px;
  font: inherit;
  color: var(--ink);
  background: #fff;
  outline-color: var(--blue);
}
.admin-page-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.admin-page-heading h1 { margin-bottom: 8px; }
.narrow-admin { max-width: 760px; }
.admin-create-form { padding: 28px; }
.admin-audit-list { display: grid; gap: 16px; }
.admin-audit-row { display: grid; grid-template-columns: minmax(0, 1fr) 130px auto; gap: 20px; align-items: center; padding: 22px; }
.admin-audit-row h2 { text-align: left; font-size: 22px; margin-bottom: 6px; }
.admin-audit-row p { color: var(--muted); margin-bottom: 6px; overflow-wrap: anywhere; }
.admin-audit-row span { color: var(--muted); font-size: 13px; font-weight: 700; }
.admin-audit-score { text-align: center; padding: 12px; border-radius: 7px; background: #f4f8ff; }
.admin-audit-score strong { display: block; color: var(--blue); font-size: 30px; line-height: 1; margin-bottom: 8px; }
.admin-audit-actions { display: flex; gap: 10px; }
.admin-audit-summary-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.audit-section-card { padding: 26px; display: grid; gap: 18px; }
.audit-section-card h2 { text-align: left; margin: 0; }
.audit-check-item { padding: 18px; border: 1px solid #dbe6f8; border-radius: 7px; background: #fbfdff; }
.audit-check-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.audit-check-head h3 { font-size: 17px; margin: 0; }
.audit-check-controls { display: flex; gap: 10px; flex: 0 0 auto; }
.audit-check-controls label { display: grid; gap: 5px; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.audit-check-controls select,
.admin-panel select {
  min-width: 120px;
  border: 1px solid #cfd9ea;
  border-radius: 4px;
  padding: 9px 11px;
  font: inherit;
  color: var(--ink);
  background: #fff;
}
.audit-check-item textarea,
.admin-panel textarea {
  min-height: 92px;
}
.audit-save-button { position: sticky; bottom: 16px; z-index: 5; box-shadow: 0 16px 32px rgba(17,101,255,.26); }
.audit-report-hero { display: grid; grid-template-columns: 270px minmax(0, 1fr); gap: 28px; padding: 30px; margin-bottom: 22px; }
.audit-report-hero span { color: var(--muted); font-weight: 900; }
.audit-report-hero strong { display: block; color: var(--blue); font-size: 58px; line-height: 1; margin: 12px 0; }
.audit-report-hero h2 { text-align: left; margin-bottom: 12px; }
.audit-report-section { padding: 28px; margin-bottom: 18px; }
.audit-report-section h2 { text-align: left; margin-bottom: 18px; }
.audit-report-section article { padding: 15px 0; border-top: 1px solid #e5edf8; }
.audit-report-section h3 { display: flex; justify-content: space-between; gap: 18px; font-size: 16px; margin-bottom: 8px; }
.audit-report-section h3 span { color: var(--blue); font-size: 13px; white-space: nowrap; }
.audit-report-section p { color: #1b2a53; }

@media (max-width: 1050px) {
  .container { width: min(100% - 34px, 960px); }
  .nav-links { display: none; }
  .hero-grid { grid-template-columns: 1fr; padding-top: 22px; }
  .service-hero-grid, .service-detail-grid, .service-intro-grid, .workflow-grid, .use-case-panel, .offer-hero-grid, .offer-content-grid, .roadmap-grid, .admin-hero-grid { grid-template-columns: 1fr; }
  .service-stat-grid { grid-template-columns: repeat(3, 1fr); }
  .outcome-grid { grid-template-columns: repeat(3, 1fr); }
  .hero-visual { min-height: 430px; }
  .service-grid, .service-grid-compact { grid-template-columns: repeat(2, 1fr); }
  .process-grid, .project-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .admin-module-grid, .admin-grid-two { grid-template-columns: 1fr; }
  .admin-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .admin-audit-row, .audit-report-hero { grid-template-columns: 1fr; }
  .admin-audit-actions, .audit-check-head, .audit-check-controls, .admin-page-heading { flex-direction: column; align-items: stretch; }
  .process-card:after { display: none; }
}
@media (max-width: 760px) {
  .nav { height: auto; padding: 12px 0; flex-wrap: wrap; }
  .brand { font-size: 21px; }
  .nav-actions { margin-left: auto; }
  .lang { display: none; }
  h1 { font-size: 31px; }
  h2 { font-size: 24px; }
  .hero-copy p { font-size: 17px; }
  .hero-buttons, .trust-list { flex-direction: column; align-items: flex-start; gap: 12px; }
  .hero-visual { transform: scale(.82); transform-origin: top left; width: 122%; margin-bottom: -56px; }
  .service-grid, .service-grid-compact, .offer-grid, .project-grid, .process-grid, .contact-panel, .footer-grid { grid-template-columns: 1fr; }
  .service-stat-grid, .use-case-list, .outcome-grid { grid-template-columns: 1fr; }
  .service-visual-card { min-height: 310px; }
  .offer-visual-card { min-height: 360px; }
  .service-card { min-height: auto; padding: 30px 22px 24px; }
  .offer-card { min-height: auto; padding: 30px 26px; }
  .project-card { min-height: auto; }
  .contact-copy { padding: 28px 22px; flex-direction: column; align-items: flex-start; }
  .contact-copy h2 { font-size: 24px; }
  .field-row { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; gap: 10px; }
  .admin-topbar { height: auto; padding: 14px 18px; gap: 12px; flex-wrap: wrap; }
  .admin-topnav { order: 3; width: 100%; }
  .admin-login-card { padding: 28px; }
  .admin-kpi-grid { grid-template-columns: 1fr; }
  .admin-danger-row { flex-direction: column; align-items: stretch; }
  .admin-day-chart { height: 180px; }
}
@media (max-width: 470px) {
  .container { width: calc(100% - 24px); }
  .button { width: 100%; padding: 0 14px; }
  .nav-actions .button { width: auto; }
  .hero-visual { transform: scale(.66); width: 150%; margin-bottom: -126px; }
  .laptop { right: 35px; }
  .systems { left: 28px; }
  .analytics { left: 8px; }
  .flow { right: -2px; }
}
