
:root{
  --services-overlap: clamp(48px, 8vw, 140px);
  --content-gutter: clamp(24px, 5vw, 120px);
  --soft-blue-gradient: linear-gradient(180deg,
    rgba(220,232,255,0.72) 0%,
    rgba(220,232,255,0.45) 55%,
    rgba(255,255,255,0.18) 100%);
  --section-vertical: linear-gradient(180deg,
    rgba(220,232,255,0) 0%,
    rgba(220,232,255,0.22) 22%,
    rgba(220,232,255,0.5) 50%,
    rgba(220,232,255,0.38) 72%,
    rgba(255,255,255,0.14) 100%);
  --section-mask: linear-gradient(90deg,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 60%,
    rgba(0,0,0,0.4) 74%,
    rgba(0,0,0,0) 84%);
}

/* ===== HERO ===== */
.hero {
  position: relative;
  min-height: clamp(520px, 60vw, 760px);
  aspect-ratio: 3 / 2;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  overflow: hidden;
  background-color: #e9f0fb;
  z-index: 2;
  padding-bottom: clamp(200px, 20vw, 280px);
  --hero-scale: clamp(0.7, calc(100vw / 1920px), 1);
}

/* Keep headline content above overlap layers */
.hero .hero-inner,
.hero .hero-content,
.hero .hero-copy {
  position: relative;
  z-index: 2;
}

/* The actual photo */
.hero .hero-media{
  position:absolute;
  inset:0;
  z-index:1;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  pointer-events:none;
}

.hero picture{
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero .hero-media img{
  position: absolute;
  inset: 0;
  z-index: 1;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center bottom;
}

/* The left blue overlay gradient */
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: none;
  opacity: 0;
  z-index: 1;
}

/* Bottom wave overlay to blend hero into the next section */
.hero .hero-wave{
  position:absolute;
  left:0;
  right:0;
  bottom: calc(-1 * var(--services-overlap));
  height: calc(var(--services-overlap) + clamp(240px, 22vw, 340px));
  background: url("../assets/images/wave.png") 58% 88% / 150% auto no-repeat;
  opacity:0.84;
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.08) 45%, rgba(0,0,0,0.42) 72%, rgba(0,0,0,1) 100%);
  mask-image: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.08) 45%, rgba(0,0,0,0.42) 72%, rgba(0,0,0,1) 100%);
  z-index:2;
  pointer-events:none;
}

.hero .hero-inner {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: 1400px;
  margin-left: var(--content-gutter);
  margin-right: auto;
  width: calc(100% - var(--content-gutter));
  padding: clamp(56px, 8vw, 84px) clamp(22px, 4vw, 28px) clamp(180px, 18vw, 220px);
  display: grid;
  grid-template-columns: 1.4fr 0.6fr;
  gap: 24px;
}

.hero .hero-left {
  color: #fff;
  max-width: clamp(540px, 60vw, 900px);
  width: 100%;
}

.hero h1 {
  font-size: calc(clamp(32px, 3.8vw, 50px) * 1.0);
  line-height: 1.12;
  letter-spacing: -0.005em;
  margin: 0 0 clamp(10px, 1.6vw, 16px);
  text-shadow: 0 6px 14px rgba(15, 23, 42, 0.22);
}

.hero p.subhead,
.hero .hero-sub{
  font-size: calc(clamp(19px, 2vw, 23px) * 1.0);
  font-weight: 500;
  opacity: 0.98;
  margin: 0 0 clamp(10px, 1.4vw, 12px);
  text-shadow: 0 4px 12px rgba(15, 23, 42, 0.18);
}

.hero .hero-body{
  font-size: calc(clamp(18px, 1.8vw, 20px) * 1.0);
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.92);
  max-width: clamp(480px, 60vw, 900px);
  margin: 0 0 clamp(16px, 2vw, 22px);
}

.hero-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}

.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:clamp(9px, 1.1vw, 11px) clamp(18px, 2.2vw, 24px);
  border-radius:999px;
  background:#e7effb;
  color:#2f5aa8;
  text-decoration:none;
  font-weight:600;
  font-size:calc(clamp(10.5px, 1vw, 12px) * 1.0);
  letter-spacing:0.06em;
  text-transform:uppercase;
  box-shadow:0 8px 16px rgba(37, 99, 235, 0.18);
  border:1px solid rgba(47, 90, 168, 0.35);
}

.btn-primary:hover{
  background:#dbe7f7;
  border-color:rgba(47, 90, 168, 0.55);
}

.btn-primary:focus-visible{
  outline:3px solid rgba(255, 255, 255, 0.7);
  outline-offset:3px;
}

.hero .btn-primary,
.hero .btn-secondary{
  margin-top:0;
}

/* ===== SECTIONS ===== */
.section-inner{
  max-width:1180px;
  margin:0 auto;
  padding:72px 50px;
  position:relative;
  z-index:1;
}

.section-title{
  font-family:var(--font-display);
  font-size:clamp(26px,3vw,38px);
  color:#1f2b4a;
  text-align:center;
  margin-bottom:12px;
  letter-spacing:0.01em;
}

.section-lead{
  max-width:720px;
  margin:0 auto 36px;
  text-align:center;
  color:#4b5563;
  font-size:14px;
  line-height:1.6;
}

.services{
  position:relative;
  background: transparent;
  margin-top: calc(-1 * var(--services-overlap));
  z-index:3;
}

.services::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  top: 0;
  background: var(--section-vertical);
  -webkit-mask-image: var(--section-mask);
  mask-image: var(--section-mask);
  z-index:0;
  pointer-events:none;
}

.services .section-inner{
  padding-top: 0;
  padding-bottom: 0;
  z-index: 6;
  margin-left: var(--content-gutter);
  margin-right: auto;
  width: calc(100% - var(--content-gutter));
}

.services .section-title{
  text-align:left;
  font-size: calc(32px * var(--hero-scale));
}

.services .section-lead{
  text-align:left;
  margin-left:0;
  margin-right:auto;
  max-width:520px;
  font-size: calc(14px * var(--hero-scale));
}

.services .service-icon-grid{
  width:min(100%, 720px);
  margin-left:0;
  margin-right:auto;
}

.service-icon-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap: calc(24px * var(--hero-scale));
}

.service-icon-card{
  background: var(--soft-blue-gradient);
  border-radius: calc(20px * var(--hero-scale));
  padding: calc(22px * var(--hero-scale)) calc(18px * var(--hero-scale)) calc(25px * var(--hero-scale) + 10px);
  border:1px solid rgba(148,163,184,0.25);
  box-shadow:0 18px 40px rgba(15,23,42,0.08);
  text-align:center;
  min-height: calc(260px * var(--hero-scale));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
}

.icon-square{
  width: calc(84px * var(--hero-scale));
  height: calc(84px * var(--hero-scale));
  border-radius:0;
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  margin: calc(15px * var(--hero-scale)) auto calc(14px * var(--hero-scale));
  box-shadow:none;
  border:0;
}

.icon-square img{
  width: calc(150px * var(--hero-scale));
  height: calc(150px * var(--hero-scale));
  object-fit:contain;
}

.service-icon-card h3{
  font-family:var(--font-display);
  font-size: calc(20px * var(--hero-scale));
  color:#1b3f7a;
  margin-bottom: calc(8px * var(--hero-scale));
  margin-top:auto;
}

.service-icon-card p{
  font-size: calc(13px * var(--hero-scale));
  line-height:1.6;
  color:#1b3f7a;
}

.section-subtitle{
  font-family:var(--font-display);
  font-size:clamp(20px,2.4vw,28px);
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:#1f2b4a;
  margin-bottom:12px;
}

.section-subtitle.accent{
  text-transform:none;
  letter-spacing:0.02em;
  color:#2b4f8a;
}

.section-lead.section-lead-left{
  margin:0 0 24px;
  text-align:left;
  max-width:480px;
}

.audience .section-subtitle{
  font-size:clamp(30px,3.6vw,42px);
}

.audience .section-lead.section-lead-left{
  font-size:calc(14px * 1.5);
  /* Your secure future starts here. Calm, professional protection—built around clear planning, experienced personnel, and discreet execution. */
}

.audience{
  position:relative;
  background: #f3f7fd url("../assets/images/wave_clean.png") center/cover no-repeat;
}

.audience .section-inner{
  margin-left: var(--content-gutter);
  margin-right: auto;
  width: calc(100% - var(--content-gutter));
  max-width: none;
}

.audience::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--section-vertical);
  -webkit-mask-image: var(--section-mask);
  mask-image: var(--section-mask);
  z-index:0;
}

.audience-inner{
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:32px;
  align-items:start;
}

.audience-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  width:100%;
}

.audience-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
  color:#1f2b4a;
  font-size:calc(13px * 1.5);
  font-weight:500;
}

.audience-photo{
  width:clamp(154px, 14vw, 196px);
  height:clamp(154px, 14vw, 196px);
  border-radius:28px;
  object-fit:cover;
  background:#ffffff;
  box-shadow:0 12px 24px rgba(15,23,42,0.12);
  border:1px solid rgba(148,163,184,0.25);
  filter:none;
}

.apart-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:18px;
}

.apart-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.check-icon{
  width:20px;
  height:20px;
  margin-top:4px;
  background:url("../assets/icons/icon-check.svg") center/contain no-repeat;
  flex-shrink:0;
}

.apart-list h3{
  font-size:calc(15px * 1.5);
  color:#1f2b4a;
  margin-bottom:4px;
}

.apart-list p{
  font-size:calc(13px * 1.5);
  line-height:1.6;
  color:#475569;
}

/* Footer override (site_06 only): no wave background */
.site-footer{
  background-image:none;
  background-color:#162543;
}

/* Mobile */
@media (max-width: 760px){
  :root{
    --services-overlap: 120px;
  }
  .hero{ min-height: 560px; }
  .hero h1{ font-size: 40px; }
  .hero-left{ padding: 52px 0; }
  .hero-actions{ align-items:center; }
  .hero .btn-primary{ align-self:center; text-align:center; }
  .hero .hero-body{
    font-size: calc(clamp(18px, 1.8vw, 20px) * 01.1);
  }
  .hero .hero-wave{
    height: calc(var(--services-overlap) + 120px);
    bottom: calc(-1 * var(--services-overlap));
    background-size: 150% auto;
  }

  .section-inner{ padding:56px 20px; }
  .service-icon-grid{ grid-template-columns:1fr; }
  .audience-inner{ grid-template-columns:1fr; }
  .audience-left,
  .audience .section-subtitle,
  .audience .section-lead.section-lead-left{
    text-align:center;
    margin-left:auto;
    margin-right:auto;
  }
  .audience .section-lead.section-lead-left{
    max-width: 520px;
  }
  .audience-grid{ grid-template-columns:1fr; }
}

@media (max-width: 980px) and (min-width: 761px){
  .service-icon-grid{ grid-template-columns:1fr; }
  .audience-inner{ grid-template-columns:1fr; }
  .audience-left,
  .audience .section-subtitle,
  .audience .section-lead.section-lead-left{
    text-align:center;
    margin-left:auto;
    margin-right:auto;
  }
  .audience .section-lead.section-lead-left{
    max-width: 520px;
  }
  .audience-grid{ grid-template-columns:1fr; }
}

@media (max-width: 1024px){
  .hero{
    min-height: clamp(420px, 72vw, 600px);
    aspect-ratio: auto;
    --hero-scale: 1;
    padding-bottom: 0;
  }

  .hero .hero-body{
    font-size: calc(clamp(18px, 1.8vw, 20px) * 1.1);
  }

  .hero::after{
    background: linear-gradient(180deg,
      rgba(15, 32, 64, 0.78) 0%,
      rgba(15, 32, 64, 0.55) 45%,
      rgba(15, 32, 64, 0.28) 72%,
      rgba(15, 32, 64, 0.08) 100%);
    opacity: 1;
  }

  .hero .hero-media{
    align-items: flex-start;
  }

  .hero .hero-media img{
    filter: brightness(0.8) saturate(1.05);
    object-position: center top;
  }

  .hero .hero-inner{
    grid-template-columns: 1fr;
    padding: clamp(48px, 8vw, 64px) 24px clamp(48px, 8vw, 80px);
  }

  .hero .hero-left{
    max-width: 700px;
  }

  .hero-actions{
    width: 100%;
  }

  .services{
    position:static !important;
    margin-top: 24px;
    background: #f8fafc;
  }

  .services::before{
    background: none;
    opacity: 0;
  }

  .services .section-inner{
    padding-top: 24px;
    padding-bottom: 40px;
  }

  .service-icon-grid{
    gap:24px;
  }

  .service-icon-card{
    min-height: 260px;
    padding:22px 18px 35px;
    border-radius:20px;
  }

  .icon-square{
    width:84px;
    height:84px;
    margin:15px auto 14px;
  }

  .icon-square img{
    width:150px;
    height:150px;
  }

  .services .section-title{
    font-size:32px;
  }

  .services .section-lead{
    font-size:16px;
  }

  .audience-grid{
    grid-template-columns:1fr;
  }

  .audience .section-inner{
    margin-left: auto;
    margin-right: auto;
    width: 100%;
  }

  .service-icon-card h3{
    font-size:20px;
    margin-bottom:8px;
  }

  .service-icon-card p{
    font-size:13px;
  }
}

@media (max-width: 1400px) and (min-width: 1025px){
  .hero{
    min-height: clamp(520px, 60vw, 760px);
    aspect-ratio: 3 / 2;
    padding-bottom: clamp(200px, 20vw, 280px);
  }
}

@media (max-width: 1200px) and (min-width: 1025px){
  .hero{
    min-height: clamp(520px, 60vw, 760px);
    aspect-ratio: 3 / 2;
    padding-bottom: clamp(200px, 20vw, 280px);
  }
}
