:root {
  --bg: oklch(0.12 0.038 264);
  --surface: oklch(0.17 0.05 264);
  --surface-2: oklch(0.22 0.055 260);
  --ink: oklch(0.97 0.008 255);
  --muted: oklch(0.75 0.025 255);
  --primary: oklch(0.72 0.10 82);
  --primary-dark: oklch(0.22 0.07 264);
  --accent: oklch(0.72 0.09 245);
  --hairline: oklch(0.46 0.045 255 / 42%);
  --font-display: "Barlow Condensed", sans-serif;
  --font-body: "Source Sans 3", sans-serif;
  --ease: cubic-bezier(.16, 1, .3, 1);
  --shell: min(1240px, calc(100% - 48px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--ink); font-family: var(--font-body); font-size: 17px; line-height: 1.6; overflow-x: hidden; }
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 4px; }
::selection { background: var(--primary); color: var(--bg); }

.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; }
.skip-link { position: fixed; z-index: 100; top: 12px; left: 12px; padding: 10px 16px; background: var(--ink); color: var(--bg); transform: translateY(-150%); transition: transform .2s; }
.skip-link:focus { transform: none; }
.shell { width: var(--shell); margin-inline: auto; }
.section { padding-block: clamp(88px, 10vw, 160px); }

.site-header { position: fixed; z-index: 30; inset: 0 0 auto; height: 84px; border-bottom: 1px solid transparent; transition: background .35s, border-color .35s, height .35s; }
.site-header.scrolled { height: 68px; background: oklch(0.12 .038 264 / 94%); border-color: var(--hairline); backdrop-filter: blur(16px); }
.header-inner { width: var(--shell); height: 100%; margin-inline: auto; display: flex; align-items: center; gap: 36px; }
.brand { width: 168px; height: 52px; display: flex; align-items: center; gap: 9px; text-decoration: none; }
.brand img { width: 45px; height: 45px; object-fit: contain; border-radius: 50%; }
.brand span { font: 800 1.55rem/.9 var(--font-display); letter-spacing: .035em; }
.main-nav { margin-left: auto; display: flex; align-items: center; gap: 30px; }
.main-nav a { color: var(--muted); text-decoration: none; font-size: .92rem; font-weight: 600; transition: color .2s; }
.main-nav a:hover { color: var(--ink); }
.menu-toggle { display: none; }

.button { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 0 25px; border: 0; border-radius: 6px; background: var(--primary); color: white; font-weight: 700; text-decoration: none; cursor: pointer; transition: transform .2s var(--ease), background .2s; }
.button:hover { transform: translateY(-2px); background: oklch(0.77 0.11 82); }
.button-small { min-height: 42px; padding-inline: 18px; font-size: .9rem; }
.text-link { display: inline-flex; gap: 10px; align-items: center; color: var(--ink); font-weight: 700; text-decoration: none; border-bottom: 1px solid var(--hairline); padding-bottom: 4px; }
.text-link span { color: var(--primary); transition: transform .2s; }
.text-link:hover span { transform: translate(3px, -3px); }

.hero { position: relative; min-height: 100svh; padding-top: 118px; overflow: hidden; display: flex; flex-direction: column; background: radial-gradient(circle at 72% 42%, oklch(0.30 .075 250 / 55%), transparent 36%), var(--bg); }
.hero-grid { position: absolute; inset: 0 0 100px 48%; opacity: .22; background-image: linear-gradient(var(--hairline) 1px, transparent 1px), linear-gradient(90deg, var(--hairline) 1px, transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(to left, black, transparent 85%); }
.hero-glow { position: absolute; width: 500px; height: 500px; border-radius: 50%; right: 2%; top: 20%; border: 1px solid oklch(0.72 .10 82 / 28%); box-shadow: inset 0 0 80px oklch(0.72 .10 82 / 7%); }
.hero-glow::before, .hero-glow::after { content: ""; position: absolute; inset: 12%; border: 1px solid var(--hairline); border-radius: inherit; }
.hero-glow::after { inset: 28%; }
.hero-brand-city { position: absolute; z-index: 0; inset: 0 auto auto 0; width: 74%; height: 100%; object-fit: cover; object-position: left center; opacity: .11; mix-blend-mode: luminosity; mask-image: linear-gradient(90deg, black 0%, black 36%, transparent 85%); }
.hero-layout { flex: 1; position: relative; display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; min-height: 650px; }
.hero-copy { position: relative; z-index: 3; padding-bottom: 40px; }
.status-line, .signal-label { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: .82rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.status-line span, .signal-label span { width: 8px; height: 8px; background: var(--primary); border-radius: 50%; box-shadow: 0 0 0 7px oklch(0.72 .10 82 / 13%); }
h1, h2, h3 { margin: 0; font-family: var(--font-display); line-height: .95; text-wrap: balance; }
.hero h1 { margin-top: 24px; font-size: clamp(4.4rem, 8vw, 5.5rem); font-weight: 700; letter-spacing: -.03em; text-transform: uppercase; }
.hero h1 strong { color: var(--primary); font-weight: 800; }
.hero-lead { max-width: 570px; color: var(--muted); font-size: clamp(1.08rem, 1.4vw, 1.26rem); line-height: 1.55; text-wrap: pretty; }
.hero-actions { display: flex; align-items: center; gap: 28px; margin-top: 34px; }
.hero-visual { align-self: end; justify-self: stretch; position: relative; height: min(72vh, 720px); z-index: 2; }
.hero-visual::before { content: ""; position: absolute; width: 74%; aspect-ratio: 1; border-radius: 50%; background: oklch(0.21 .065 260); bottom: 2%; left: 15%; box-shadow: 0 0 90px oklch(0.72 .10 82 / 12%); }
.hero-visual img { position: absolute; z-index: 2; height: 95%; width: 100%; bottom: 0; object-fit: contain; object-position: center bottom; filter: saturate(.72) contrast(1.06); }
.scan-line { position: absolute; z-index: 4; left: 12%; right: 8%; top: 35%; height: 1px; background: linear-gradient(90deg, transparent, var(--primary), transparent); box-shadow: 0 0 12px var(--primary); animation: scan 5s ease-in-out infinite; }
.visual-index { position: absolute; z-index: 4; right: 6%; top: 13%; font-family: var(--font-display); color: var(--muted); letter-spacing: .12em; }
.hero-fact { position: absolute; z-index: 5; right: 3%; bottom: 10%; display: flex; align-items: center; gap: 13px; padding: 13px 16px; background: oklch(0.13 .04 264 / 90%); border: 1px solid var(--hairline); border-radius: 8px; backdrop-filter: blur(10px); }
.hero-fact b, .hero-fact small { display: block; }
.hero-fact small { color: var(--muted); }
.fact-pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--primary); animation: pulse 2s infinite; }
.trust-strip { min-height: 100px; display: flex; align-items: center; gap: 36px; border-top: 1px solid var(--hairline); }
.trust-strip p { color: var(--muted); }
.trust-items { flex: 1; display: flex; justify-content: space-between; gap: 20px; font-family: var(--font-display); font-size: 1.18rem; font-weight: 600; text-transform: uppercase; }

.intro { background: oklch(0.97 0.006 255); color: oklch(0.18 .045 264); }
.intro-layout { display: grid; grid-template-columns: .45fr 1.2fr .8fr; gap: clamp(32px, 5vw, 80px); align-items: start; }
.section-mark { writing-mode: vertical-rl; color: oklch(0.48 .045 260); font-size: .76rem; font-weight: 700; letter-spacing: .12em; }
.intro h2, .section-heading h2, .credentials h2, .contact h2 { font-size: clamp(3rem, 5.6vw, 5.2rem); letter-spacing: -.025em; text-transform: uppercase; }
.intro-main > p { margin-top: 34px; max-width: 660px; color: oklch(0.38 .04 260); font-size: 1.12rem; line-height: 1.7; }
.principles { margin: 0; }
.principles > div { display: grid; grid-template-columns: 42px 1fr; gap: 14px; padding: 20px 0; border-top: 1px solid oklch(0.78 .025 255); }
.principles dt { color: oklch(0.58 .10 82); font-family: var(--font-display); font-weight: 700; }
.principles dd { margin: 0; }
.principles strong, .principles span { display: block; }
.principles strong { font-size: 1.1rem; }
.principles span { color: oklch(0.42 .035 260); font-size: .93rem; }
.founders-heading { grid-column: 1 / -1; display: grid; grid-template-columns: .55fr 1.45fr; gap: clamp(32px, 6vw, 90px); align-items: end; margin-top: clamp(70px, 9vw, 130px); padding-top: 34px; border-top: 1px solid oklch(0.78 .025 255); }
.founders-heading > p { margin: 0; color: oklch(0.48 .075 82); font-size: .8rem; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }
.founders-heading h3 { max-width: 800px; font-size: clamp(2.5rem, 4.4vw, 4.4rem); color: oklch(0.18 .045 264); letter-spacing: -.02em; text-transform: uppercase; }
.founders { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 58px); margin-top: 54px; }
.founder { min-width: 0; display: grid; grid-template-columns: minmax(220px, .82fr) 1fr; min-height: 490px; background: oklch(0.93 .015 255); overflow: hidden; }
.founder-photo { position: relative; min-height: 100%; overflow: hidden; background: var(--primary-dark); }
.founder-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, oklch(0.16 .055 264 / 40%), transparent 48%); }
.founder-photo img { position: absolute; z-index: 1; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; filter: saturate(.92) contrast(1.02); }
.founder-luigi .founder-photo img { object-position: center 42%; }
.founder-photo span { position: absolute; z-index: 2; left: 18px; bottom: 12px; color: oklch(1 0 0 / 76%); font: 800 4rem/1 var(--font-display); letter-spacing: -.03em; }
.founder-copy { display: flex; flex-direction: column; align-items: flex-start; padding: clamp(28px, 3.3vw, 48px); color: oklch(0.18 .045 264); }
.founder-role { margin: 0 0 24px; color: oklch(0.49 .09 82); font-size: .76rem; font-weight: 700; letter-spacing: .08em; line-height: 1.35; text-transform: uppercase; }
.founder-copy h3 { font-size: clamp(2.1rem, 3.2vw, 3.4rem); letter-spacing: -.02em; text-transform: uppercase; }
.founder-copy > p:not(.founder-role) { margin: 24px 0 30px; color: oklch(0.38 .04 260); line-height: 1.65; }
.founder-copy ul { width: 100%; margin: auto 0 0; padding: 0; list-style: none; }
.founder-copy li { padding: 9px 0; border-top: 1px solid oklch(0.78 .025 255); color: oklch(0.31 .05 260); font-size: .9rem; font-weight: 600; }

.services { background: var(--bg); }
.section-heading { display: grid; grid-template-columns: .9fr 1fr; align-items: end; gap: 60px; margin-bottom: 72px; }
.section-heading p { max-width: 570px; margin: 0 0 6px; color: var(--muted); font-size: 1.12rem; }
.service-ledger { border-top: 1px solid var(--hairline); }
.service-row { display: grid; grid-template-columns: 70px 1fr 1.2fr 40px; gap: 32px; align-items: center; min-height: 130px; padding: 22px 8px; border-bottom: 1px solid var(--hairline); transition: padding .35s var(--ease), background .25s; }
.service-row:hover { padding-inline: 20px; background: var(--surface); }
.service-no { color: var(--primary); font-family: var(--font-display); font-weight: 700; }
.service-row h3 { font-size: clamp(1.8rem, 3vw, 2.7rem); text-transform: uppercase; letter-spacing: -.015em; }
.service-row p { color: var(--muted); line-height: 1.5; }
.service-arrow { justify-self: end; color: var(--primary); font-size: 1.4rem; }

.operators { position: relative; background: var(--surface); overflow: hidden; }
.operators-layout { display: grid; grid-template-columns: .95fr 1fr; gap: clamp(50px, 8vw, 120px); align-items: center; }
.operators-visual { position: relative; min-height: 650px; }
.photo-frame { position: absolute; inset: 0 8% 0 0; overflow: hidden; background: radial-gradient(circle at 50% 42%, oklch(0.34 .075 252), oklch(0.13 .04 264) 68%); clip-path: polygon(8% 0, 100% 0, 92% 100%, 0 100%); }
.photo-frame::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 65%, var(--surface)); }
.photo-frame img { width: 100%; height: 100%; object-fit: contain; object-position: center bottom; filter: saturate(.65); }
.operator-note { position: absolute; z-index: 2; left: 0; bottom: 6%; max-width: 300px; padding: 17px 20px; background: var(--primary); color: white; border-radius: 0 8px 8px 0; }
.operator-note b, .operator-note span { display: block; }
.operator-note span { font-size: .84rem; opacity: .82; line-height: 1.35; }
.operators-copy { position: relative; z-index: 2; }
.outline-word { position: absolute; z-index: -1; right: -18vw; top: -130px; font-family: var(--font-display); font-size: clamp(7rem, 15vw, 14rem); line-height: 1; font-weight: 800; color: transparent; -webkit-text-stroke: 1px oklch(0.72 .10 82 / 14%); }
.operators h2, .technology h2 { font-size: clamp(3.1rem, 5vw, 5rem); letter-spacing: -.025em; text-transform: uppercase; }
.operators-copy > p { max-width: 610px; color: var(--muted); font-size: 1.08rem; }
.check-list { margin: 32px 0; padding: 0; list-style: none; }
.check-list li { position: relative; padding: 13px 0 13px 32px; border-bottom: 1px solid var(--hairline); }
.check-list li::before { content: "✓"; position: absolute; left: 2px; color: var(--primary); font-weight: 800; }

.technology { position: relative; background: oklch(0.97 0.006 255); color: oklch(0.18 .045 264); overflow: hidden; }
.tech-bg { position: absolute; inset: 0; opacity: .06; background-image: radial-gradient(oklch(0.30 .08 260) 1px, transparent 1px); background-size: 22px 22px; }
.technology-layout { position: relative; display: grid; grid-template-columns: 1fr .9fr; gap: clamp(50px, 9vw, 130px); align-items: center; }
.technology .signal-label { color: oklch(0.42 .045 260); }
.technology h2 { margin-top: 24px; }
.tech-copy > p:not(.signal-label) { margin-top: 28px; color: oklch(0.38 .04 260); max-width: 670px; font-size: 1.08rem; }
.tech-specs { display: flex; gap: 22px; margin-top: 44px; }
.tech-specs div { flex: 1; padding-top: 16px; border-top: 2px solid var(--primary); }
.tech-specs strong, .tech-specs span { display: block; }
.tech-specs strong { font: 800 clamp(2rem, 3vw, 3rem)/1 var(--font-display); }
.tech-specs span { margin-top: 8px; color: oklch(0.42 .035 260); font-size: .86rem; line-height: 1.3; }
.tech-panel { position: relative; min-height: 520px; overflow: hidden; border-radius: 10px; background: oklch(0.12 0 0); }
.tech-panel > img { width: 100%; height: 100%; object-fit: cover; opacity: .62; filter: saturate(.55); }
.tech-panel::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, oklch(0.12 .04 264 / 20%), oklch(0.24 .08 255 / 58%)); }
.radar { position: absolute; z-index: 2; width: 260px; height: 260px; border: 1px solid oklch(0.72 .10 82 / 42%); border-radius: 50%; inset: 50% auto auto 50%; transform: translate(-50%, -50%); }
.radar::before, .radar::after { content: ""; position: absolute; inset: 20%; border: inherit; border-radius: inherit; }
.radar::after { inset: 40%; }
.radar span { position: absolute; left: 50%; bottom: 50%; width: 50%; height: 50%; transform-origin: bottom left; border-left: 1px solid var(--primary); background: linear-gradient(100deg, oklch(0.72 .10 82 / 24%), transparent 60%); animation: radar 4s linear infinite; }
.radar i { position: absolute; left: 68%; top: 30%; width: 8px; height: 8px; background: var(--accent); border-radius: 50%; box-shadow: 0 0 12px var(--accent); }
.tech-panel-label { position: absolute; z-index: 3; inset: auto 18px 18px; color: var(--ink); font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; }

.credentials { background: var(--bg); }
.credentials-title { display: flex; justify-content: space-between; align-items: end; gap: 50px; margin-bottom: 72px; }
.credentials-intro { max-width: 500px; }
.credentials-title p { margin-top: 0; color: var(--muted); }
.brochure-download { margin-top: 18px; }
.credentials-grid { display: grid; grid-template-columns: 1.45fr .8fr .8fr; gap: 14px; align-items: stretch; }
.credential { margin: 0; min-height: 310px; padding: 28px; display: flex; flex-direction: column; justify-content: space-between; background: oklch(0.97 0.006 255); color: oklch(0.20 .045 264); border-radius: 10px; }
.credential img { width: 100%; height: 190px; object-fit: contain; }
.credential figcaption { margin-top: 20px; font-weight: 700; font-size: .9rem; }
.credential-certificate { background: oklch(0.15 0 0); color: var(--ink); }
.ifpo-logos { flex: 1; display: grid; grid-template-columns: 1.7fr .8fr; gap: 26px; align-items: center; }
.ifpo-logos img { height: 170px; }

.contact { background: var(--primary-dark); }
.contact-layout { display: grid; grid-template-columns: .95fr 1fr; gap: clamp(60px, 9vw, 130px); }
.contact-copy > p:not(.signal-label) { color: oklch(0.82 .025 255); max-width: 560px; }
.direct-contacts { margin-top: 42px; }
.direct-contacts a { display: grid; grid-template-columns: 100px 1fr; gap: 16px; padding: 17px 0; border-top: 1px solid oklch(0.72 .10 82 / 28%); text-decoration: none; }
.direct-contacts small { color: oklch(0.80 .055 82); }
.direct-contacts strong { overflow-wrap: anywhere; }
.contact-form { padding: clamp(26px, 4vw, 46px); background: oklch(0.13 .04 264); border-radius: 12px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact-form label { display: block; margin-bottom: 18px; color: var(--muted); font-size: .88rem; font-weight: 600; }
.contact-form label > span { font-weight: 400; }
.contact-form input:not([type="checkbox"]), .contact-form select, .contact-form textarea { width: 100%; margin-top: 7px; border: 1px solid var(--hairline); border-radius: 5px; background: oklch(0.18 .045 264); color: var(--ink); padding: 12px 13px; transition: border-color .2s, background .2s; }
.contact-form input:not([type="checkbox"]), .contact-form select { height: 50px; }
.contact-form textarea { resize: vertical; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--primary); background: oklch(0.22 .055 260); outline: none; }
.privacy { display: flex !important; align-items: flex-start; gap: 10px; }
.privacy input { width: 17px; height: 17px; margin-top: 3px; accent-color: var(--primary); }
.privacy a { color: var(--ink); text-underline-offset: 3px; }
.honeypot { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip-path: inset(50%); white-space: nowrap; }
.form-submit { width: 100%; }
.form-note { margin: 10px 0 0; color: var(--muted); text-align: center; font-size: .8rem; }

.site-footer { padding: 72px 0 20px; background: oklch(0.09 .03 264); }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 50px; }
.footer-brand img { width: 112px; border-radius: 8px; }
.footer-brand p, .footer-grid > div > p { color: var(--muted); }
.footer-grid h3 { font: 700 1.15rem var(--font-display); text-transform: uppercase; }
.footer-grid a { text-decoration: none; }
.footer-bottom { display: flex; justify-content: space-between; gap: 24px; margin-top: 65px; padding-top: 18px; border-top: 1px solid var(--hairline); color: var(--muted); font-size: .82rem; }
.legal-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 18px; }
.legal-links a { color: inherit; text-decoration: none; }
.legal-links a:hover { color: var(--ink); }
.whatsapp-float { position: fixed; z-index: 20; right: 22px; bottom: 22px; width: 56px; height: 56px; display: grid; place-items: center; border-radius: 50%; background: var(--primary); box-shadow: 0 6px 8px oklch(0 0 0 / 28%); transition: transform .25s var(--ease); }
.whatsapp-float:hover { transform: translateY(-4px) scale(1.03); }
.whatsapp-float svg { width: 27px; fill: white; }

.legal-body { min-height: 100vh; background: oklch(0.97 0.006 255); color: oklch(0.18 .045 264); }
.legal-header { position: sticky; z-index: 10; top: 0; min-height: 78px; padding: 12px max(24px, calc((100% - 1120px) / 2)); display: flex; justify-content: space-between; align-items: center; gap: 24px; background: var(--bg); color: var(--ink); border-bottom: 1px solid var(--hairline); }
.legal-brand { display: flex; align-items: center; gap: 10px; color: var(--ink); text-decoration: none; }
.legal-brand img { width: 48px; height: 48px; border-radius: 50%; }
.legal-brand span { font: 800 1.55rem var(--font-display); letter-spacing: .03em; }
.legal-page { width: min(1120px, calc(100% - 48px)); margin-inline: auto; padding: clamp(70px, 8vw, 120px) 0; }
.legal-hero { padding-bottom: clamp(45px, 6vw, 80px); border-bottom: 1px solid oklch(0.78 .025 255); }
.legal-hero h1, .thanks-content h1 { margin-top: 24px; font-size: clamp(4rem, 9vw, 6rem); color: oklch(0.18 .045 264); letter-spacing: -.03em; text-transform: uppercase; }
.legal-hero > p:last-child { color: oklch(0.43 .035 260); }
.legal-content { max-width: 820px; margin: 70px auto 0; }
.legal-content section { padding: 0 0 42px; margin-bottom: 42px; border-bottom: 1px solid oklch(0.82 .02 255); }
.legal-content h2 { font-size: clamp(1.8rem, 3vw, 2.55rem); color: oklch(0.18 .045 264); text-transform: uppercase; }
.legal-content p, .legal-content li { color: oklch(0.35 .035 260); line-height: 1.75; }
.legal-content a { color: oklch(0.40 .09 250); text-underline-offset: 3px; overflow-wrap: anywhere; }
.legal-content li + li { margin-top: 12px; }
.legal-footer { padding: 24px max(24px, calc((100% - 1120px) / 2)); display: flex; justify-content: space-between; gap: 24px; background: var(--bg); color: var(--muted); font-size: .86rem; }
.legal-footer a { color: inherit; }
.thanks-page { min-height: 100vh; padding: clamp(28px, 5vw, 70px); background: radial-gradient(circle at 70% 40%, oklch(0.30 .075 250 / 55%), transparent 36%), var(--bg); color: var(--ink); }
.thanks-content { max-width: 760px; margin: clamp(90px, 15vh, 170px) auto 0; }
.thanks-content h1 { color: var(--ink); }
.thanks-content > p:not(.signal-label) { max-width: 590px; color: var(--muted); font-size: 1.12rem; }
.thanks-content > p a { color: var(--ink); }
.thanks-content .button { margin-top: 24px; }

.load-in { animation: entrance .9s var(--ease) both; }
.delay-1 { animation-delay: .1s; }
.delay-2 { animation-delay: .2s; }
.delay-3 { animation-delay: .3s; }

@keyframes entrance { from { opacity: .01; transform: translateY(28px); filter: blur(8px); } to { opacity: 1; transform: none; filter: none; } }
@keyframes scan { 0%, 100% { transform: translateY(-100px); opacity: 0; } 20%, 80% { opacity: .8; } 50% { transform: translateY(220px); } }
@keyframes pulse { 50% { box-shadow: 0 0 0 8px oklch(0.72 .10 82 / 0%); } }
@keyframes radar { to { transform: rotate(360deg); } }

@media (max-width: 1050px) {
  .header-cta { display: none; }
  .hero-layout { grid-template-columns: 1.1fr .9fr; }
  .intro-layout { grid-template-columns: 30px 1fr; }
  .principles { grid-column: 2; }
  .founders-heading, .founders { grid-column: 1 / -1; }
  .founder { grid-template-columns: 1fr; }
  .founder-photo { min-height: 410px; }
  .founder-copy { min-height: 410px; }
  .credentials-grid { grid-template-columns: 1fr 1fr; }
  .credential-ifpo { grid-column: span 2; }
  .footer-grid { grid-template-columns: 1.2fr 1fr 1fr; }
  .footer-grid > div:last-child { grid-column: 2; }
}

@media (max-width: 800px) {
  :root { --shell: min(100% - 32px, 680px); }
  .site-header { height: 70px; }
  .brand { width: 150px; }
  .brand img { width: 40px; height: 40px; }
  .menu-toggle { order: 3; margin-left: auto; display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 44px; height: 44px; border: 0; background: transparent; }
  .menu-toggle > span:not(.sr-only) { display: block; width: 24px; height: 2px; margin-left: auto; background: var(--ink); transition: transform .25s, opacity .2s; }
  .menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .main-nav { position: fixed; inset: 69px 0 0; padding: 45px 24px; display: flex; flex-direction: column; align-items: flex-start; gap: 8px; background: var(--bg); transform: translateX(100%); transition: transform .45s var(--ease); }
  .main-nav.open { transform: none; }
  .main-nav a { width: 100%; padding: 15px 0; border-bottom: 1px solid var(--hairline); font: 700 2rem var(--font-display); text-transform: uppercase; }
  .hero { padding-top: 100px; min-height: auto; }
  .hero-layout { display: flex; flex-direction: column; align-items: stretch; }
  .hero-copy { padding-top: 45px; }
  .hero h1 { font-size: clamp(3.8rem, 17vw, 5.4rem); }
  .hero-visual { width: 100%; height: 560px; }
  .hero-grid { inset-left: 15%; }
  .trust-strip { padding-block: 22px; align-items: flex-start; }
  .trust-items { flex-wrap: wrap; justify-content: flex-start; }
  .trust-items span { flex: 0 0 calc(50% - 10px); }
  .section-heading, .operators-layout, .technology-layout, .contact-layout { grid-template-columns: 1fr; }
  .founders-heading { grid-template-columns: 1fr; align-items: start; }
  .founders { grid-template-columns: 1fr; }
  .founder { grid-template-columns: minmax(180px, .7fr) 1fr; min-height: 500px; }
  .founder-photo { min-height: 100%; }
  .founder-copy { min-height: auto; }
  .section-heading { align-items: start; gap: 28px; }
  .service-row { grid-template-columns: 40px 1fr 28px; gap: 14px; padding-block: 26px; }
  .service-row p { grid-column: 2 / 4; margin: 0; }
  .operators-visual { min-height: 570px; }
  .technology-layout { gap: 50px; }
  .tech-panel { min-height: 410px; }
  .credentials-title { display: block; }
  .credentials-title p { margin-top: 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: span 2; }
  .footer-grid > div:last-child { grid-column: auto; }
}

@media (max-width: 560px) {
  body { font-size: 16px; }
  .section { padding-block: 84px; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .hero-visual { height: 430px; }
  .hero-fact { right: 0; bottom: 6%; }
  .trust-strip { display: block; }
  .intro-layout { grid-template-columns: 1fr; }
  .section-mark { display: none; }
  .principles { grid-column: auto; }
  .founders-heading, .founders { grid-column: auto; }
  .founder { grid-template-columns: 1fr; }
  .founder-photo { min-height: 430px; }
  .founder-copy { min-height: 430px; }
  .intro h2, .section-heading h2, .credentials h2, .contact h2, .operators h2, .technology h2 { font-size: clamp(2.8rem, 14vw, 4rem); }
  .service-row h3 { font-size: 1.7rem; }
  .operators-visual { min-height: 470px; }
  .photo-frame { right: 0; }
  .tech-specs { gap: 10px; }
  .tech-specs strong { font-size: 2rem; }
  .credentials-grid { grid-template-columns: 1fr; }
  .credential-ifpo { grid-column: auto; }
  .ifpo-logos { grid-template-columns: 1fr; gap: 8px; }
  .ifpo-logos img { height: 125px; }
  .credential { min-height: 260px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-brand { grid-column: auto; }
  .footer-bottom { align-items: flex-start; flex-direction: column; gap: 8px; }
  .legal-links { justify-content: flex-start; }
  .legal-header { align-items: flex-start; }
  .legal-header .text-link { margin-top: 12px; font-size: .82rem; }
  .legal-page { width: min(100% - 32px, 680px); }
  .legal-footer { flex-direction: column; }
  .whatsapp-float { width: 52px; height: 52px; right: 16px; bottom: 16px; }
}

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