@font-face {
  font-family: "Inter";
  src: url("assets/fonts/inter/inter-var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Space Grotesk";
  src: url("assets/fonts/space-grotesk/space-grotesk-var.woff2") format("woff2");
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Mono";
  src: url("assets/fonts/ibm-plex-mono/ibm-plex-mono-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Mono";
  src: url("assets/fonts/ibm-plex-mono/ibm-plex-mono-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Mono";
  src: url("assets/fonts/ibm-plex-mono/ibm-plex-mono-semibold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root {
  --paper: #f8fcff;
  --white: #ffffff;
  --ink: #113753;
  --muted: #526f80;
  --line: #d9eaf2;
  --aqua: #1dbbe2;
  --aqua-dark: #1376b9;
  --aqua-pale: #e3f7fb;
  --blue-pale: #eaf5ff;
  --green: #32b99a;
  --green-pale: #e5f8f1;
  --radius: 22px;
  --shadow: 0 18px 60px rgba(25, 107, 156, 0.1);
  --font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --font-heading: "Space Grotesk", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  --tracking-heading: -.045em;
  --tracking-compact: -.025em;
  --tracking-mono: .035em;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
}

* { box-sizing: border-box; }
html { overflow-x: hidden; scroll-behavior: smooth; }
[id] { scroll-margin-top: 94px; }
body { overflow-x: hidden; margin: 0; background: var(--paper); font-family: var(--font-body); font-feature-settings: "kern" 1, "liga" 1; text-rendering: optimizeLegibility; }
p,li,button,input,textarea,select { font-family: var(--font-body); }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 3px solid rgba(22,119,199,.9); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.section-shell { width: min(1180px, calc(100% - 48px)); margin-inline: auto; }
.site-header {
  position: sticky; top: 0; z-index: 10; display: flex; align-items: center; justify-content: space-between;
  height: 78px; padding: 0 max(24px, calc((100% - 1180px) / 2)); background: rgba(251,253,253,.92);
  border-bottom: 1px solid rgba(217,234,242,.86); backdrop-filter: blur(18px);
}
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-heading); font-size: 23px; letter-spacing: -.8px; }
.brand strong { color: var(--aqua-dark); }
.brand-logo { width: 40px; height: 40px; object-fit: cover; border-radius: 9px; }
.site-nav { display: flex; align-items: center; gap: 20px; color: #385963; font-size: 13px; font-weight: 600; }
.site-nav a { position: relative; transition: color .22s ease, transform .22s ease, filter .22s ease; }
.site-nav a:not(.nav-cta)::after {
  content: ""; position: absolute; right: 0; bottom: -7px; left: 0; height: 2px; border-radius: 99px;
  background: linear-gradient(90deg,var(--aqua),var(--green)); opacity: 0; transform: scaleX(.2); transform-origin: center;
  transition: opacity .22s ease, transform .22s ease, box-shadow .22s ease;
}
.site-nav a:hover,.site-nav a:focus-visible { color: var(--aqua-dark); transform: translateY(-2px); }
.site-nav a:not(.nav-cta):hover::after,.site-nav a:not(.nav-cta):focus-visible::after,.site-nav a[aria-current="page"]::after {
  opacity: 1; transform: scaleX(1); box-shadow: 0 0 12px rgba(29,187,226,.44);
}
.nav-cta { padding: 12px 17px; color: var(--white) !important; border-radius: 99px; background: linear-gradient(110deg,var(--aqua-dark),#238a76); box-shadow: 0 7px 16px rgba(19,118,185,.16); }
.nav-cta:hover,.nav-cta:focus-visible { filter: brightness(1.1); box-shadow: 0 11px 24px rgba(19,118,185,.26),0 0 20px rgba(50,185,154,.16); }
.nav-dropdown { position: relative; }
.nav-dropdown:hover,.nav-dropdown:focus-within,.nav-dropdown.open { z-index: 30; }
.nav-dropdown-link { display: inline-flex; align-items: center; gap: 5px; }
.nav-dropdown-link::before { content: ""; width: 6px; height: 6px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; opacity: .72; order: 2; transform: translateY(-2px) rotate(45deg); transition: transform .22s ease; }
.nav-dropdown.open .nav-dropdown-link::before,.nav-dropdown:hover .nav-dropdown-link::before,.nav-dropdown:focus-within .nav-dropdown-link::before { transform: translateY(1px) rotate(225deg); }
.nav-submenu {
  visibility: hidden; position: absolute; z-index: 20; top: calc(100% + 15px); left: -15px; min-width: 218px; padding: 9px;
  border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.98); box-shadow: 0 17px 34px rgba(19,118,185,.14);
  opacity: 0; pointer-events: none; transform: translateY(-7px); transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
}
.nav-submenu::before { content: ""; position: absolute; right: 0; bottom: 100%; left: 0; height: 16px; }
.nav-dropdown:hover .nav-submenu,.nav-dropdown:focus-within .nav-submenu,.nav-dropdown.open .nav-submenu { visibility: visible; opacity: 1; pointer-events: auto; transform: translateY(0); }
.nav-submenu a { display: block; padding: 10px 11px; border-radius: 9px; color: #385963; white-space: nowrap; }
.nav-submenu a::after { display: none; }
.nav-submenu a:hover,.nav-submenu a:focus-visible { color: var(--aqua-dark); background: linear-gradient(110deg,var(--blue-pale),var(--green-pale)); transform: translateY(0); }
.menu-toggle { display: none; }
.hero { position: relative; min-height: 690px; display: grid; align-items: center; }
.hero-copy { position: relative; z-index: 2; width: 50%; padding-bottom: 36px; }
h1,h2,h3 { margin: 0; font-family: var(--font-heading); letter-spacing: var(--tracking-heading); }
h3 { letter-spacing: var(--tracking-compact); }
h1 { max-width: 690px; font-size: clamp(48px, 5vw, 72px); line-height: 1.03; }
h2 { max-width: 730px; font-size: clamp(34px, 3vw, 51px); line-height: 1.1; }
h3 { font-size: 22px; line-height: 1.17; }
.hero-copy p { max-width: 590px; margin: 26px 0 32px; color: var(--muted); font-size: 19px; line-height: 1.65; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.button { display: inline-flex; align-items: center; justify-content: center; padding: 15px 21px; border-radius: 99px; font-weight: 700; transition: transform .22s ease, box-shadow .22s ease, filter .22s ease, border-color .22s ease, background-color .22s ease; }
.button.primary { color: white; background: linear-gradient(110deg,var(--aqua-dark),#238a76); box-shadow: 0 10px 22px rgba(19,118,185,.2); }
.button.secondary { border: 1px solid var(--line); background: rgba(255,255,255,.65); }
.button:hover,.button:focus-visible { transform: translateY(-3px); filter: brightness(1.06); box-shadow: 0 14px 28px rgba(19,118,185,.2),0 0 18px rgba(50,185,154,.12); }
.hero-media { position:absolute; inset:0 -11vw 0 18%; overflow:hidden; z-index:1; pointer-events:none; }
.particle-hero-media { background:radial-gradient(circle at 72% 48%,rgba(29,187,226,.08),transparent 37%); }
.particle-hero-media::before {
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(90deg,var(--paper) 5%,rgba(248,252,255,.96) 22%,rgba(248,252,255,.54) 40%,rgba(248,252,255,.08) 69%,transparent 100%);
}
.particle-hero-video {
  position:absolute; top:50%; right:clamp(-17rem,-13vw,-6rem); width:min(1180px,89vw); height:auto;
  transform:translateY(-50%); object-fit:contain; filter:saturate(1.03) contrast(1.02);
}
.proof { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; padding:20px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.proof div { display:flex; min-height:118px; flex-direction:column; justify-content:center; padding:16px 17px; border:1px solid rgba(19,118,185,.08); border-radius:14px; background:linear-gradient(145deg,rgba(235,248,255,.92),rgba(255,255,255,.9)); }
.proof div:nth-child(2) { background:linear-gradient(145deg,rgba(237,253,250,.96),rgba(255,255,255,.9)); }
.proof div:nth-child(3) { background:linear-gradient(145deg,rgba(246,249,224,.94),rgba(255,255,255,.9)); }
.proof div:nth-child(4) { background:linear-gradient(145deg,rgba(241,241,255,.96),rgba(255,255,255,.9)); }
.proof div:nth-child(5) { background:linear-gradient(145deg,rgba(255,244,230,.94),rgba(255,255,255,.9)); }
.proof strong { width:fit-content; pointer-events:none; user-select:none; font-family:var(--font-heading); color:var(--aqua-dark); font-size:35px; animation:proof-neon 8s linear infinite; }
.proof div:nth-child(2) strong { animation-delay:1.6s; }.proof div:nth-child(3) strong { animation-delay:3.2s; }.proof div:nth-child(4) strong { animation-delay:4.8s; }.proof div:nth-child(5) strong { animation-delay:6.4s; }
.proof span { margin-top:4px; color:var(--muted); font-size:13px; line-height:1.35; }
@keyframes proof-neon { 0%,14%,100% { color:var(--aqua-dark); text-shadow:none; } 4%,10% { color:#078cbc; text-shadow:0 0 5px rgba(29,187,226,.48),0 0 14px rgba(50,185,154,.2); } }
.intro { padding: 145px 0 85px; }
.section-label { margin: 0 0 14px; color: var(--aqua-dark); font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.section-lead { max-width: 730px; margin: 22px 0 0; color: var(--muted); font-size: 19px; line-height: 1.7; }
.solutions { position: relative; isolation: isolate; padding-bottom: 145px; }
.solutions::before,.services-section::before,.infrastructure-page::before,.about::before {
  content: "MACOUTECH"; position: absolute; z-index: 0; top: 24px; right: 0; color: rgba(19,118,185,.045);
  font-family: var(--font-heading); font-size: clamp(46px,7vw,104px); font-weight: 700; letter-spacing: -.07em;
  line-height: 1; pointer-events: none; user-select: none;
}
.solutions > *,.services-section > *,.infrastructure-page > *,.about > * { position: relative; z-index: 1; }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 36px; margin-bottom: 36px; }
.section-heading > p { max-width: 330px; margin: 0; color: var(--muted); line-height: 1.55; }
.solution-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; overflow: hidden; border: 1px solid var(--line); background: var(--line); }
.solution-card {
  isolation: isolate; overflow: hidden; position: relative; min-height: 265px; padding: 27px; border: 0;
  background: linear-gradient(145deg,rgba(255,255,255,.88),rgba(234,245,255,.78));
  transition: transform .28s ease, box-shadow .28s ease, background .28s ease;
}
.solution-card:nth-child(even) { background: linear-gradient(145deg,rgba(255,255,255,.9),rgba(229,248,241,.86)); }
.solution-card:nth-child(3n) { background: linear-gradient(145deg,rgba(234,245,255,.88),rgba(255,255,255,.9)); }
.solution-card.featured { background: linear-gradient(145deg,#dff4ff,#ddf8ef); color: var(--ink); }
.solution-card::before {
  content: ""; position: absolute; z-index: -1; right: -14px; bottom: -12px; width: 128px; height: 128px;
  background: url("assets/macoutech-logo-outline.webp") center / contain no-repeat; filter: grayscale(1) contrast(.82); mix-blend-mode: multiply;
  opacity: .045; transform: translate(8px,8px) scale(.86) rotate(-7deg);
  transition: opacity .34s ease, transform .45s cubic-bezier(.2,.72,.2,1), filter .34s ease;
}
.solution-card::after {
  content: ""; position: absolute; z-index: -2; inset: 0; background: linear-gradient(135deg,rgba(29,187,226,.1),rgba(50,185,154,.13));
  opacity: 0; transition: opacity .28s ease;
}
.solution-card:hover,.solution-card:focus-within { z-index: 2; background: linear-gradient(145deg,#f6fdff,#effcf7); transform: translateY(-7px) scale(1.018); box-shadow: 0 18px 36px rgba(19,118,185,.15),0 0 24px rgba(50,185,154,.12); }
.solution-card:hover::before,.solution-card:focus-within::before { opacity: .15; filter: saturate(.75) contrast(.88) drop-shadow(0 0 14px rgba(29,187,226,.18)); transform: translate(0,0) scale(1) rotate(-4deg); }
.solution-card:hover::after,.solution-card:focus-within::after { opacity: 1; }
.solution-number { margin-bottom: 48px; color: var(--aqua); font-family: var(--font-mono); font-weight: 800; }
.featured .solution-number { color: var(--aqua-dark); }
.solution-card p { color: var(--muted); font-size: 15px; line-height: 1.58; }
.featured p { color: var(--muted); }
.solution-card span { display: block; margin-top: 20px; color: #9bdeda; font-size: 12px; font-weight: 700; letter-spacing: .08em; }
.research { overflow: hidden; background: linear-gradient(115deg,#e9f7ff,#e5f8f1); }
.research-layout { display: grid; grid-template-columns: 1.05fr .95fr; min-height: 570px; align-items: center; }
.research-copy { padding: 90px 0; }
.research-copy > p:not(.section-label) { max-width: 600px; color: var(--muted); font-size: 18px; line-height: 1.7; }
.award-list { display: flex; gap: 42px; margin-top: 42px; }
.award-list div { display: flex; flex-direction: column; gap: 4px; border-left: 2px solid var(--aqua); padding-left: 14px; }
.award-list span { max-width: 175px; color: var(--muted); font-size: 13px; line-height: 1.4; }
.research-visual { position: relative; height: 100%; min-height: 430px; }
.wave { position: absolute; top: 50%; left: -10%; right: -60%; height: 130px; border-top: 3px solid rgba(28,157,155,.4); border-bottom: 3px solid rgba(28,157,155,.16); border-radius: 50%; }
.wave-one { transform: rotate(-9deg) skewX(-25deg); }
.wave-two { transform: rotate(9deg) skewX(25deg); }
.lens { position: absolute; top: 50%; left: 50%; display: grid; grid-template-columns: repeat(3,62px); gap: 10px; transform: translate(-50%,-50%) rotate(45deg); }
.lens span { aspect-ratio: 1; border-radius: 17px; background: rgba(255,255,255,.8); box-shadow: 0 5px 24px rgba(28,157,155,.2); }
.lens span:nth-child(5) { background: linear-gradient(135deg,var(--aqua),var(--green)); }
.about { isolation:isolate; position:relative; padding:125px 0 20px; }
.about-heading { display:grid; grid-template-columns:1fr 420px; gap:40px; align-items:end; }
.about-heading > p,.about-copy p { margin:0; color:var(--muted); font-size:17px; line-height:1.72; }
.about-layout { display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; margin-top:36px; padding-top:32px; border-top:1px solid var(--line); }
.about-copy { display:grid; gap:16px; align-content:start; }
.about-values { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line); }
.about-values article { isolation:isolate; overflow:hidden; position:relative; min-height:210px; padding:23px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:rgba(255,255,255,.52); transition:transform .28s ease,box-shadow .28s ease,background .28s ease; }
.about-values article::after {
  content:""; position:absolute; z-index:-1; right:-15px; bottom:-13px; width:112px; height:112px;
  background:url("assets/macoutech-logo-outline.webp") center / contain no-repeat; filter:grayscale(1) contrast(.82); mix-blend-mode:multiply;
  opacity:.045; transform:translate(8px,8px) scale(.86) rotate(-7deg);
  transition:opacity .34s ease,transform .45s cubic-bezier(.2,.72,.2,1),filter .34s ease;
}
.about-values article:hover,.about-values article:focus-within { z-index:2; background:linear-gradient(145deg,#f6fdff,#effcf7); transform:translateY(-5px); box-shadow:0 17px 31px rgba(19,118,185,.12); }
.about-values article:hover::after,.about-values article:focus-within::after { opacity:.16; filter:grayscale(1) contrast(.74) drop-shadow(0 0 14px rgba(91,112,122,.16)); transform:translate(0,0) scale(1) rotate(-4deg); }
.about-values strong { color:var(--aqua); font-size:12px; letter-spacing:.13em; }.about-values h3 { margin-top:31px; font-size:24px; }.about-values p { color:var(--muted); font-size:14px; line-height:1.58; }
.patents { padding: 140px 0; }
.patent-list { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.patent-list article { padding: 29px; border-radius: var(--radius); background: white; box-shadow: 0 10px 32px rgba(30,95,99,.06); }
.patent-image { display: block; width: calc(100% + 58px); aspect-ratio: 4 / 3; margin: -29px -29px 25px; object-fit: cover; border-radius: var(--radius) var(--radius) 0 0; }
.patent-list span { display: block; margin-bottom: 34px; color: var(--aqua-dark); font-size: 11px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }
.patent-list p { color: var(--muted); font-size: 15px; line-height: 1.6; }
.patent-note { max-width: 790px; margin: 22px 0 0; color: var(--muted); font-size: 13px; line-height: 1.6; }
.team { padding-bottom: 145px; }
.team-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 38px; }
.team-grid article { padding: 28px; border-top: 1px solid var(--line); background: rgba(255,255,255,.45); }
.initials { display: flex; align-items: center; justify-content: center; width: 58px; height: 58px; margin-bottom: 28px; border-radius: 50%; color: var(--aqua-dark); background: var(--aqua-pale); font-family: var(--font-heading); font-weight: 800; }
.team-photo { display: flex; align-items: end; justify-content: center; width: min(100%,220px); height: 255px; margin-bottom: 27px; overflow: hidden; border-radius: 17px; background: linear-gradient(145deg,var(--blue-pale),var(--green-pale)); }
.team-photo img { width: 100%; height: 100%; object-fit: contain; object-position: center bottom; }
.team-grid span { display: block; margin: 8px 0 15px; color: var(--aqua-dark); font-size: 13px; font-weight: 700; }
.team-grid p { color: var(--muted); font-size: 15px; line-height: 1.6; }
.team-grid a { display: inline-block; margin-top: 8px; color: var(--aqua-dark); font-size: 14px; font-weight: 700; }
.contact { display: flex; align-items: center; justify-content: space-between; gap: 28px; padding: 65px; border-radius: 25px; background: linear-gradient(110deg,var(--blue-pale),var(--green-pale)); }
.contact h2 { max-width: 760px; font-size: clamp(31px,3vw,47px); }
footer { display: flex; align-items: center; gap: 24px; width: min(1180px,calc(100% - 48px)); margin: 70px auto 0; padding: 29px 0; border-top: 1px solid var(--line); color: var(--muted); font-size: 13px; }
footer p { margin-right: auto; }
.contact-hero { padding: 118px 0 58px; }
.contact-hero h1 { font-size: clamp(56px,7vw,94px); }
.contact-hero > p:not(.section-label) { max-width: 670px; color: var(--muted); font-size: 19px; line-height: 1.65; }
.contact-details { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.contact-details article { min-height: 185px; padding: 27px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.48); }
.contact-details h2 { margin: 24px 0 10px; font-size: 27px; }
.contact-details a,.contact-details p { color: var(--muted); font-size: 16px; line-height: 1.55; }
.contact-details a:hover { color: var(--aqua-dark); }
.contact-icon { color: var(--green); font-size: 12px; font-weight: 800; letter-spacing: .12em; }
.contact-content { display: grid; grid-template-columns: .92fr 1.08fr; gap: 18px; padding: 85px 0; }
.map-panel,.form-panel { overflow: hidden; padding: 23px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.75); box-shadow: 0 12px 35px rgba(25,107,156,.06); }
.panel-title { min-height: 96px; }
.panel-title h2 { font-size: 31px; }
.map-panel iframe { width: 100%; border: 0; border-radius: 14px; background: var(--blue-pale); }
.map-panel iframe { height: 525px; }
.map-link { margin-top: 16px; font-size: 14px; }
.contact-form { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.contact-form label { display: flex; flex-direction: column; gap: 7px; }
.contact-form label span { color: var(--ink); font-size: 13px; font-weight: 700; }
.contact-form label:has(> [required]) > span:first-of-type::after { content:" *"; color:#c44949; font-weight:800; }
.contact-form input,.contact-form select,.contact-form textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 11px; padding: 13px 14px;
  color: var(--ink); background: #fbfeff; font: inherit; outline: none; transition: .2s ease;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus { border-color: var(--aqua); box-shadow: 0 0 0 3px rgba(29,187,226,.12); }
.contact-form .invalid-field { border-color:#d56b6b; background:#fff2f2; box-shadow:0 0 0 3px rgba(213,107,107,.12); }
.contact-form .invalid-field:focus { border-color:#c44949; background:#fff6f6; box-shadow:0 0 0 3px rgba(213,107,107,.18); }
.phone-field { display:grid; grid-template-columns:112px minmax(0,1fr); gap:8px; }
.contact-form .phone-field .country-code { padding-inline:10px 6px; color:var(--aqua-dark); font-weight:700; }
.contact-form .phone-field input { min-width:0; }
.contact-form textarea { resize: vertical; min-height: 164px; }
.message-field { position:relative; }
.message-field::after {
  content:""; position:absolute; z-index:1; right:18px; bottom:16px; width:118px; height:118px; pointer-events:none;
  background:url("assets/macoutech-logo-outline.webp") center / contain no-repeat; filter:grayscale(1) contrast(.8); mix-blend-mode:multiply;
  opacity:.055; transform:scale(.9) rotate(-6deg); transition:opacity .3s ease,transform .38s ease,filter .3s ease;
}
.message-field:focus-within::after { opacity:.13; filter:grayscale(1) contrast(.76) drop-shadow(0 0 12px rgba(91,112,122,.14)); transform:scale(1) rotate(-3deg); }
.message-field textarea { position:relative; z-index:0; padding-right:142px; background:rgba(251,254,255,.91); }
.full-field,.contact-form .button,.form-note,.form-status { grid-column: 1 / -1; }
.consent-field { display: grid !important; grid-template-columns: 18px 1fr; align-items: start; gap: 9px !important; }
.consent-field input { width: 16px; height: 16px; margin-top: 2px; accent-color: var(--green); }
.consent-field input.invalid-field { outline:2px solid rgba(196,73,73,.72); outline-offset:2px; box-shadow:none; }
.consent-field span { color: var(--muted) !important; font-size: 12px !important; font-weight: 500 !important; line-height: 1.5; }
.consent-field a,.footer-link,.content-page a { color: var(--aqua-dark); font-weight: 700; text-decoration-color: rgba(19,118,185,.38); text-decoration-line: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; transition: color .2s ease, text-decoration-color .2s ease, text-underline-offset .2s ease, filter .2s ease; }
.consent-field a:hover,.consent-field a:focus-visible,.footer-link:hover,.footer-link:focus-visible,.content-page a:hover,.content-page a:focus-visible { color: #0d629c; text-decoration-color: var(--green); text-underline-offset: 6px; filter: drop-shadow(0 4px 7px rgba(29,187,226,.14)); }
.turnstile-field { display:flex; flex-direction:column; gap:7px; }
.turnstile-field small { color:var(--muted); font-size:12px; }
.website-field { position:absolute !important; left:-10000px !important; width:1px !important; height:1px !important; overflow:hidden !important; }
.contact-form .button { width: fit-content; border: 0; cursor: pointer; font: inherit; }
.form-note { margin: 0; color: var(--muted); font-size: 12px; }
.form-status { min-height: 18px; margin: -5px 0 0; color: var(--aqua-dark); font-size: 13px; font-weight: 700; }
.form-status.error { color: #b54848; }
.social-strip { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 44px; border-radius: var(--radius); background: linear-gradient(110deg,var(--blue-pale),var(--green-pale)); }
.social-strip h2 { font-size: 35px; }
.social-links { display: flex; flex-wrap: wrap; gap: 10px; }
.social-links a { padding: 13px 19px; border: 1px solid rgba(19,118,185,.16); border-radius: 99px; color: var(--aqua-dark); background: rgba(255,255,255,.65); font-weight: 700; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background-color .22s ease; }
.social-links a:hover,.social-links a:focus-visible { border-color: rgba(19,118,185,.32); background: white; transform: translateY(-3px); box-shadow: 0 11px 22px rgba(19,118,185,.12); }
.content-page { padding: 108px 0 60px; }
.content-page h1 { max-width: 820px; font-size: clamp(52px,6vw,84px); }
.content-intro { max-width: 760px; margin: 22px 0 54px; color: var(--muted); font-size: 19px; line-height: 1.7; }
.content-page section { max-width: 850px; padding: 27px 0; border-top: 1px solid var(--line); }
.content-page section h2 { margin-bottom: 12px; font-size: 30px; }
.content-page section p,.legal-note { color: var(--muted); line-height: 1.72; }
.legal-note { max-width: 850px; padding: 18px; border-radius: 12px; background: var(--blue-pale); font-size: 13px; }
.lang-link { color: var(--aqua-dark) !important; font-size: 12px; letter-spacing: .1em; }
.detail-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; max-width: 1000px; margin: 12px 0 34px; background: var(--line); border: 1px solid var(--line); }
.detail-grid article { min-height: 230px; padding: 28px; background: rgba(255,255,255,.93); }
.patent-detail-grid .patent-image { width: calc(100% + 56px); margin: -28px -28px 25px; }
.patent-concept { display: flex; min-height: 195px; width: calc(100% + 56px); margin: -28px -28px 25px; padding: 28px; flex-direction: column; justify-content: end; border-radius: var(--radius) var(--radius) 0 0; background: linear-gradient(135deg,#d9f2ff,#dff8ef); }
.patent-concept strong { color: var(--aqua-dark); font-family: var(--font-heading); font-size: 52px; letter-spacing: -.08em; }
.detail-grid .patent-concept span { margin-top: 7px; color: var(--muted); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.patent-badges { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 20px; }
.detail-grid .patent-badges span { padding: 7px 9px; border-radius: 99px; color: var(--aqua-dark); background: var(--blue-pale); font-size: 10px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.detail-grid .patent-badges .registered { color: #197a66; background: var(--green-pale); }
.detail-grid .patent-badges .pending { color: #87620e; background: #fff6d8; }
.patent-detail-grid h2 { margin-top: 0; }
.patent-meta { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; margin: 22px 0 0; }
.patent-meta div { padding: 10px; border-radius: 9px; background: var(--blue-pale); }
.patent-meta dt { color: var(--muted); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.patent-meta dd { margin: 4px 0 0; color: var(--ink); font-size: 14px; font-weight: 700; }
.detail-grid span { color: var(--green); font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.detail-grid h2 { margin: 31px 0 12px; font-size: 29px; }
.detail-grid p { color: var(--muted); line-height: 1.65; }
.detail-grid small { display: block; margin-top: 18px; color: var(--aqua-dark); line-height: 1.55; }
.page-cta { margin-top: 10px; }
.filter-bar { display: flex; flex-wrap: wrap; gap: 9px; margin: 0 0 30px; }
.filter-btn { padding: 10px 15px; border: 1px solid var(--line); border-radius: 99px; color: var(--aqua-dark); background: rgba(255,255,255,.76); cursor: pointer; font: inherit; font-size: 13px; font-weight: 800; }
.filter-btn.active { color: white; border-color: var(--aqua-dark); background: var(--aqua-dark); }
.outputs-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 15px; margin-bottom: 35px; }
.output-card { padding: 28px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.8); }
.output-card.featured { grid-column: 1 / -1; background: linear-gradient(120deg,var(--blue-pale),var(--green-pale)); }
.output-card .output-type { color: var(--aqua-dark); font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.output-card h2 { margin: 20px 0 10px; font-size: 31px; }
.output-card p { color: var(--muted); line-height: 1.7; }
.portfolio-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
.portfolio-grid .output-card { min-height: 390px; }
.portfolio-grid .output-card h2 { font-size: 24px; }
.source-line { margin: 0 0 12px; color: var(--muted); font-size: 14px; font-weight: 700; }
.patent-story { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.patent-story strong { display: block; margin-top: 10px; color: var(--aqua-dark); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.patent-story p { margin: 5px 0 0; color: var(--muted); font-size: 14px; line-height: 1.58; }
.mini-block { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.mini-block strong { display: block; margin-bottom: 5px; color: var(--aqua-dark); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.mini-block p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.62; }
.bigg-feature { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(320px,.95fr); gap: 30px; max-width: none !important; margin-bottom: 38px; padding: 30px !important; border: 1px solid var(--line) !important; border-radius: 25px; background: linear-gradient(145deg,#fff,#f1fbf8); box-shadow: var(--shadow); }
.bigg-images { display: grid; gap: 14px; }
.bigg-images img { display: block; width: 100%; border: 1px solid var(--line); border-radius: 17px; background: white; box-shadow: 0 12px 28px rgba(25,107,156,.08); }
.bigg-images img:last-child { width: min(78%,420px); justify-self: center; }
.bigg-feature h2 { font-size: clamp(34px,4vw,52px) !important; }
.bigg-feature p:not(.section-label) { color: var(--muted); font-size: 17px; line-height: 1.7; }
.portfolio-summary { max-width: none !important; margin-bottom: 32px; padding: 25px 0 30px !important; }
.portfolio-summary p { color: var(--muted); line-height: 1.7; }
.summary-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 11px; margin-top: 20px; }
.summary-grid div { padding: 19px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.8); }
.summary-grid strong { display: block; color: var(--aqua-dark); font-family: var(--font-mono); font-size: 35px; }
.summary-grid span { display: block; margin-top: 5px; color: var(--muted); font-size: 13px; font-weight: 700; }
.output-links { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 18px; }
.output-links a,.card-link { color: var(--aqua-dark); font-size: 14px; font-weight: 800; text-decoration: underline; text-decoration-color: rgba(19,118,185,.38); text-underline-offset: 3px; transition: color .2s ease, text-decoration-color .2s ease, text-underline-offset .2s ease, filter .2s ease; }
.output-links a:hover,.output-links a:focus-visible,.card-link:hover,.card-link:focus-visible { color: #0d629c; text-decoration-color: var(--green); text-underline-offset: 6px; filter: drop-shadow(0 4px 7px rgba(29,187,226,.14)); }
.card-link { display: inline-block; margin-top: 15px; }
.status-granted::before { content: "✓ "; }
.status-pending::before { content: "… "; }
.section-label,.services-tag,.output-type,.patent-badges span,.patent-meta dt,.patent-meta dd,.patent-story strong,.mini-block strong,.solution-number,.services-metric-strip strong,.services-process b,.summary-grid strong,.lang-link {
  font-family: var(--font-mono);
  letter-spacing: var(--tracking-mono);
}
.services-hero { padding: 94px 0 70px; background: linear-gradient(135deg,#f8fdff 0%,#e9f8ff 55%,#e9faf3 100%); }
.section-tabs { display: flex; gap: 8px; padding-top: 22px; padding-bottom: 3px; }
.section-tabs a { padding: 10px 15px; border: 1px solid var(--line); border-radius: 99px; color: var(--muted); background: rgba(255,255,255,.76); font-size: 13px; font-weight: 800; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background-color .22s ease, color .22s ease; }
.section-tabs a.active { border-color: rgba(19,118,185,.2); color: var(--aqua-dark); background: linear-gradient(110deg,var(--blue-pale),var(--green-pale)); }
.section-tabs a:hover,.section-tabs a:focus-visible { border-color: rgba(19,118,185,.28); color: var(--aqua-dark); background: white; transform: translateY(-3px); box-shadow: 0 10px 20px rgba(19,118,185,.1); }
.services-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 62px; align-items: center; }
.services-hero-grid > * { min-width: 0; }
.services-hero-copy h1 { max-width: 780px; font-size: clamp(54px,5vw,79px); line-height: .99; }
.services-hero-copy h1 span { color: var(--aqua-dark); }
.services-hero-copy > p:not(.services-tag) { max-width: 690px; margin: 24px 0 0; color: var(--muted); font-size: 18px; line-height: 1.72; }
.services-tag { display: inline-block; margin: 0 0 20px; padding: 8px 13px; border: 1px solid rgba(29,187,226,.2); border-radius: 99px; color: var(--aqua-dark); background: rgba(255,255,255,.55); font-size: 11px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.services-visual-card { overflow: hidden; position: relative; min-height: 470px; border: 1px solid rgba(19,118,185,.1); border-radius: 28px; background: linear-gradient(145deg,rgba(13,116,175,.94),rgba(19,159,172,.86) 60%,rgba(52,176,132,.84)); box-shadow: 0 24px 65px rgba(18,115,142,.2); }
.services-interference { position: absolute; inset: 0; overflow: hidden; }
.services-ring { position: absolute; top: 49%; left: 51%; width: 220px; height: 220px; border: 1px solid rgba(207,255,248,.45); border-radius: 50%; transform: translate(-50%,-50%); animation: services-ring 4.2s ease-out infinite; }
.services-ring.ring-two { animation-delay: 1.35s; }.services-ring.ring-three { animation-delay: 2.7s; }
.services-beam { position: absolute; top: 50%; left: -9%; width: 61%; height: 2px; background: linear-gradient(90deg,rgba(255,255,255,0),rgba(226,255,251,.83)); transform-origin: right center; animation: services-beam 3.2s ease-in-out infinite; }
.services-beam.beam-two { transform: rotate(14deg); animation-delay: .28s; }.services-beam.beam-three { transform: rotate(-14deg); animation-delay: .56s; }
.services-node { position: absolute; top: 49%; left: 51%; width: 32px; height: 32px; border: 5px solid rgba(255,255,255,.5); border-radius: 50%; background: #d6fff3; box-shadow: 0 0 0 12px rgba(180,255,231,.14),0 0 45px rgba(222,255,247,.9); transform: translate(-50%,-50%); }
.services-metric-strip { display: grid; position: absolute; left: 0; right: 0; bottom: 0; grid-template-columns: repeat(3,1fr); background: rgba(5,69,112,.35); backdrop-filter: blur(8px); }
.services-metric-strip span { min-height: 87px; padding: 18px; border-right: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.86); font-size: 12px; line-height: 1.35; }
.services-metric-strip span:last-child { border: 0; }.services-metric-strip strong { display: block; margin-bottom: 7px; color: #c0ffeb; font-size: 13px; letter-spacing: .12em; }
@keyframes services-ring { 0% { opacity: 0; transform: translate(-50%,-50%) scale(.14); } 26% { opacity: .78; } 100% { opacity: 0; transform: translate(-50%,-50%) scale(2.15); } }
@keyframes services-beam { 0%,100% { opacity: .2; scale: .42 1; } 50% { opacity: .9; scale: 1 1; } }
.services-section { position: relative; isolation: isolate; padding: 112px 0; }
.services-section-head { display: grid; grid-template-columns: 1fr 390px; gap: 40px; align-items: end; margin-bottom: 38px; }
.services-section-head h2 { max-width: 720px; font-size: clamp(36px,4vw,55px); }
.services-section-head > p { margin: 0; color: var(--muted); line-height: 1.7; }
.services-card-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; overflow: hidden; border: 1px solid var(--line); background: var(--line); }
.services-card {
  isolation: isolate; overflow: hidden; position: relative; min-height: 355px; padding: 27px; border: 0;
  background: linear-gradient(145deg,rgba(255,255,255,.9),rgba(234,245,255,.8));
  transition: transform .28s ease, box-shadow .28s ease, background .28s ease;
}
.services-card:nth-child(even) { background: linear-gradient(145deg,rgba(255,255,255,.92),rgba(229,248,241,.88)); }
.services-card:nth-child(3n) { background: linear-gradient(145deg,rgba(234,245,255,.9),rgba(255,255,255,.92)); }
.services-card::before {
  content: ""; position: absolute; z-index: -1; right: -15px; bottom: -13px; width: 134px; height: 134px;
  background: url("assets/macoutech-logo-outline.webp") center / contain no-repeat; filter: grayscale(1) contrast(.82); mix-blend-mode: multiply;
  opacity: .05; transform: translate(8px,8px) scale(.86) rotate(-7deg);
  transition: opacity .34s ease, transform .45s cubic-bezier(.2,.72,.2,1), filter .34s ease;
}
.services-card::after {
  content: ""; position: absolute; z-index: -2; inset: 0; background: linear-gradient(135deg,rgba(29,187,226,.1),rgba(50,185,154,.13));
  opacity: 0; transition: opacity .28s ease;
}
.services-card:hover,.services-card:focus-within { z-index: 2; background: linear-gradient(145deg,#f6fdff,#effcf7); transform: translateY(-7px) scale(1.018); box-shadow: 0 18px 36px rgba(19,118,185,.15),0 0 24px rgba(50,185,154,.12); }
.services-card:hover::before,.services-card:focus-within::before { opacity: .17; filter: grayscale(1) contrast(.74) drop-shadow(0 0 14px rgba(91,112,122,.16)); transform: translate(0,0) scale(1) rotate(-4deg); }
.services-card:hover::after,.services-card:focus-within::after { opacity: 1; }
.services-icon { display: block; min-height: 66px; color: var(--green); font-family: var(--font-heading); font-size: 36px; font-weight: 500; }
.services-card h3 { font-size: 25px; }.services-card p,.services-card li { color: var(--muted); font-size: 14px; line-height: 1.58; }
.services-card ul { margin: 19px 0 0; padding: 16px 0 0 17px; border-top: 1px solid var(--line); }
.services-card li { margin: 5px 0; padding-left: 4px; }
.services-capability-band,.services-proof { background: linear-gradient(115deg,#e9f7ff,#e5f8f1); }
.services-capability-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 55px; padding-top: 76px; padding-bottom: 76px; align-items: center; }
.services-capability-panel h2 { font-size: clamp(35px,4vw,53px); }.services-capability-panel p { color: var(--muted); line-height: 1.72; }
.services-capability-list { display: flex; flex-wrap: wrap; gap: 10px; }
.services-capability-list span { padding: 11px 14px; border: 1px solid rgba(19,118,185,.13); border-radius: 99px; color: var(--aqua-dark); background: rgba(255,255,255,.6); font-size: 13px; font-weight: 700; }
.services-process { display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid var(--line); }
.services-process article { padding: 26px 21px; border-right: 1px solid var(--line); }.services-process article:last-child { border: 0; }
.services-process b { color: var(--aqua); font-size: 13px; letter-spacing: .13em; }.services-process h3 { margin-top: 35px; font-size: 23px; }.services-process p { color: var(--muted); font-size: 14px; line-height: 1.65; }
.services-proof { padding: 100px 0; }.services-proof-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 13px; }
.services-proof-grid article { padding: 29px; border-radius: var(--radius); background: rgba(255,255,255,.67); }
.services-proof-grid h3 { font-size: 25px; }.services-proof-grid p { color: var(--muted); line-height: 1.65; }
.services-cta { margin-top: 100px; padding: 55px; border-radius: 27px; background: linear-gradient(135deg,var(--aqua-dark),#127f99 60%,#238a76); color: white; }
.services-cta h2 { max-width: 850px; font-size: clamp(36px,4vw,56px); }.services-cta p { max-width: 800px; color: rgba(255,255,255,.82); line-height: 1.72; }.services-cta .secondary { margin-top: 16px; border-color: rgba(255,255,255,.22); color: var(--ink); background: white; }
.content-page .services-cta p { color: rgba(255,255,255,.9); }
.infrastructure-page { isolation: isolate; position: relative; max-width: 1180px; }
.infrastructure-summary { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; overflow: hidden; margin: -12px 0 72px; border: 1px solid var(--line); border-radius: 17px; background: var(--line); }
.infrastructure-summary div { padding: 19px; background: linear-gradient(145deg,#fff,var(--blue-pale)); }
.infrastructure-summary div:nth-child(even) { background: linear-gradient(145deg,#fff,var(--green-pale)); }
.infrastructure-summary strong { display: block; color: var(--aqua-dark); font-family: var(--font-mono); font-size: 20px; letter-spacing: var(--tracking-mono); }
.infrastructure-summary span { display: block; margin-top: 7px; color: var(--muted); font-size: 13px; font-weight: 700; }
.content-page .infrastructure-intro,.content-page .infrastructure-panel,.content-page .infrastructure-capabilities { max-width: none; }
.infrastructure-intro { padding-bottom: 40px !important; }
.infrastructure-panel { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); gap: 30px; margin: 24px 0; padding: 28px !important; border: 1px solid var(--line) !important; border-radius: 23px; background: linear-gradient(145deg,#fff,#f2fbf8); box-shadow: var(--shadow); }
.infrastructure-panel img { display: block; width: 100%; height: 100%; min-height: 310px; object-fit: cover; border: 1px solid var(--line); border-radius: 16px; }
.infrastructure-panel h2 { font-size: clamp(29px,3vw,42px) !important; }
.infrastructure-panel p:not(.section-label),.infrastructure-panel li { color: var(--muted); font-size: 15px; line-height: 1.68; }
.infrastructure-panel ul { padding-left: 19px; }
.infrastructure-panel li { margin: 7px 0; }
.infrastructure-capabilities { margin-top: 80px; padding-top: 38px !important; }
.infrastructure-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; overflow: hidden; margin-top: 25px; border: 1px solid var(--line); background: var(--line); }
.infrastructure-grid article { min-height: 220px; padding: 23px; background: linear-gradient(145deg,#fff,var(--blue-pale)); }
.infrastructure-grid article:nth-child(even) { background: linear-gradient(145deg,#fff,var(--green-pale)); }
.infrastructure-grid h3 { font-size: 22px; }
.infrastructure-grid p { color: var(--muted); font-size: 14px; line-height: 1.62; }
.capability-hero { background: radial-gradient(circle at 80% 25%,rgba(50,185,154,.15),transparent 28%),linear-gradient(135deg,#f8fdff,#edf8ff 55%,#eaf9f2); }
.capability-hero-visual { overflow: hidden; position: relative; min-height: 470px; border: 1px solid rgba(19,118,185,.12); border-radius: 28px; background: linear-gradient(145deg,rgba(255,255,255,.94),rgba(234,245,255,.85),rgba(229,248,241,.9)); box-shadow: 0 24px 65px rgba(18,115,142,.14); }
.capability-hero-visual::before,.capability-art::before { content:""; position:absolute; inset:18px; background: linear-gradient(90deg,rgba(19,118,185,.065) 1px,transparent 1px),linear-gradient(0deg,rgba(19,118,185,.065) 1px,transparent 1px); background-size:22px 22px; }
.cap-ring { position:absolute; top:48%; left:50%; width:var(--size); height:var(--size); border:1px solid rgba(19,118,185,.36); border-radius:50%; transform:translate(-50%,-50%); animation:services-ring 5.2s ease-out infinite; }
.cap-ring.r1 { --size:105px; }.cap-ring.r2 { --size:190px; animation-delay:1.45s; border-color:rgba(50,185,154,.35); }.cap-ring.r3 { --size:285px; animation-delay:2.9s; }
.cap-axis { position:absolute; top:48%; left:10%; width:80%; height:2px; background:linear-gradient(90deg,transparent,rgba(19,118,185,.45),rgba(50,185,154,.5),transparent); }.cap-axis.a1 { transform:rotate(27deg); }.cap-axis.a2 { transform:rotate(-27deg); }
.capability-hero-visual > b { position:absolute; top:48%; left:50%; width:56px; height:56px; border-radius:50%; background:radial-gradient(circle,#fff 0 20%,#8ee4de 24%,rgba(29,187,226,.23) 58%,transparent 62%); transform:translate(-50%,-50%); box-shadow:0 0 36px rgba(29,187,226,.42); }
.cap-pillar { position:absolute; width:10px; height:52px; border-radius:8px; background:linear-gradient(var(--aqua-dark),var(--green)); opacity:.75; }.cap-pillar.p1 { top:20%; left:19%; transform:rotate(-16deg); }.cap-pillar.p2 { top:18%; right:20%; transform:rotate(16deg); }.cap-pillar.p3 { bottom:22%; left:24%; transform:rotate(16deg); }.cap-pillar.p4 { right:24%; bottom:21%; transform:rotate(-16deg); }
.capability-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:17px; }
.capability-card { isolation:isolate; overflow:hidden; position:relative; border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.76); box-shadow:0 14px 34px rgba(20,112,137,.055); transition:.25s ease; }
.capability-card::after { content:""; position:absolute; z-index:-1; right:-14px; bottom:-12px; width:116px; height:116px; background:url("assets/macoutech-logo-outline.webp") center / contain no-repeat; filter:grayscale(1) contrast(.82); mix-blend-mode:multiply; opacity:.04; transform:translate(8px,8px) scale(.86) rotate(-7deg); transition:opacity .34s ease,transform .45s cubic-bezier(.2,.72,.2,1),filter .34s ease; }
.capability-card:hover { transform:translateY(-4px); box-shadow:0 20px 42px rgba(20,112,137,.1); }
.capability-card:hover::after,.capability-card:focus-within::after { opacity:.15; filter:grayscale(1) contrast(.74) drop-shadow(0 0 14px rgba(91,112,122,.16)); transform:translate(0,0) scale(1) rotate(-4deg); }
.capability-art { overflow:hidden; position:relative; height:150px; border-bottom:1px solid var(--line); background:linear-gradient(145deg,#f9fdff,#edf8f8); }
.capability-body { padding:25px; }.capability-body h3 { font-size:26px; }.capability-body p,.capability-body li { color:var(--muted); font-size:14px; line-height:1.62; }.capability-body ul { margin:15px 0 0; padding-left:18px; }.capability-body li { margin-top:5px; }
.capability-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:15px; }.capability-tags span { padding:7px 9px; border:1px solid rgba(19,118,185,.11); border-radius:99px; color:var(--aqua-dark); background:var(--blue-pale); font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }
.capability-proof { margin:25px 0 0; padding:18px 20px; border-radius:14px; color:var(--aqua-dark); background:linear-gradient(110deg,var(--blue-pale),var(--green-pale)); font-size:14px; font-weight:700; line-height:1.6; }
.capability-art i,.capability-art b { position:absolute; display:block; }
.art-phononic i { width:22px; height:22px; border:2px solid var(--aqua); border-radius:50%; }.art-phononic i:nth-child(1){left:20%;top:25%}.art-phononic i:nth-child(2){left:38%;top:25%}.art-phononic i:nth-child(3){left:56%;top:25%}.art-phononic i:nth-child(4){left:29%;top:58%}.art-phononic i:nth-child(5){left:47%;top:58%}.art-phononic i:nth-child(6){left:65%;top:58%}.art-phononic b { left:49%; top:38%; width:30px; height:30px; border-radius:50%; background:var(--green); box-shadow:0 0 0 12px rgba(50,185,154,.13); }
.art-saw i { top:24px; width:8px; height:78px; border-radius:5px; background:var(--aqua-dark); }.art-saw i:nth-child(1){left:20%}.art-saw i:nth-child(2){left:27%}.art-saw i:nth-child(3){left:34%}.art-saw i:nth-child(4){right:34%}.art-saw i:nth-child(5){right:27%}.art-saw i:nth-child(6){right:20%}.art-saw b { left:39%; top:63px; width:22%; height:2px; background:linear-gradient(90deg,var(--green),var(--aqua)); box-shadow:0 -12px 0 rgba(29,187,226,.4),0 12px 0 rgba(50,185,154,.4); }
.art-sensor b { left:47%; top:53px; width:38px; height:38px; border-radius:50%; background:var(--green); box-shadow:0 0 0 11px rgba(50,185,154,.12); }.art-sensor i { width:11px; height:11px; border-radius:50%; background:var(--aqua-dark); }.art-sensor i:nth-child(1){left:20%;top:38px}.art-sensor i:nth-child(2){right:20%;top:32px}.art-sensor i:nth-child(3){left:28%;bottom:27px}.art-sensor i:nth-child(4){right:28%;bottom:25px}
.art-fem i { width:64%; height:1px; left:18%; background:rgba(19,118,185,.45); transform-origin:center; }.art-fem i:nth-child(1){top:33px}.art-fem i:nth-child(2){top:58px}.art-fem i:nth-child(3){top:83px}.art-fem i:nth-child(4){top:108px}.art-fem i:nth-child(5){top:70px;transform:rotate(-23deg);background:var(--green)}.art-fem b { left:54%; top:55px; width:18px; height:18px; border-radius:50%; background:var(--aqua); }
.art-cad i { left:27%; width:46%; height:1px; background:var(--aqua-dark); }.art-cad i:nth-child(1){top:39px}.art-cad i:nth-child(2){top:59px}.art-cad i:nth-child(3){top:79px}.art-cad i:nth-child(4){top:99px}.art-cad b { left:37%; top:33px; width:28%; height:75px; border:2px solid var(--green); transform:skewY(-16deg); }
.art-validate i { left:12%; width:17%; height:2px; top:75px; background:var(--aqua-dark); transform-origin:right center; }.art-validate i:nth-child(2){left:28%;transform:rotate(-38deg)}.art-validate i:nth-child(3){left:44%;transform:rotate(51deg)}.art-validate i:nth-child(4){left:60%;transform:rotate(-32deg)}.art-validate i:nth-child(5){left:76%;transform:rotate(25deg)}.art-validate b { left:47%; top:63px; width:20px; height:20px; border-radius:50%; background:var(--green); }
.art-project i { width:18px; height:18px; border-radius:50%; background:var(--aqua); }.art-project i:nth-child(1){left:22%;top:36px}.art-project i:nth-child(2){left:46%;top:69px}.art-project i:nth-child(3){right:22%;top:36px}.art-project i:nth-child(4){right:28%;bottom:20px}.art-project b { left:26%; top:45px; width:50%; height:62px; border:1px solid var(--green); border-radius:50%; }
.art-green i { left:30%; top:66px; width:42%; height:2px; background:var(--aqua); }.art-green i:nth-child(2){transform:rotate(-17deg)}.art-green i:nth-child(3){transform:rotate(17deg)}.art-green b { left:42%; top:28px; width:54px; height:76px; border-radius:70% 0 70% 0; background:linear-gradient(145deg,var(--green),#92db9d); transform:rotate(43deg); opacity:.88; }

@media (max-width: 1180px) and (min-width: 941px) {
  .site-nav { gap: 12px; font-size: 12px; }
  .nav-cta { padding: 10px 13px; }
}

@media (max-width: 940px) {
  .site-header { height: 70px; }
  .menu-toggle { display: grid; gap: 5px; padding: 8px; border: 0; background: transparent; }
  .menu-toggle span { display: block; width: 23px; height: 2px; background: var(--ink); }
  .site-nav { display: none; position: absolute; top: 70px; left: 0; right: 0; padding: 20px 24px; flex-direction: column; align-items: stretch; gap: 15px; background: var(--paper); border-bottom: 1px solid var(--line); }
  .site-nav.open { display: flex; }
  .site-nav a:not(.nav-cta)::after { right: auto; width: 42px; transform-origin: left center; }
  .nav-dropdown-link { justify-content: space-between; width: 100%; }
  .nav-submenu { display: none; visibility: visible; position: static; min-width: 0; margin-top: 9px; padding: 6px; border-radius: 11px; box-shadow: none; opacity: 1; pointer-events: auto; transform: none; transition: none; }
  .nav-dropdown:hover .nav-submenu,.nav-dropdown:focus-within .nav-submenu { display: none; }
  .nav-dropdown.open .nav-submenu { display: block; }
  .nav-submenu::before { display: none; }
  .hero { min-height: 690px; align-items: start; padding-top: 72px; }
  .hero-copy { width: 100%; }
  h1 { font-size: 48px; }
  .hero-copy p { font-size: 17px; }
  .hero-media { inset: 255px -48% 0 -48%; opacity: .84; }
  .particle-hero-media::before { background:linear-gradient(180deg,rgba(248,252,255,.12) 0%,rgba(248,252,255,.42) 42%,var(--paper) 94%); }
  .particle-hero-video { top:28%; right:auto; left:50%; width:min(1040px,148vw); transform:translateX(-50%); }
  .proof { grid-template-columns: repeat(2,1fr); }
  .proof div { min-height:104px; padding:15px; }
  .proof div:last-child { grid-column:1 / -1; }
  .proof strong { font-size: 29px; }
  .intro { padding: 90px 0 55px; }
  .section-heading { align-items: start; flex-direction: column; }
  .solution-grid { grid-template-columns: 1fr; }
  .solution-card { min-height: auto; }
  .solution-card:hover,.solution-card:focus-within { transform: translateY(-4px) scale(1.008); }
  .solution-number { margin-bottom: 28px; }
  .research-layout { grid-template-columns: 1fr; }
  .research-visual { min-height: 280px; }
  .about { padding-top:88px; }.about-heading,.about-layout { grid-template-columns:1fr; gap:20px; }.about-layout { margin-top:25px; padding-top:24px; }
  .about-values { grid-template-columns:1fr; }.about-values article { min-height:auto; }.about-values h3 { margin-top:22px; }
  .award-list { gap: 25px; flex-direction: column; }
  .patents { padding: 90px 0; }
  .patent-list,.team-grid { grid-template-columns: 1fr; }
  .team { padding-bottom: 90px; }
  .contact { padding: 34px; flex-direction: column; align-items: start; }
  footer { flex-wrap: wrap; gap: 14px; }
  footer p { width: 100%; margin: 0; }
  .contact-hero { padding: 76px 0 38px; }
  .contact-details,.contact-content { grid-template-columns: 1fr; }
  .contact-content { padding: 54px 0; }
  .map-panel iframe { height: 330px; }
  .contact-form { grid-template-columns: 1fr; }
  .full-field,.contact-form .button,.form-note,.form-status { grid-column: auto; }
  .social-strip { padding: 28px; flex-direction: column; align-items: start; }
  .detail-grid { grid-template-columns: 1fr; }
  .content-page h1 { overflow-wrap: normal; font-size: 43px; }
  .patent-detail-grid h2,.patent-detail-grid small { overflow-wrap: anywhere; }
  .services-hero { padding: 62px 0 45px; }.services-hero-grid,.services-capability-panel { grid-template-columns: 1fr; gap: 35px; }
  .services-hero-copy h1 { overflow-wrap: anywhere; font-size: 54px; }.services-visual-card { min-height: 335px; }
  .services-metric-strip span { min-height: 79px; padding: 14px 10px; font-size: 10px; }
  .services-section { padding: 78px 0; }.services-section-head { grid-template-columns: 1fr; gap: 15px; }
  .services-card-grid,.services-process,.services-proof-grid { grid-template-columns: 1fr; }
  .services-card { min-height: auto; }.services-process article { border-right: 0; border-bottom: 1px solid var(--line); }
  .services-card:hover,.services-card:focus-within { transform: translateY(-4px) scale(1.008); }
  .services-proof { padding: 76px 0; }.services-cta { margin-top: 74px; padding: 31px; }
  .capability-hero-visual { min-height:335px; }.capability-grid { grid-template-columns:1fr; }
  .outputs-grid,.portfolio-grid,.bigg-feature,.summary-grid { grid-template-columns: 1fr; }.output-card.featured { grid-column: auto; }
  .infrastructure-summary,.infrastructure-panel,.infrastructure-grid { grid-template-columns: 1fr; }
  .infrastructure-panel.reverse img { order: -1; }
  .infrastructure-panel img { min-height: 230px; }
}

@media (max-width: 940px) and (orientation: landscape) {
  .hero { min-height: 560px; }
  .hero-copy { max-width: 68%; }
  .hero-media { inset:70px -30% 0 28%; opacity:.62; }
  .particle-hero-media::before { background:linear-gradient(90deg,var(--paper) 0%,rgba(248,252,255,.84) 24%,rgba(248,252,255,.12) 72%,transparent 100%); }
  .particle-hero-video { top:43%; left:56%; width:min(980px,112vw); transform:translate(-50%,-50%); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
  .proof strong { animation:none; text-shadow:none; }
  .particle-hero-video { display:none; }
  .particle-hero-media {
    background-image:url("assets/macoutech-logo-outline.webp");
    background-repeat:no-repeat; background-position:center right; background-size:min(1180px,89vw) auto;
  }
}
