:root {
  --ink: #0c1514;
  --muted: #667572;
  --line: #d8e4e0;
  --paper: #f6f8f5;
  --soft: #eaf3ee;
  --green: #006145;
  --green-dark: #022f29;
  --red: #df1f2d;
  --amber: #f6c14f;
  --white: #ffffff;
  --shadow: 0 26px 80px rgba(3, 28, 25, 0.22);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, Arial, sans-serif; color: var(--ink); background: linear-gradient(180deg, #f8faf6 0, var(--paper) 45%, #eef5f1 100%); }
a { color: inherit; text-decoration: none; }

.site-header {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 18px clamp(20px, 5vw, 72px);
  background: rgba(7, 31, 28, .92);
  border-bottom: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(18px);
}
.brand { display: inline-flex; align-items: center; gap: 12px; color: var(--white); font-weight: 800; }
.brand img { width: 42px; height: 42px; object-fit: cover; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; }
.nav-links { display: flex; align-items: center; gap: clamp(16px, 3vw, 34px); color: rgba(255,255,255,.68); font-weight: 700; }
.nav-links a:hover, .site-footer a:hover { color: var(--red); }
.menu-toggle { display: none; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.18); border-radius: 8px; background: rgba(255,255,255,.08); }
.menu-toggle span { display: block; width: 18px; height: 2px; margin: 4px auto; background: var(--white); }

.header-action, .primary-button, .secondary-button {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 46px; padding: 0 20px; border-radius: 8px; font-weight: 800;
  transition: transform 180ms ease, box-shadow 180ms ease;
}
.header-action, .primary-button { color: var(--white); background: var(--red); box-shadow: 0 14px 34px rgba(223,31,45,.28); }
.secondary-button { color: var(--white); border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.08); }
.header-action:hover, .primary-button:hover, .secondary-button:hover { transform: translateY(-2px); }

.hero {
  position: relative; display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr);
  align-items: center; min-height: calc(100vh - 80px); gap: clamp(34px, 7vw, 92px);
  padding: clamp(54px, 8vw, 112px) clamp(20px, 5vw, 72px) clamp(34px, 5vw, 70px);
  overflow: hidden; color: var(--white);
  background: radial-gradient(circle at 78% 18%, rgba(223,31,45,.32), transparent 29%), radial-gradient(circle at 12% 28%, rgba(0,97,69,.46), transparent 32%), linear-gradient(135deg, #061a17 0%, #0a2924 48%, #031210 100%);
}
.hero::before { position: absolute; inset: 80px 0 0; pointer-events: none; content: ""; background: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px); background-size: 56px 56px; mask-image: linear-gradient(180deg, rgba(0,0,0,.82), transparent 82%); }
.hero-copy { position: relative; z-index: 1; max-width: 780px; }
.eyebrow { margin: 0 0 14px; color: var(--red); font-size: .78rem; font-weight: 800; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 20px; color: var(--white); font-size: clamp(3.35rem, 9vw, 8rem); line-height: .9; }
h2 { max-width: 880px; margin-bottom: 0; font-size: clamp(2rem, 4.4vw, 4.4rem); line-height: 1; }
h3 { margin-bottom: 14px; font-size: 1.3rem; line-height: 1.12; }
.lead { max-width: 710px; margin-bottom: 32px; color: rgba(255,255,255,.76); font-size: clamp(1.1rem, 2vw, 1.38rem); line-height: 1.55; }
.hero-actions, .hero-kpis { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-kpis { margin-top: 30px; gap: 10px; }
.hero-kpis span { display: inline-flex; align-items: center; min-height: 38px; padding: 0 14px; border: 1px solid rgba(255,255,255,.14); border-radius: 999px; color: rgba(255,255,255,.82); background: rgba(255,255,255,.07); font-size: .88rem; font-weight: 800; }
.hero-visual { position: relative; display: grid; min-height: 540px; place-items: center; isolation: isolate; }
.hero-visual::before { position: absolute; inset: 1% 4% 3% 11%; z-index: -1; content: ""; border: 1px solid rgba(255,255,255,.13); border-radius: 28px; background: linear-gradient(135deg, rgba(255,255,255,.09), rgba(223,31,45,.2)), repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 1px, transparent 1px 18px); transform: skewY(-4deg); }
.hero-visual img { width: min(78vw, 430px); aspect-ratio: 1; object-fit: cover; border: 12px solid rgba(255,255,255,.08); border-radius: 50%; box-shadow: var(--shadow); }
.visual-stat { position: absolute; right: 8px; bottom: 16px; width: min(310px, 78%); padding: 18px; color: var(--white); border: 1px solid rgba(255,255,255,.16); border-radius: 18px; background: rgba(3,18,16,.88); backdrop-filter: blur(14px); box-shadow: var(--shadow); }
.visual-stat strong, .visual-stat span { display: block; }
.visual-stat span { margin-top: 8px; color: rgba(255,255,255,.78); line-height: 1.45; }

.trust-strip { display: flex; flex-wrap: wrap; gap: 12px; padding: 18px clamp(20px, 5vw, 72px); border-bottom: 1px solid var(--line); background: #f1f6f2; }
.trust-strip span { display: inline-flex; align-items: center; min-height: 44px; padding: 0 18px; border: 1px solid rgba(0,97,69,.14); border-radius: 999px; color: var(--green-dark); background: var(--white); font-weight: 800; }
.section { padding: clamp(70px, 10vw, 132px) clamp(20px, 5vw, 72px); background: linear-gradient(90deg, rgba(0,97,69,.05) 0 1px, transparent 1px 100%), var(--paper); background-size: 84px 100%; }
.section-heading { display: grid; grid-template-columns: .34fr 1fr; gap: 30px; margin-bottom: clamp(34px, 6vw, 66px); }
.service-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.service-card { position: relative; min-height: 248px; padding: clamp(24px, 3vw, 38px); overflow: hidden; border: 1px solid rgba(0,97,69,.13); border-radius: 22px; background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(236,246,240,.92)); box-shadow: 0 18px 54px rgba(16,25,24,.07); }
.service-card::after { position: absolute; right: -34px; top: -34px; width: 120px; height: 120px; content: ""; border: 18px solid rgba(223,31,45,.1); border-radius: 50%; }
.service-card:nth-child(even) { transform: translateY(34px); }
.service-card span { display: inline-flex; margin-bottom: 44px; color: var(--red); font-weight: 800; }
.service-card p, .work-band p, .process-list p { color: var(--muted); line-height: 1.65; }

.work-band { display: grid; grid-template-columns: minmax(320px, .68fr) minmax(0, .92fr); gap: clamp(34px, 6vw, 82px); align-items: center; padding: clamp(70px, 10vw, 126px) clamp(20px, 5vw, 72px); color: var(--white); background: radial-gradient(circle at 15% 15%, rgba(223,31,45,.28), transparent 30%), linear-gradient(135deg, #061a17, #0b312a 56%, #041412); }
.work-band .eyebrow { color: var(--amber); }
.work-band p { margin-top: 24px; color: rgba(255,255,255,.76); font-size: 1.08rem; }
.process-list { display: grid; gap: 14px; }
.process-list div { display: grid; grid-template-columns: 54px 1fr; gap: 18px; padding: 22px; border: 1px solid rgba(255,255,255,.14); border-left: 4px solid var(--red); border-radius: 16px; background: rgba(255,255,255,.07); }
.process-list span { color: var(--amber); font-weight: 800; }
.contact-section { display: grid; grid-template-columns: minmax(0, .9fr) minmax(300px, .5fr); gap: 34px; align-items: end; padding: clamp(70px, 10vw, 122px) clamp(20px, 5vw, 72px); background: linear-gradient(135deg, rgba(255,255,255,.7), rgba(234,243,238,.94)), linear-gradient(90deg, rgba(223,31,45,.1), transparent 34%); }
.contact-actions { display: grid; gap: 12px; }
.contact-actions a { display: flex; align-items: center; justify-content: space-between; min-height: 58px; padding: 0 18px; overflow-wrap: anywhere; border: 1px solid rgba(0,97,69,.16); border-radius: 14px; color: var(--green); background: rgba(255,255,255,.74); font-weight: 800; }
.contact-actions a::after { content: "->"; margin-left: 12px; color: var(--red); }
.site-footer { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 24px clamp(20px, 5vw, 72px); color: rgba(255,255,255,.66); background: #071f1c; font-size: .9rem; }
.footer-links { display: inline-flex; align-items: center; flex-wrap: wrap; justify-content: flex-end; gap: 12px; }
.social-icon { display: inline-grid; width: 40px; height: 40px; place-items: center; border: 1px solid rgba(255,255,255,.14); border-radius: 50%; color: var(--white); background: rgba(255,255,255,.08); }
.social-icon svg { width: 19px; height: 19px; }

@media (max-width: 960px) {
  .site-header { flex-wrap: wrap; }
  .menu-toggle { display: block; }
  .nav-links { display: none; order: 4; width: 100%; flex-direction: column; align-items: flex-start; }
  .site-header.menu-open .nav-links { display: flex; }
  .hero, .work-band, .contact-section, .section-heading { grid-template-columns: 1fr; }
  .service-card:nth-child(even) { transform: none; }
}
@media (max-width: 620px) {
  .header-action, .hero-actions, .primary-button, .secondary-button { width: 100%; }
  h1 { font-size: clamp(3rem, 17vw, 4.6rem); }
  .hero-kpis span { width: 100%; justify-content: center; }
  .hero-visual { min-height: 360px; }
  .visual-stat { position: relative; right: auto; bottom: auto; width: 100%; margin-top: 16px; }
  .service-grid { grid-template-columns: 1fr; }
  .site-footer { flex-direction: column; align-items: flex-start; }
  .footer-links { justify-content: flex-start; }
}
