﻿:root{
  --home-blue:#082b5b;
  --home-dark:#061b42;
  --home-green:#49a532;
  --home-soft:#f3f4f6;
  --home-line:#e5e7eb;
}

body{
  background:var(--home-soft);
}

.hero{
  min-height:720px;
  padding-bottom:0;
  background:
    radial-gradient(ellipse 42% 40% at 21% 24%,rgba(255,255,255,.95) 0%,rgba(255,255,255,.82) 42%,rgba(255,255,255,.28) 62%,rgba(255,255,255,0) 78%),
    linear-gradient(90deg,rgba(255,255,255,.94) 0%,rgba(255,255,255,.82) 22%,rgba(255,255,255,.22) 39%,rgba(255,255,255,0) 52%),
    url('hero.webp') center center/cover no-repeat;
}

.hero-content{
  max-width:900px;
  padding-top:46px;
  padding-bottom:0;
}

.hero h1{
  margin:0 0 30px;
  color:var(--home-blue);
  font-size:55px;
  line-height:1.05;
  letter-spacing:0;
}

.hero h1 span{
  color:var(--home-green);
}

.hero-sub{
  margin:0;
  color:var(--home-blue);
  font-size:32px;
  line-height:1.05;
  font-weight:900;
}

.hero .lead{
  margin-top:24px;
  max-width:560px;
}

.hero .checks{
  margin-top:28px;
}


.buttons{
  margin-top:34px;
}

.hero .buttons .btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-sizing:border-box!important;
  min-width:0!important;
  min-height:0!important;
  border:0!important;
  padding:11px 20px!important;
  font-size:14px!important;
  line-height:1!important;
  border-radius:999px!important;
}

.desktop-title{
  display:inline;
}

.desktop-break{
  display:block;
}

.mobile-title{
  display:none;
}

.cards .grid4{
  align-items:stretch;
}

.service-intro{
  margin-bottom:24px;
}

.service-intro h2{
  margin:0;
  color:var(--home-blue);
  font-size:26px;
  line-height:1.05;
  text-transform:uppercase;
}

.service-intro p{
  max-width:560px;
  margin:12px 0 0;
  color:#475569;
  font-size:16px;
  line-height:1.6;
}

.cards .card{
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
  overflow:hidden;
  padding:0 0 26px;
  text-align:left;
  text-decoration:none;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.cards .card:hover,
.cards .card:focus-visible{
  transform:translateY(-5px);
  border-color:rgba(73,165,50,.45);
  box-shadow:0 18px 42px rgba(2,8,23,.14);
}

.cards .card img{
  width:100%;
  height:154px;
  margin:0 0 18px;
  object-fit:cover;
  display:block;
  border-radius:0;
  transform:scale(1.01);
  transition:transform .28s ease;
}

.cards .card:hover img,
.cards .card:focus-visible img{
  transform:scale(1.055);
}

.cards .card h3,
.cards .card p,
.card-proof{
  padding:0 22px;
}

.cards .card h3{
  margin:0 0 8px;
}

.cards .card p{
  margin:0 0 16px;
}

.card-proof{
  display:flex;
  align-items:center;
  gap:7px;
  margin-top:auto;
  padding-top:16px;
  color:#256f1c;
  font-size:13px;
  line-height:1.2;
  font-weight:800;
}

.card-proof:before{
  content:"✓";
  display:inline-grid;
  place-items:center;
  width:20px;
  height:20px;
  flex:0 0 20px;
  border-radius:50%;
  background:#e1f2da;
  color:var(--home-green);
  font-size:13px;
  font-weight:900;
}

.home-proof-section{
  padding:46px 20px 0;
  background:
    linear-gradient(180deg,#fff 0%,var(--home-soft) 100%);
}

.home-proof-wrap{
  display:grid;
  grid-template-columns:.95fr 1.25fr;
  gap:34px;
  align-items:stretch;
  max-width:1120px;
  margin:0 auto;
  padding:34px;
  border:1px solid rgba(8,43,91,.1);
  border-radius:10px;
  background:#fff;
  box-shadow:0 14px 34px rgba(2,8,23,.08);
}

.proof-kicker{
  display:inline-flex;
  margin-bottom:14px;
  color:var(--home-green);
  font-size:13px;
  line-height:1.1;
  font-weight:900;
  text-transform:uppercase;
}

.home-proof-intro h2{
  margin:0;
  max-width:480px;
  color:var(--home-blue);
  font-size:26px;
  line-height:1.05;
  text-transform:uppercase;
}

.home-proof-intro p{
  margin:18px 0 0;
  max-width:520px;
  color:#223b63;
  font-size:16px;
  line-height:1.6;
}

.home-proof-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.home-proof-item{
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding:20px 18px;
  border:1px solid rgba(8,43,91,.09);
  border-radius:10px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.home-proof-item span{
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  margin-bottom:14px;
  border-radius:50%;
  background:#e1f2da;
  color:var(--home-green);
  font-weight:900;
}

.home-proof-item strong{
  color:var(--home-blue);
  font-size:17px;
  line-height:1.15;
}

.home-proof-item p{
  margin:9px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.45;
}

.contactbar{
  display:none;
}

.about-me-section,
.process-section{
  background:var(--home-soft);
}

.about-me-section{
  padding:40px 2px 40px 20px;
}

.process-section{
  padding:40px 20px 40px 2px;
}

@media (min-width:1100px){
  .about-me-section,
  .process-section{
    display:inline-block;
    width:calc(50% - 4px);
    vertical-align:top;
  }
}

.about-me-container,
.process-card,
.region-card{
  max-width:1400px;
  margin:0 auto;
  border-radius:28px;
  background:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.about-me-container{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:20px;
  align-items:start;
  min-height:560px;
  overflow:hidden;
  padding:22px 24px;
}

.about-eyebrow,
.section-title{
  display:block;
  color:var(--home-blue);
  font-size:26px;
  line-height:1.05;
  font-weight:700;
  text-transform:uppercase;
}

.about-divider,
.region-divider{
  width:70px;
  height:4px;
  margin:14px 0 28px;
  border-radius:2px;
  background:var(--home-green);
}

.about-me-content p,
.section-text{
  color:#223b63;
  font-size:16px;
  line-height:1.6;
}

.about-signature{
  margin:20px 0 26px;
  color:var(--home-green);
  font-family:"Segoe Script","Brush Script MT",cursive;
  font-size:32px;
  line-height:1;
  font-weight:700;
}

.about-button{
  display:inline-block;
  border-radius:999px;
  background:var(--home-green);
  color:#fff;
  padding:18px 36px;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(76,175,51,.25);
}

.about-me-image{
  align-self:end;
  text-align:right;
}

.about-me-image img{
  width:auto;
  max-width:100%;
  max-height:900px;
  object-fit:cover;
  transform:scale(1.65) translateY(-18px);
  transform-origin:bottom center;
}

.process-card{
  min-height:560px;
  padding:22px 24px;
}

.process-card h2{
  margin:0 0 40px;
}

.process-list{
  position:relative;
}

.process-list:before{
  content:"";
  position:absolute;
  left:22px;
  top:10px;
  bottom:10px;
  width:3px;
  background:var(--home-line);
}

.process-step{
  position:relative;
  display:grid;
  grid-template-columns:44px 64px 1fr;
  gap:22px;
  align-items:start;
  margin-bottom:34px;
}

.process-step:last-child{
  margin-bottom:0;
}

.process-number{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--home-green);
  color:#fff;
  font-size:20px;
  font-weight:800;
}

.process-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:64px;
  height:64px;
  color:var(--home-green);
}

.process-icon svg{
  width:42px;
  height:42px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.process-content h3{
  margin:8px 0 6px;
  color:#222;
  font-size:17px;
  line-height:1.15;
}

.process-content p{
  margin:0;
  color:#444;
}

.region-section{
  padding:0 20px 42px;
  background:var(--home-soft);
}

.region-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  overflow:hidden;
}

.region-content{
  padding:34px 50px 55px;
}

.region-content h2{
  margin:0;
}

.region-list{
  margin:24px 0 28px;
  padding:0;
  list-style:none;
}

.region-list li{
  display:flex;
  gap:12px;
  align-items:center;
  margin:12px 0;
  color:#223b63;
}

.region-check{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  border-radius:50%;
  background:#e1f2da;
  color:var(--home-green);
  font-weight:900;
}

.region-map{
  position:relative;
  min-height:520px;
  overflow:hidden;
  background:
    radial-gradient(circle at 70% 55%,rgba(76,175,51,.12) 0,rgba(76,175,51,.12) 120px,rgba(76,175,51,.06) 120px,rgba(76,175,51,.06) 220px,transparent 220px),
    linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px),
    linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),
    #fafafa;
  background-size:auto,40px 40px,40px 40px,auto;
}

.region-map img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.28;
  filter:saturate(.85) contrast(1.05);
}

.region-pin{
  position:absolute;
  left:70%;
  top:55%;
  width:72px;
  height:72px;
  border-radius:50% 50% 50% 0;
  background:var(--home-green);
  box-shadow:0 12px 24px rgba(76,175,51,.25);
  transform:translate(-50%,-50%) rotate(-45deg);
}

.region-pin:after{
  content:"";
  position:absolute;
  top:24px;
  left:24px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:#fff;
}

.final-cta{
  padding:0 20px;
  background:var(--home-soft);
}

.final-cta-wrap{
  max-width:1400px;
  margin:0 auto;
  overflow:hidden;
  border-radius:20px 20px 0 0;
  background:linear-gradient(135deg,var(--home-dark),#0a2d63);
  color:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.final-cta-top{
  display:grid;
  grid-template-columns:1.2fr auto;
  gap:24px;
  align-items:center;
  padding:34px 42px;
  border-bottom:1px solid rgba(255,255,255,.15);
}

.final-cta-top h2{
  margin:0;
  font-size:26px;
  line-height:1.08;
}

.final-cta-top h2 span{
  color:#63c53d;
}

.final-cta-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  justify-content:flex-end;
}

.final-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  border-radius:999px;
  padding:0 24px;
  font-weight:800;
}

.final-btn-green{
  background:var(--home-green);
  color:#fff;
}

.final-btn-outline{
  border:1px solid rgba(255,255,255,.6);
  color:#fff;
}

.final-contact-bar{
  display:grid;
  grid-template-columns:1.3fr repeat(3,auto);
  gap:22px;
  align-items:center;
  padding:22px 42px;
}

.final-contact-bar a,
.final-contact-bar span{
  color:#fff;
  font-size:14px;
  line-height:1.35;
  font-weight:700;
}

.area-text{
  display:flex;
  gap:8px;
  align-items:flex-start;
}

@media (max-width:1099px){
  .about-me-section,
  .process-section{
    display:block;
    width:auto;
    padding:40px 20px;
  }

  .about-me-container,
  .process-card{
    height:auto !important;
  }

  .about-me-container,
  .region-card,
  .final-cta-top{
    grid-template-columns:1fr;
  }

  .about-me-image{
    text-align:center;
  }

  .about-me-image img{
    max-height:520px;
    transform:none;
  }

  .region-map{
    min-height:360px;
  }

  .final-cta-buttons{
    justify-content:flex-start;
  }

  .final-contact-bar{
    grid-template-columns:1fr;
    text-align:left;
  }
}

@media (max-width:700px){
  .hero{
    min-height:auto;
    padding:0;
    background:#fff;
  }

  .hero:before{
    content:"";
    display:block;
    width:100%;
    aspect-ratio:3/2;
    background:url('hero.webp') center top/contain no-repeat #f7fbff;
  }

  .hero-content{
    max-width:100%;
    margin-top:0;
    padding:28px 0 40px;
    background:linear-gradient(180deg,rgba(255,255,255,.96),#fff 42%);
  }

  .hero h1{
    font-size:22px;
    line-height:.92;
  }

  .hero-sub{
    font-size:16px;
    line-height:1.08;
  }

  .hero .lead,
  .hero .checks li{
    font-size:14px;
  }

  .hero .lead{
    margin-top:12px;
  }

  .hero .checks{
    margin-top:26px;
  }

  

  .buttons{
    gap:10px;
    margin-top:24px;
  }

  .hero .buttons .btn{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    box-sizing:border-box!important;
    min-width:0!important;
    min-height:0!important;
    border:0!important;
    padding:9px 14px !important;
    font-size:12px !important;
    line-height:1.35!important;
    border-radius:999px!important;
  }

  .cards{
    margin-top:0;
    padding-top:18px;
  }

  .cards .grid4{
    grid-auto-rows:1fr;
  }

  .service-intro{
    margin-bottom:16px;
  }

  .service-intro h2{
    font-size:17px;
    line-height:1.15;
  }

  .service-intro p{
    margin-top:8px;
    font-size:14px;
    line-height:1.45;
  }

  .cards .card{
    padding-bottom:14px;
  }

  .cards .card img{
    height:86px;
    margin-bottom:10px;
  }

  .cards .card h3,
  .cards .card p,
  .card-proof{
    padding:0 10px;
  }

  .card-proof{
    gap:5px;
    padding-top:10px;
    font-size:11px;
  }

  .card-proof:before{
    width:17px;
    height:17px;
    flex-basis:17px;
    font-size:11px;
  }

  .home-proof-section{
    padding:24px 12px 0;
  }

  .home-proof-wrap{
    grid-template-columns:1fr;
    gap:18px;
    padding:20px 16px;
  }

  .home-proof-intro h2{
    font-size:17px;
    line-height:1.15;
  }

  .home-proof-intro p{
    margin-top:12px;
    font-size:14px;
    line-height:1.45;
  }

  .home-proof-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .home-proof-item{
    padding:16px 14px;
  }

  .home-proof-item strong{
    font-size:15px;
  }

  .about-me-section,
  .process-section{
    padding:32px 12px;
  }

  .about-me-container,
  .process-card{
    border-radius:16px;
    padding:20px 16px;
  }

  .about-eyebrow,
  .section-title,
  .region-content h2,
  .final-cta-top h2{
    font-size:17px;
    line-height:1.15;
  }

  .about-divider,
  .region-divider{
    width:50px;
    height:3px;
    margin:10px 0 16px;
  }

  .about-me-content p,
  .section-text,
  .process-content p,
  .region-list li{
    font-size:14px;
    line-height:1.35;
  }

  .about-signature{
    margin:10px 0 2px;
    font-size:22px;
  }

  .about-me-image img{
    max-height:280px;
  }

  .process-section{
    padding-top:0;
  }

  .process-card h2{
    margin-bottom:0;
  }

  .process-list:before{
    left:16px;
  }

  .process-step{
    grid-template-columns:32px 38px 1fr;
    gap:10px;
    margin-bottom:18px;
  }

  .process-number{
    width:32px;
    height:32px;
    font-size:14px;
  }

  .process-icon{
    width:38px;
    height:38px;
  }

  .process-icon svg{
    width:26px;
    height:26px;
  }

  .process-content h3{
    margin:4px 0;
    font-size:17px;
    line-height:1.15;
  }

  .region-section,
  .final-cta{
    padding-left:12px;
    padding-right:12px;
  }

  .region-card,
  .final-cta-wrap{
    border-radius:16px;
  }

  .region-content,
  .final-cta-top,
  .final-contact-bar{
    padding:20px 16px;
  }

  .region-list{
    margin:14px 0 18px;
  }

  .region-check{
    width:20px;
    height:20px;
    font-size:13px;
  }

  .region-map{
    min-height:260px;
  }

  .region-pin{
    width:44px;
    height:44px;
  }

  .region-pin:after{
    top:15px;
    left:15px;
    width:14px;
    height:14px;
  }

  .final-cta-top{
    gap:16px;
  }

  .final-btn{
    min-height:auto;
    padding:9px 14px;
    font-size:12px;
  }

  .final-contact-bar{
    gap:10px;
  }

  .final-contact-bar a,
  .final-contact-bar span{
    font-size:14px;
  }

  .desktop-title{
    display:none;
  }

  .desktop-break{
    display:none;
  }

  .mobile-title{
    display:inline;
  }
}

.buttons{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:14px;
}

.cards{
  margin-top:0;
  padding:34px 0;
  background:#fff;
  border-top:1px solid var(--home-line);
  border-bottom:1px solid var(--home-line);
}

.card,
.about-me-container,
.process-card,
.region-card,
.final-cta-wrap{
  border-radius:10px;
}

.card{
  box-shadow:0 10px 24px rgba(2,8,23,.08);
}

.about-me-section,
.process-section,
.region-section{
  padding-top:46px;
  padding-bottom:54px;
}

.final-cta{
  padding-top:0;
}

.final-cta-wrap{
  max-width:1120px;
}

@media (max-width:700px){
  .hero-content{
    padding-top:28px;
  }

  .cards,
  .about-me-section,
  .process-section,
  .region-section{
    padding-top:24px;
    padding-bottom:24px;
  }

  .cards{
    margin-top:0;
  }

  .card,
  .about-me-container,
  .process-card,
  .region-card,
  .final-cta-wrap{
    border-radius:10px;
  }
}

.home-workflow-section{
  padding:54px 20px;
  background:var(--home-soft);
}

.home-workflow-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:22px;
  max-width:1120px;
  margin:0 auto;
  align-items:stretch;
}

.home-workflow-section .about-me-container,
.home-workflow-section .process-card{
  width:auto;
  max-width:none;
  min-height:0;
  height:100%;
  margin:0;
  border:1px solid rgba(8,43,91,.1);
  border-radius:10px;
  background:#fff;
  box-shadow:0 14px 34px rgba(2,8,23,.08);
}

.home-workflow-section .about-me-container{
  display:grid;
  grid-template-columns:1.1fr .78fr;
  gap:24px;
  align-items:stretch;
  overflow:hidden;
  padding:0;
}

.home-workflow-section .about-me-content{
  padding:34px 0 34px 34px;
}

.home-workflow-section .about-me-content h2,
.process-head h2{
  margin:0;
  color:var(--home-blue);
  font-size:26px;
  line-height:1.05;
  text-transform:uppercase;
}

.story-lead,
.process-head p{
  margin:18px 0 0;
  color:#223b63;
  font-size:16px;
  line-height:1.6;
}

.about-trust-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}

.about-trust-list span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:9px 12px;
  border:1px solid rgba(73,165,50,.18);
  border-radius:999px;
  background:#f3fbef;
  color:#256f1c;
  font-size:13px;
  line-height:1.1;
  font-weight:800;
}

.about-trust-list span:before{
  content:"✓";
  color:var(--home-green);
  font-weight:900;
}

.home-workflow-section .about-signature{
  margin:28px 0 0;
}

.home-workflow-section .about-me-image{
  position:relative;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  min-height:100%;
  overflow:hidden;
  background:
    radial-gradient(circle at 62% 22%,rgba(73,165,50,.18),transparent 34%),
    linear-gradient(145deg,#eef7ff,#f8fafc);
}

.home-workflow-section .about-me-image img{
  width:300%;
  height:auto;
  max-width:none;
  max-height:none;
  object-fit:contain;
  object-position:center bottom;
  transform:translateY(-12px);
}

.about-image-badge{
  position:absolute;
  left:18px;
  bottom:18px;
  padding:10px 13px;
  border:1px solid rgba(255,255,255,.75);
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:var(--home-blue);
  font-size:13px;
  line-height:1;
  font-weight:900;
  box-shadow:0 10px 24px rgba(2,8,23,.12);
}

.home-workflow-section .process-card{
  padding:34px;
}

.process-head{
  margin-bottom:22px;
}

.home-workflow-section .process-list{
  display:grid;
  gap:12px;
}

.home-workflow-section .process-list:before{
  display:none;
}

.home-workflow-section .process-step{
  display:grid;
  grid-template-columns:50px 1fr;
  gap:16px;
  align-items:start;
  margin:0;
  padding:16px;
  border:1px solid rgba(8,43,91,.09);
  border-radius:10px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.home-workflow-section .process-number{
  width:50px;
  height:50px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--home-blue),#0b3f82);
  color:#fff;
  font-size:15px;
  line-height:1;
}

.home-workflow-section .process-icon{
  display:none;
}

.home-workflow-section .process-content h3{
  margin:1px 0 6px;
  color:var(--home-blue);
  font-size:17px;
  line-height:1.15;
}

.home-workflow-section .process-content p{
  color:#475569;
  font-size:14px!important;
  line-height:1.45!important;
}

@media (max-width:1099px){
  .home-workflow-grid{
    grid-template-columns:1fr;
  }

  .home-workflow-section .about-me-container{
    grid-template-columns:1fr .65fr;
  }
}

@media (max-width:700px){
  .home-workflow-section{
    padding:24px 12px;
  }

  .home-workflow-grid{
    gap:14px;
  }

  .home-workflow-section .about-me-container{
    grid-template-columns:1fr;
  }

  .home-workflow-section .about-me-content,
  .home-workflow-section .process-card{
    padding:20px 16px;
  }

  .home-workflow-section .about-me-content h2,
  .process-head h2{
    font-size:17px;
    line-height:1.15;
  }

  .story-lead,
  .process-head p{
    margin-top:12px;
    font-size:14px;
    line-height:1.45;
  }

  .about-trust-list{
    gap:8px;
    margin-top:18px;
  }

  .about-trust-list span{
    padding:8px 10px;
    font-size:12px;
  }

  .home-workflow-section .about-signature{
    margin-top:18px;
  }

  .home-workflow-section .about-me-image{
    min-height:260px;
  }

  .home-workflow-section .about-me-image img{
    width:100%;
    transform:none;
  }

  .home-workflow-section .process-step{
    grid-template-columns:42px 1fr;
    gap:12px;
    padding:14px;
  }

  .home-workflow-section .process-number{
    width:42px;
    height:42px;
    border-radius:12px;
    font-size:13px;
  }

.home-workflow-section .process-content h3{
    font-size:15px;
  }
}

.region-section{
  padding:0 20px 54px;
}

.region-card{
  max-width:1120px;
  border:1px solid rgba(8,43,91,.1);
  border-radius:10px;
  box-shadow:0 14px 34px rgba(2,8,23,.08);
}

.region-content{
  padding:42px 44px;
}

.region-content h2{
  max-width:430px;
  margin:0;
  font-size:26px;
  line-height:1.05;
}

.region-lead{
  max-width:520px;
  margin:18px 0 0;
  color:#223b63;
  font-size:16px;
  line-height:1.6;
}

.region-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}

.region-tags span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:9px 12px;
  border:1px solid rgba(73,165,50,.18);
  border-radius:999px;
  background:#f3fbef;
  color:#256f1c;
  font-size:13px;
  line-height:1.1;
  font-weight:800;
}

.region-tags span:before{
  content:"✓";
  color:var(--home-green);
  font-weight:900;
}

.region-note{
  margin-top:26px;
  padding:18px;
  border:1px solid rgba(8,43,91,.09);
  border-left:4px solid var(--home-green);
  border-radius:10px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.region-note strong{
  display:block;
  color:var(--home-blue);
  font-size:17px;
  line-height:1.15;
}

.region-note p{
  margin:8px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.45;
}

.region-map{
  min-height:430px;
  background:
    radial-gradient(circle at 69% 58%,rgba(73,165,50,.2) 0,rgba(73,165,50,.2) 96px,rgba(73,165,50,.08) 96px,rgba(73,165,50,.08) 190px,transparent 190px),
    linear-gradient(135deg,#eef7ff,#f8fafc);
}

.region-map:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(8,43,91,.1));
  pointer-events:none;
}

.region-map img{
  opacity:.48;
  filter:saturate(.95) contrast(1.08);
}

.region-pin{
  z-index:1;
  left:69%;
  top:58%;
  width:64px;
  height:64px;
  box-shadow:0 18px 34px rgba(73,165,50,.35);
}

.region-pin:before{
  content:"";
  position:absolute;
  inset:-14px;
  border:2px solid rgba(73,165,50,.25);
  border-radius:50% 50% 50% 0;
}

.region-pin:after{
  top:21px;
  left:21px;
  width:22px;
  height:22px;
}

.region-map-panel{
  position:absolute;
  z-index:2;
  left:24px;
  bottom:24px;
  max-width:260px;
  padding:15px 17px;
  border:1px solid rgba(255,255,255,.75);
  border-radius:10px;
  background:rgba(255,255,255,.9);
  box-shadow:0 12px 28px rgba(2,8,23,.14);
}

.region-map-panel span{
  display:block;
  color:var(--home-green);
  font-size:12px;
  line-height:1.1;
  font-weight:900;
  text-transform:uppercase;
}

.region-map-panel strong{
  display:block;
  margin-top:6px;
  color:var(--home-blue);
  font-size:16px;
  line-height:1.2;
}

@media (max-width:700px){
  .region-section{
    padding:24px 12px;
  }

  .region-content{
    padding:20px 16px;
  }

  .region-content h2{
    font-size:17px;
    line-height:1.15;
  }

  .region-lead{
    margin-top:12px;
    font-size:14px;
    line-height:1.45;
  }

  .region-tags{
    gap:8px;
    margin-top:18px;
  }

  .region-tags span{
    padding:8px 10px;
    font-size:12px;
  }

  .region-note{
    margin-top:18px;
    padding:14px;
  }

  .region-note strong{
    font-size:15px;
  }

  .region-map{
    min-height:280px;
  }

  .region-map-panel{
    left:14px;
    right:14px;
    bottom:14px;
    max-width:none;
  }
}

.final-cta-top{
  grid-template-columns:1fr;
  align-items:stretch;
  justify-items:center;
  text-align:center;
}

.final-cta-copy span{
  display:block;
  color:#63c53d;
  font-size:12px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
}

.final-cta-copy h2{
  margin:10px 0 12px;
}

.final-cta-copy h2 strong{
  color:#63c53d;
  font:inherit;
}

.final-cta-copy p{
  max-width:680px;
  margin:0;
  color:rgba(255,255,255,.86);
  font-size:16px;
  line-height:1.6;
}

.home-final-contact-card{
  width:100%!important;
  max-width:760px!important;
  margin:8px auto 0!important;
  background:linear-gradient(180deg,#fff,#f8fbfd)!important;
  text-align:left!important;
}

.home-final-contact-stack{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}

.home-final-contact-stack a{
  position:relative;
  overflow:hidden;
  display:grid;
  place-items:center;
  min-height:64px;
  padding:10px;
  border-radius:12px;
  color:#fff;
  text-align:center;
  font-size:13px;
  font-weight:900;
  text-decoration:none;
  box-shadow:0 10px 22px rgba(2,8,23,.12);
}

.home-final-contact-stack a:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.18),transparent);
  transform:translateX(-130%);
  transition:transform .45s ease;
}

.home-final-contact-stack a:hover:after,
.home-final-contact-stack a:focus-visible:after{
  transform:translateX(130%);
}

.home-final-contact-stack span{
  position:relative;
  z-index:1;
  display:grid;
  gap:3px;
}

.home-final-contact-stack small{
  color:rgba(255,255,255,.86);
  font-size:12px;
  line-height:1.25;
  font-weight:800;
}

.home-final-contact-stack .whatsapp{
  background:#3c8f2a;
}

.home-final-contact-stack .phone{
  background:#061b42;
}

.home-final-contact-stack .mail{
  background:#d5a000;
}

@media (max-width:700px){
  .final-cta-top{
    grid-template-columns:1fr;
  }

  .final-cta-copy p{
    font-size:14px;
    line-height:1.45;
  }

  .home-final-contact-card{
    padding:14px!important;
  }

  .home-final-contact-stack{
    grid-template-columns:1fr;
  }
}

.cards{
  background:linear-gradient(180deg,#fff 0%,#f7fafc 100%)!important;
}

.cards .card{
  border:1px solid rgba(8,43,91,.1)!important;
  border-radius:10px!important;
  background:#fff!important;
  box-shadow:0 18px 38px rgba(2,8,23,.08)!important;
}

.cards .card:hover,
.cards .card:focus-visible{
  box-shadow:0 24px 52px rgba(2,8,23,.13)!important;
}

.card-proof{
  min-height:36px;
  align-items:center;
  margin:0 22px;
  padding:12px 0 0!important;
  border-top:1px solid #e2e8f0;
}

.home-proof-item,
.process-step,
.region-note,
.home-final-contact-card{
  border:1px solid rgba(8,43,91,.1)!important;
  box-shadow:0 16px 34px rgba(2,8,23,.07)!important;
}

.home-proof-item,
.process-step,
.region-note{
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}

.home-proof-item:hover,
.process-step:hover,
.region-note:hover{
  transform:translateY(-2px);
  border-color:rgba(73,165,50,.32)!important;
  box-shadow:0 20px 42px rgba(2,8,23,.1)!important;
}

.final-cta{
  background:
    radial-gradient(circle at 14% 0%,rgba(73,165,50,.2),transparent 34%),
    linear-gradient(135deg,#061b42,#082b5b)!important;
}

.home-final-contact-card{
  border-radius:14px!important;
  box-shadow:0 22px 48px rgba(2,8,23,.2)!important;
}

.home-final-contact-stack a{
  transition:transform .2s ease,box-shadow .2s ease!important;
}

.home-final-contact-stack a:hover,
.home-final-contact-stack a:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 16px 30px rgba(2,8,23,.18)!important;
}

@media (min-width:701px){
  .home-final-contact-stack a{
    min-height:74px!important;
  }
}

@media (max-width:700px){
  .cards .card{
    padding-bottom:18px!important;
  }

  .cards .card img{
    height:150px!important;
    margin-bottom:16px!important;
  }

  .card-proof{
    min-height:0;
    margin:0 18px;
  }

  .home-final-contact-stack a{
    min-height:74px!important;
  }
}
/* Mobile typography scale */
@media (max-width:700px){
  .hero h1{font-size:22px!important;line-height:1.08!important;letter-spacing:0!important}
  .hero-sub{font-size:19px!important;line-height:1.12!important}
  .hero .lead,.section-text,.card p,.home-proof-item p,.process-content p,.region-content p,.final-cta-copy p{font-size:13px!important;line-height:1.5!important}
  .service-intro h2,.home-proof-intro h2,.about-me-container h2,.process-head h2,.region-content h2,.final-cta-copy h2,.final-cta-top h2{font-size:15px!important;line-height:1.24!important}
  .cards .card h3,.process-content h3,.home-proof-item strong{font-size:13px!important;line-height:1.22!important}
}
/* Mobile service cards */
@media (max-width:700px){
  .cards .grid4{
    grid-template-columns:1fr!important;
    gap:14px!important;
  }

  .cards .card{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    height:auto!important;
    min-height:0!important;
    padding:0 0 16px!important;
    overflow:hidden!important;
    text-align:center!important;
  }

  .cards .card img{
    width:100%!important;
    height:150px!important;
    margin:0 0 14px!important;
    border-radius:10px 10px 0 0!important;
    object-fit:cover!important;
    transform:none!important;
  }

  .cards .desktop-title{
    display:inline!important;
  }

  .cards .mobile-title{
    display:none!important;
  }

  .cards .card h3{
    margin:0 18px 7px!important;
    font-size:14px!important;
    line-height:1.22!important;
    text-align:center!important;
  }

  .cards .card p{
    margin:0 18px!important;
    text-align:center!important;
  }

  .card-proof{
    align-items:center!important;
    justify-content:center!important;
    min-height:24px!important;
    margin:12px 18px 0!important;
    padding:0!important;
    line-height:1.35!important;
    overflow:visible!important;
  }

  .card-proof:before{
    margin-top:0!important;
  }
}
/* Mobile service card proof */
@media (max-width:700px){
  .card-proof{
    display:inline-flex!important;
    align-self:center!important;
    align-items:center!important;
    justify-content:center!important;
    width:auto!important;
    max-width:calc(100% - 36px)!important;
    min-height:0!important;
    margin:14px auto 0!important;
    padding:6px 10px!important;
    border-radius:999px!important;
    background:rgba(73,165,50,.1)!important;
    color:#256f1c!important;
    font-size:12px!important;
    line-height:1.2!important;
    text-align:center!important;
    overflow:visible!important;
  }

  .card-proof:before{
    width:18px!important;
    height:18px!important;
    flex:0 0 18px!important;
    margin:0!important;
    font-size:11px!important;
    line-height:1!important;
  }
}
/* Mobile service card final spacing */
@media (max-width:700px){
  .cards .grid4{
    align-items:start!important;
  }

  .cards .card{
    justify-content:flex-start!important;
    height:auto!important;
    min-height:0!important;
    padding-bottom:14px!important;
  }

  .card-proof{
    margin-top:14px!important;
    margin-bottom:0!important;
  }
}
/* Mobile proof items */
@media (max-width:700px){
  .home-proof-item{
    display:grid!important;
    grid-template-columns:34px minmax(0,1fr)!important;
    grid-template-rows:auto auto!important;
    column-gap:12px!important;
    row-gap:4px!important;
    align-items:start!important;
    padding:16px 14px!important;
  }

  .home-proof-item span{
    grid-column:1!important;
    grid-row:1 / 3!important;
    width:34px!important;
    height:34px!important;
    margin:0!important;
  }

  .home-proof-item strong,
  .home-proof-item p{
    grid-column:2!important;
    min-width:0!important;
  }

  .home-proof-item strong{
    grid-row:1!important;
    margin:0!important;
  }

  .home-proof-item p{
    grid-row:2!important;
    margin:0!important;
  }
}