.nav {
  display:flex; align-items:center; gap:32px; color:rgba(248,250,252,.82); font-size:15px;
}

.nav a, .nav button {
  color:rgba(248,250,252,.82); background:none; border:none; padding:0; font:inherit; cursor:pointer;
}

.nav a:hover, .nav button:hover { color:#fff; }

.nav-dropdown { position:relative; }

.nav-menu {
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%);
  min-width:240px; display:none; flex-direction:column; gap:0;
  background:rgba(17,24,39,.96); border:1px solid rgba(248,250,252,.10); border-radius:18px;
  box-shadow:0 18px 46px rgba(17,24,39,.35); overflow:hidden;
}

.nav-dropdown.open .nav-menu { display:flex; }

.nav-menu a {
  padding:14px 16px; border-top:1px solid rgba(248,250,252,.08);
}

.nav-menu a:first-child { border-top:none; }

.hero {
  position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; color:#fff; padding-top:112px;
}

.hero-slide {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.8s ease-in-out;
}

.hero-slide.active { opacity:1; }

.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(17,24,39,.78) 0%, rgba(17,24,39,.56) 42%, rgba(17,24,39,.34) 100%);
}

.hero-inner {
  position:relative; z-index:1; width:100%; padding:56px 0 120px;
}

.hero-copy {
  max-width:980px;
  margin-left:clamp(220px, 17vw, 320px);
  margin-top:-42px;
}

.hero h1 {
  margin:0; max-width:980px; font-size:clamp(48px, 6vw, 72px);
  line-height:1; letter-spacing:-.03em;
}

.hero p {
  margin:26px 0 0; max-width:650px; font-size:clamp(18px,2vw,20px);
  line-height:1.6; color:rgba(248,250,252,.92);
}

.section { padding:96px 0; }

.section-title {
  display:inline-flex; border:1px solid rgba(0,166,81,.22); background:rgba(0,166,81,.08); color:var(--green);
  border-radius:999px; padding:7px 14px; font-size:12px; text-transform:uppercase; letter-spacing:.18em;
}

h2 {
  margin:18px 0 0; font-size:36px; line-height:1.1; letter-spacing:-.025em;
}

.lead {
  margin:16px 0 0; max-width:920px; color:var(--muted); font-size:18px; line-height:1.75;
}

.features { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:32px; }

.news-section { background:#fff; }

.news-wrap { padding-top:6px; }

.news-title {
  margin:20px 0 0;
  font-size:clamp(34px, 4.2vw, 52px);
  line-height:1.08;
  letter-spacing:-.03em;
}

.news-grid {
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:26px;
  margin-top:28px;
}

.news-card {
  background:#fff;
  border:1px solid var(--line);
  border-radius:40px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.news-card-body { padding:20px 22px 24px; }

.news-image {
  aspect-ratio: 16 / 9;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(17,24,39,.06), rgba(17,24,39,.10));
  border:1px solid rgba(17,24,39,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(17,24,39,.44);
  font-size:18px;
  text-align:center;
  overflow:hidden;
}

.news-image img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  border-radius:inherit;
}

.news-image.news-image-logo {
  background:#fff;
  border-color:rgba(17,24,39,.10);
  padding:18px 22px;
  align-items:center;
  justify-content:center;
}

.news-image.news-image-logo img {
  object-fit:contain;
  object-position:center;
  background:#fff;
  max-width:100%;
  max-height:100%;
  margin:auto;
}

.news-date {
  margin-top:18px;
  color:rgba(17,24,39,.72);
  font-size:16px;
}

.news-card h3 {
  margin:6px 0 0;
  font-size:22px;
  line-height:1.2;
}

.news-card p {
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.6;
  font-size:16px;
}

@media (max-width: 1100px) {
  .news-grid { grid-template-columns:1fr; }
}

.feature { padding:12px; }

.badge {
  width:48px; height:48px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  background:rgba(0,166,81,.10); color:var(--green);
}

.badge::before {
  content:""; width:18px; height:18px; border:2px solid currentColor; border-radius:999px;
}

.feature h3 { margin:16px 0 8px; font-size:18px; }

.feature p { margin:0; color:var(--muted); line-height:1.6; font-size:16px; }

.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }

.grid-2 { display:grid; grid-template-columns:1.1fr .9fr; gap:28px; margin-top:52px; }

.card {
  background:#fff; border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow);
}

.card-body { padding:32px; }

.mod-card h3 { margin:20px 0 12px; font-size:20px; line-height:1.35; }

.mod-card p { margin:0; color:var(--muted); line-height:1.75; font-size:16px; }

.dark-card {
  position:relative; overflow:hidden; color:#fff; border:none;
}

.dark-card .bg { position:absolute; inset:0; background-size:cover; background-position:center; }

.dark-card .shade { position:absolute; inset:0; background:rgba(17,24,39,.72); }

.dark-card .inner { position:relative; padding:32px; }

.dark-card h3 { margin:16px 0 0; font-size:30px; line-height:1.2; letter-spacing:-.025em; }

.dark-card p { margin:16px 0 0; color:rgba(248,250,252,.84); line-height:1.7; font-size:16px; }

.mini-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:32px; }

.mini-item {
  border:1px solid rgba(248,250,252,.12); background:rgba(248,250,252,.06); border-radius:20px; padding:16px;
}

.mini-item strong { display:block; font-size:16px; margin-bottom:8px; }

.mini-item span { color:rgba(248,250,252,.74); font-size:14px; line-height:1.5; }

.kicker { color:var(--green); font-size:12px; text-transform:uppercase; letter-spacing:.18em; }

.faq h3, .service-intro h3, .info-card h3, .contact-form h3 { margin:16px 0 0; font-size:24px; line-height:1.25; }

.faq-list, .small-list { display:grid; gap:12px; margin-top:24px; }

.faq-item, .small-item {
  border:1px solid var(--line); border-radius:18px; padding:14px 16px; background:var(--light);
  color:rgba(17,24,39,.82); font-size:15px; line-height:1.5;
}

.services-wrap { margin-top:28px; }

.service-header { max-width:1180px; }

.service-header .section-title {
  display:inline-flex;
  color:var(--green) !important;
  border-color:rgba(0,166,81,.22) !important;
  background:rgba(0,166,81,.08) !important;
}

.service-header h2 { margin:18px 0 0; }

.service-copy {
  margin-top:18px;
  max-width:1180px;
  color:var(--muted);
  font-size:18px;
  line-height:1.72;
}

.service-copy p { margin:0 0 18px; }

.service-columns {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
  margin-top:42px;
  align-items:stretch;
}

.service-column {
  display:flex;
  flex-direction:column;
  gap:20px;
  align-self:start;
}

.service-box {
  background:#fff;
  border:1px solid rgba(17,24,39,.10);
  border-radius:28px;
  box-shadow:var(--shadow);
  padding:28px 28px 24px;
}

.service-box h3 {
  margin:0;
  font-size:20px;
  line-height:1.28;
  letter-spacing:-.02em;
  color:var(--graphite);
}

.service-box ul {
  margin:14px 0 0 22px;
  padding:0;
}

.service-box li {
  margin:8px 0 0;
  font-size:16px;
  line-height:1.55;
  color:var(--muted);
}

.service-box.compact {
  min-height:auto;
}

.service-box.compact h3 {
  margin:0;
}

.service-intro p {
  margin:18px 0 0;
  max-width:1280px;
  font-size:18px;
  line-height:1.58;
  color:var(--graphite);
}

@media (max-width: 1100px) {
  .service-columns { grid-template-columns:1fr; }
}

.cases-section { position:relative; overflow:hidden; color:#fff; }

.cases-bg {
  position:absolute; inset:0; background-image:url("../images/inline/e1b6b965272ff12c.webp"); background-size:cover; background-position:center;
}

.cases-shade { position:absolute; inset:0; background:rgba(17,24,39,.80); }

.cases-inner { position:relative; z-index:1; }

.cases-head { display:flex; align-items:end; justify-content:space-between; gap:24px; }

.btn {
  display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 22px; border-radius:18px;
  border:1px solid rgba(248,250,252,.16); color:#fff; background:rgba(248,250,252,.06); font-weight:600;
}

.case-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:20px; margin-top:34px; }

.case-card {
  position:relative; overflow:hidden;
  background:rgba(248,250,252,.06); border:1px solid rgba(248,250,252,.14); border-radius:24px; backdrop-filter:blur(6px);
}

.case-card .card-body { padding:24px; }

.case-thumb {
  height:180px; border-radius:18px; background-size:cover; background-position:center; margin-bottom:16px;
}

.case-tag {
  display:inline-flex; padding:8px 12px; border-radius:999px;
  border:1px solid rgba(0,166,81,.28); background:rgba(0,166,81,.14); color:#F8FAFC;
  font-size:12px; text-transform:uppercase; letter-spacing:.14em;
}

.case-card h3 { margin:16px 0 0; font-size:22px; }

.case-link { color:inherit; text-decoration:none; }

.case-link:hover { text-decoration:underline; text-underline-offset:4px; }

.case-card p { margin:10px 0 0; color:rgba(248,250,252,.78); line-height:1.65; font-size:15px; }

.case-card.case-card-featured {
  min-height:420px;
}

.case-card.case-card-featured .featured-case-image {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.04);
  transition:filter .35s ease, transform .45s ease;
  transform:scale(1.01);
  z-index:0;
}

.case-card.case-card-featured::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.03) 0%, rgba(17,24,39,.10) 36%, rgba(17,24,39,.78) 100%);
  z-index:1;
  pointer-events:none;
}

.case-card.case-card-featured:hover .featured-case-image {
  filter:grayscale(0) contrast(1.02);
  transform:scale(1.03);
}

.case-card.case-card-featured .card-body {
  position:relative;
  z-index:2;
  min-height:420px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:24px 22px 36px;
}

.case-card.case-card-featured .case-thumb,
.case-card.case-card-featured p {
  display:none;
}

.case-card.case-card-featured .case-tag {
  width:max-content;
  align-self:flex-start;
  margin-bottom:10px;
  background:rgba(0,166,81,.22);
}

.case-card.case-card-featured h3 {
  margin:0;
  color:#fff;
}

.case-card.case-card-featured-secondary {
  min-height:420px;
}

.case-card.case-card-featured-secondary .featured-case-image-secondary {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.04);
  transition:filter .35s ease, transform .45s ease;
  transform:scale(1.01);
  z-index:0;
}

.case-card.case-card-featured-secondary::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.03) 0%, rgba(17,24,39,.10) 36%, rgba(17,24,39,.78) 100%);
  z-index:1;
  pointer-events:none;
}

.case-card.case-card-featured-secondary:hover .featured-case-image-secondary {
  filter:grayscale(0) contrast(1.02);
  transform:scale(1.03);
}

.case-card.case-card-featured-secondary .card-body {
  position:relative;
  z-index:2;
  min-height:420px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:24px 22px 36px;
}

.case-card.case-card-featured-secondary .case-thumb,
.case-card.case-card-featured-secondary p {
  display:none;
}

.case-card.case-card-featured-secondary .case-tag {
  width:max-content;
  align-self:flex-start;
  margin-bottom:10px;
  background:rgba(0,166,81,.22);
}

.case-card.case-card-featured-secondary h3 {
  margin:0;
  color:#fff;
}

.case-card.case-card-featured-tertiary {
  min-height:420px;
}

.case-card.case-card-featured-tertiary .featured-case-image-tertiary {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.04);
  transition:filter .35s ease, transform .45s ease;
  transform:scale(1.01);
  z-index:0;
}

.case-card.case-card-featured-tertiary::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.04) 0%, rgba(17,24,39,.12) 38%, rgba(17,24,39,.82) 100%);
  z-index:1;
  pointer-events:none;
}

.case-card.case-card-featured-tertiary:hover .featured-case-image-tertiary {
  filter:grayscale(0) contrast(1.02);
  transform:scale(1.03);
}

.case-card.case-card-featured-tertiary .card-body {
  position:relative;
  z-index:2;
  min-height:420px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:24px 22px 36px;
}

.case-card.case-card-featured-tertiary .case-thumb,
.case-card.case-card-featured-tertiary p {
  display:none;
}

.case-card.case-card-featured-tertiary .case-tag {
  width:max-content;
  align-self:flex-start;
  margin-bottom:12px;
  background:rgba(0,166,81,.22);
}

.case-card.case-card-featured-tertiary h3 {
  margin:0;
  color:#fff;
}

.case-card.case-card-featured-quaternary {
  min-height:420px;
}

.case-card.case-card-featured-quaternary .featured-case-image-quaternary {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.04);
  transition:filter .35s ease, transform .45s ease;
  transform:scale(1.01);
  z-index:0;
}

.case-card.case-card-featured-quaternary::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.02) 0%, rgba(17,24,39,.06) 34%, rgba(17,24,39,.76) 100%);
  z-index:1;
  pointer-events:none;
}

.case-card.case-card-featured-quaternary:hover .featured-case-image-quaternary {
  filter:grayscale(0) contrast(1.02);
  transform:scale(1.03);
}

.case-card.case-card-featured-quaternary .card-body {
  position:relative;
  z-index:2;
  min-height:420px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:24px 22px 36px;
}

.case-card.case-card-featured-quaternary .case-thumb,
.case-card.case-card-featured-quaternary p {
  display:none;
}

.case-card.case-card-featured-quaternary .case-tag {
  width:max-content;
  align-self:flex-start;
  margin-bottom:12px;
  background:rgba(0,166,81,.22);
}

.case-card.case-card-featured-quaternary h3 {
  margin:0;
  color:#fff;
}

.info-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px; }

.info-card p { margin:12px 0 0; color:var(--muted); line-height:1.7; font-size:16px; }

.team-columns { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px; margin-top:44px; align-items:stretch; }

.team-col { display:flex; flex-direction:column; gap:24px; }

.team-col.team-col-right { height:100%; justify-content:flex-start; }

.team-col.team-col-right .team-card { flex:0 0 auto; }

.team-card .role { margin-top:6px; color:var(--green); font-weight:700; font-size:16px; }

.team-card .degree { margin-top:14px; color:rgba(17,24,39,.78); line-height:1.6; font-size:16px; }

.team-card p { margin:10px 0 0; color:var(--muted); line-height:1.7; font-size:16px; }

.team-links { display:flex; flex-wrap:wrap; gap:14px; margin-top:16px; }

.team-links a { color:var(--green); text-decoration:underline; text-underline-offset:3px; }

.contact-grid { display:grid; grid-template-columns:.95fr 1.05fr; gap:28px; }

.contact-dark {
  position:relative; overflow:hidden; border:none; color:#fff;
}

.contact-dark .bg { position:absolute; inset:0; background-image:url("../images/inline/c5d6f3c2a7b7c4ef.jpg"); background-size:cover; background-position:center; }

.contact-dark .shade { position:absolute; inset:0; background:rgba(17,24,39,.72); }

.contact-dark .inner { position:relative; padding:32px; }

.contact-dark h3 { margin:18px 0 0; font-size:30px; line-height:1.2; }

.contact-dark p, .contact-dark .contact-line { color:rgba(248,250,252,.86); font-size:16px; line-height:1.75; }

.contact-lines { display:grid; gap:18px; margin-top:28px; }

.contact-form label { display:block; margin:0 0 8px; font-size:14px; color:var(--muted); }

.form-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:24px; }

.form-grid .full { grid-column:1/-1; }

input, textarea {
  width:100%; border:1px solid var(--line); border-radius:18px; padding:14px 16px; background:#fff;
  color:var(--graphite); font:inherit;
}

textarea { min-height:150px; resize:vertical; }

.submit {
  margin-top:20px; display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 22px;
  border:none; border-radius:18px; background:var(--green); color:#fff; font-weight:700; cursor:pointer;
  transition: opacity .18s ease, background .18s ease;
}
.submit:hover:not(:disabled) { background:#00b85b; }
.submit:disabled { opacity:.6; cursor:wait; }

.form-status {
  margin:14px 0 0; min-height:1.2em; font-size:14px; line-height:1.4;
}
.form-status[data-kind="ok"] { color:var(--green); }
.form-status[data-kind="err"] { color:#c53030; }
.form-status[data-kind="pending"] { color:var(--muted); }

.clients-section { background:#fff; }

.clients-intro { margin-top:18px; max-width:780px; color:var(--muted); font-size:18px; line-height:1.75; }

.clients-group { margin-top:40px; }

.clients-group + .clients-group { margin-top:54px; }

.clients-group-title {
  margin:0 0 22px; font-size:18px; line-height:1.35; color:var(--graphite); font-weight:500;
}

.clients-logos {
  display:grid; grid-template-columns:repeat(5, minmax(0,1fr)); gap:12px 18px; align-items:center;
}

.client-logo-item {
  min-height:64px; display:flex; align-items:center; justify-content:center; padding:2px 2px;
}

.client-logo-item img {
  max-width:100%; max-height:64px; width:auto; height:auto; object-fit:contain;
  filter:none; opacity:1; background:#fff;
}

.client-logo-item.tall img { max-height:82px; }

.client-logo-item.wide img { max-height:56px; }

.client-logo-item.big img { max-height:86px; }

.client-logo-item.wide.big img { max-height:68px; }

.client-logo-item.tall.big img { max-height:108px; }

.client-logo-item img.logo-mgu { max-height:64px !important; max-width:120px !important; width:auto; }

.client-logo-item img.logo-gazprom-intl { max-height:66px !important; max-width:182px !important; width:auto; }

.client-logo-item.logo-gazprom-intl-item { min-height:76px; align-items:flex-start; padding-top:0; transform:translateY(-8px); }

#information .info-grid { grid-template-columns:repeat(2,1fr); }

@media (max-width: 1120px) {
  .features, .grid-3, .mini-grid, .info-grid { grid-template-columns:repeat(2,1fr); }
  .clients-logos { grid-template-columns:repeat(3,1fr); gap:12px 16px; }
  .grid-2, .contact-grid { grid-template-columns:1fr; }
  .case-grid { grid-template-columns:1fr; }
  .hero-copy { margin-left:clamp(28px, 6vw, 72px); max-width:860px; }
}

@media (max-width: 880px) {
  .header-inner { flex-wrap:wrap; }
  .nav { gap:18px; flex-wrap:wrap; }
  .container { width:min(100% - 32px, 1280px); }
  .features, .grid-3, .info-grid, .mini-grid, .team-columns { grid-template-columns:1fr; }
  .team-col.team-col-right { height:auto; justify-content:flex-start; }
  .clients-logos { grid-template-columns:repeat(2,1fr); gap:12px 14px; }
  
  .hero { padding-top:148px; }
  .hero-copy { margin-left:0; margin-top:0; max-width:760px; }
  .hero-inner { padding:28px 0 72px; }
  h2 { font-size:30px; }
}

.software-section .section-title {
  display:inline-flex;
  color:var(--green) !important;
  border-color:rgba(0,166,81,.22) !important;
  background:rgba(0,166,81,.08) !important;
}

.software-head {
  max-width:1200px;
}

.software-head h2 {
  margin:18px 0 0;
}

.software-intro {
  margin-top:18px;
  max-width:1300px;
  color:var(--graphite);
  font-size:18px;
  line-height:1.58;
}

.software-shell {
  display:grid;
  grid-template-columns:minmax(0, .95fr) minmax(0, 1.05fr);
  gap:26px;
  margin-top:34px;
  align-items:start;
}

.software-panel {
  background:#fff;
  border:1px solid rgba(17,24,39,.10);
  border-radius:36px;
  box-shadow:var(--shadow);
  padding:28px;
}

.software-menu-title {
  margin:0 0 14px;
  font-size:24px;
  line-height:1.2;
  color:var(--graphite);
}

.software-menu {
  display:grid;
  gap:6px;
}

.software-item {
  appearance:none;
  border:none;
  background:transparent;
  padding:0;
  text-align:left;
  font:inherit;
  color:var(--graphite);
  cursor:pointer;
}

.software-item .software-item-text {
  display:inline;
  font-size:18px;
  line-height:2.02;
}

.software-item.is-active .software-item-text {
  font-weight:700;
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:4px;
}

.software-item:hover .software-item-text {
  color:#0f172a;
}

.software-registry-note {
  margin-top:22px;
  padding:22px 24px 24px;
  border:1px solid rgba(17,24,39,.10);
  border-radius:36px;
  background:#fff;
  box-shadow:var(--shadow);
}

.software-registry-note p {
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.55;
}

.software-registry-note p + p {
  margin-top:18px;
}

.software-registry-note a {
  color:var(--graphite);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
}

.software-demo {
  display:flex;
  flex-direction:column;
  height:100%;
}

.software-demo-media {
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
}

.software-demo-media img {
  width:100%;
  height:auto;
  display:block;
}

.software-demo-caption {
  margin-top:18px;
}

.software-demo-caption ul {
  margin:0 0 0 24px;
  padding:0;
}

.software-demo-caption li {
  margin:10px 0 0;
  color:var(--graphite);
  font-size:16px;
  line-height:1.5;
}

.software-demo-note {
  margin-top:14px;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
}

.software-demo-title {
  margin:16px 0 0;
  font-size:18px;
  line-height:1.3;
  color:var(--graphite);
}

.software-demo-description {
  margin:12px 0 0;
  color:var(--muted);
  font-size:16px;
  line-height:1.6;
}

.software-compare {
  position:relative;
  width:100%;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  aspect-ratio: 16 / 9;
  display:none;
  user-select:none;
  touch-action:none;
  --split:50%;
}

.software-compare.is-active {
  display:block;
}

.software-compare-base,
.software-compare-overlay {
  position:absolute;
  inset:0;
}

.software-compare-base img,
.software-compare-overlay img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.software-compare-overlay {
  overflow:hidden;
  clip-path: inset(0 calc(100% - var(--split)) 0 0);
  border-right:3px solid #ef4444;
}

.software-compare-handle {
  position:absolute;
  top:0;
  bottom:0;
  left:var(--split);
  width:0;
  pointer-events:none;
}

.software-compare-handle::before,
.software-compare-handle::after {
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
}

.software-compare-handle::before {
  top:50%;
  width:38px;
  height:38px;
  border-radius:999px;
  transform:translate(-50%, -50%);
  background:#ef4444;
  box-shadow:0 10px 24px rgba(239,68,68,.24);
}

.software-compare-handle::after {
  top:50%;
  width:0;
  height:0;
  transform:translate(-50%, -50%);
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  border-left:14px solid #fff;
  margin-left:2px;
}

.software-demo-media.mode-compare {
  border:none;
  background:transparent;
}

.software-demo-media.mode-empty {
  border:1px dashed rgba(17,24,39,.12);
  background:rgba(17,24,39,.02);
}

.software-demo-media.mode-empty #softwareDemoImage,
.software-demo-media.mode-empty #softwareCompare {
  display:none !important;
}

.software-demo-media.mode-empty #softwareFade,
.software-demo-media.mode-compare #softwareFade {
  display:none !important;
}

.software-demo-media.mode-fade {
  border:none;
  background:transparent;
}

.software-demo-media.mode-fade #softwareDemoImage,
.software-demo-media.mode-fade #softwareCompare {
  display:none !important;
}

.software-demo-media.mode-fade #softwareFade {
  display:block !important;
}

.software-fade {
  position:relative;
  width:100%;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  aspect-ratio: 16 / 10;
  display:none;
}

.software-fade img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.software-fade img:first-child {
  opacity:1;
}

.software-fade img:last-child {
  opacity:0;
}

.software-fade.is-active img:first-child {
  animation: softwareFadeOut 10s ease-in-out infinite;
}

.software-fade.is-active img:last-child {
  animation: softwareFadeIn 10s ease-in-out infinite;
}

.software-carousel {
  position:relative;
  width:100%;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  aspect-ratio: 16 / 10;
  display:none;
}

.software-carousel.is-active {
  display:block;
}

.software-carousel img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
  background:#fff;
}

.software-carousel-btn {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px;
  height:40px;
  border:none;
  border-radius:999px;
  background:rgba(15,23,42,.78);
  color:#fff;
  cursor:pointer;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 24px rgba(15,23,42,.18);
}

.software-carousel-btn:hover {
  background:rgba(15,23,42,.92);
}

.software-carousel-btn.prev { left:14px; }

.software-carousel-btn.next { right:14px; }

.software-carousel-btn::before {
  content:"";
  width:10px;
  height:10px;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  display:block;
}

.software-carousel-btn.prev::before {
  transform:rotate(-135deg);
  margin-left:4px;
}

.software-carousel-btn.next::before {
  transform:rotate(45deg);
  margin-right:4px;
}

.software-carousel-counter {
  position:absolute;
  right:16px;
  bottom:14px;
  z-index:3;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(15,23,42,.72);
  color:#fff;
  font-size:13px;
  line-height:1;
  letter-spacing:.02em;
}

.software-carousel-slide-caption {
  position:absolute;
  left:16px;
  bottom:14px;
  max-width:calc(100% - 120px);
  z-index:3;
  padding:8px 12px;
  border-radius:14px;
  background:rgba(15,23,42,.72);
  color:#fff;
  font-size:14px;
  line-height:1.25;
}

.software-demo-media.mode-carousel {
  border:none;
  background:transparent;
}

.software-demo-media.mode-carousel #softwareDemoImage,
.software-demo-media.mode-carousel #softwareCompare,
.software-demo-media.mode-carousel #softwareFade {
  display:none !important;
}

.software-demo-media.mode-empty #softwareCarousel,
.software-demo-media.mode-compare #softwareCarousel,
.software-demo-media.mode-fade #softwareCarousel {
  display:none !important;
}

@keyframes softwareFadeIn {
  0%, 42% { opacity:0; }
  58%, 100% { opacity:1; }
}

@keyframes softwareFadeOut {
  0%, 42% { opacity:1; }
  58%, 100% { opacity:0; }
}

@media (max-width: 1100px) {
  .software-shell {
    grid-template-columns:1fr;
  }
}

.case-card h3 a {
  color:inherit;
  text-decoration:none;
}

.case-card h3 a:hover {
  text-decoration:underline !important;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
}

.case-card.case-card-featured-quaternary h3 a:hover {
  text-decoration:underline !important;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
}

.news-image.news-image-forum {
  padding:0;
  background:transparent;
}

.news-image.news-image-forum img {
  object-fit:cover;
  object-position:center;
}
