:root{
  --teal:#063f35;
  --leaf:#009640;
  --leaf-2:#0f7f4c;
  --sun:#c7d52b;
  --clay:#c56a2b;
  --paper:#f7fbf6;
  --line:rgba(6,63,53,.13);
}
body{
  font-family:"Manrope",Arial,sans-serif;
  font-size:15px;
  line-height:1.56;
  background:
    linear-gradient(180deg,#ffffff 0,#f5fbf6 170px,#e9f6ee 720px,#f7fbf6 100%);
}
.topbar svg,.header-call svg,.footer-cta svg,.footer-card svg,.card-icon svg,.strip-icon svg,.tile-icon svg,.round-icon svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.25;stroke-linecap:round;stroke-linejoin:round}
.topbar-social svg{width:17px;height:17px}
.topbar-social a:first-child svg,.topbar-social a:nth-child(3) svg{fill:currentColor;stroke:none}
.topbar{
  background:linear-gradient(90deg,#064c36,#007c3b);
  border-bottom:1px solid rgba(255,255,255,.16);
  font-size:13px;
}
.topbar-inner{
  min-height:34px;
  font-weight:700;
  display:flex;
  justify-content:flex-start;
  gap:26px;
}
.topbar-item{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:#eaf9ef;
  white-space:nowrap;
}
.site-header{
  background:#fff!important;
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 28px rgba(6,63,53,.1);
  backdrop-filter:blur(10px);
}
.header-inner{
  min-height:82px;
  gap:22px;
}
.brand{
  min-width:0;
  flex:0 1 330px;
}
.brand-mark{
  width:58px;
  height:58px;
  box-shadow:0 10px 24px rgba(0,109,55,.24);
  transition:transform .3s ease,box-shadow .3s ease;
}
.brand-mark span,.brand-mark:before,.brand-mark:after{
  width:34px;
  height:8px;
  box-shadow:0 12px 0 #c56a2b,0 -12px 0 #008d4a;
}
.brand-mark:after{
  transform:translateY(12px);
}
.brand:hover .brand-mark{
  transform:rotate(-4deg) scale(1.04);
  box-shadow:0 15px 32px rgba(0,109,55,.28);
}
.brand-text{
  color:var(--teal);
  font-weight:400;
  letter-spacing:.01em;
  font-size:20px;
  line-height:1.05;
}
.brand-text strong{
  display:block;
  margin-top:2px;
  font-size:20px;
}
.header-call{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:40px;
  padding:0 18px;
  color:var(--teal);
  border:1px solid rgba(6,63,53,.18);
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  font-size:13px;
  white-space:nowrap;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.header-call:hover{
  transform:translateY(-1px);
  border-color:var(--leaf);
  box-shadow:0 14px 30px rgba(6,63,53,.12);
}
.site-nav{
  flex:1 1 auto;
  justify-content:flex-end;
  gap:16px;
  font-size:12px;
  letter-spacing:.035em;
}
.site-nav a,.nav-group>button{
  position:relative;
  color:var(--teal);
  padding:12px 0;
  transition:color .2s ease,transform .2s ease;
}
.site-nav a:hover,.nav-group>button:hover{
  transform:translateY(-1px);
}
.site-nav a:after,.nav-group>button:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:7px;
  height:3px;
  background:var(--sun);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .18s ease;
}
.site-nav a:hover:after,.nav-group>button:hover:after,.site-nav a.active:after{
  transform:scaleX(1);
}
.nav-group>div{
  border-radius:14px;
  border:1px solid var(--line);
  overflow:hidden;
  animation:menuDrop .16s ease both;
}
.nav-group>div a{
  padding:9px 16px;
}
.hero{
  min-height:auto;
  display:flex;
  align-items:center;
  padding:34px 0 26px;
  background:transparent;
}
.hero-frame{
  position:relative;
  min-height:620px;
  border-radius:30px;
  overflow:hidden;
  display:grid;
  align-items:center;
  background:
    linear-gradient(90deg,rgba(247,251,246,.94) 0,rgba(231,246,237,.82) 42%,rgba(231,246,237,.34) 100%),
    url("../img/hero-servizio-civile-parma-piacenza.png") center/cover;
  box-shadow:0 24px 70px rgba(6,63,53,.14);
  border:1px solid rgba(6,63,53,.1);
}
.hero-copy{
  padding:0;
}
.hero-grid{
  width:100%;
  padding:64px;
  grid-template-columns:minmax(0,1.03fr) minmax(340px,.78fr);
}
.hero h1{
  color:var(--teal);
  opacity:1!important;
  max-width:720px;
  font-size:48px;
  line-height:1.04;
  font-family:"Playfair Display",Georgia,serif;
  text-transform:none;
  letter-spacing:.01em;
  animation:fadeUpSolid .42s ease both;
}
.hero p{
  color:#17473b;
  opacity:1!important;
  font-size:16px;
  max-width:560px;
  animation:fadeUpSolid .42s ease .06s both;
}
.hero p strong{
  color:var(--leaf-2);
}
.hero-card{
  border-left:0;
  border-top:8px solid var(--leaf);
  border-radius:22px;
  background:rgba(255,255,255,.9);
  opacity:1!important;
  animation:fadeUpSolid .42s ease .1s both;
  box-shadow:0 28px 70px rgba(6,63,53,.16);
}
.card-icon,.strip-icon,.tile-icon,.round-icon{
  display:inline-grid;
  place-items:center;
  color:var(--leaf);
  background:#e4f4e9;
  border-radius:50%;
}
.card-icon{
  width:72px;
  height:72px;
  margin-bottom:18px;
}
.card-icon svg{
  width:36px;
  height:36px;
}
.hero-card h2{
  font-size:24px;
  line-height:1.2;
}
.hero-card a{
  color:var(--leaf-2)!important;
  font-weight:800;
  text-decoration:none;
  border-bottom:3px solid var(--sun);
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.btn-arrow{
  display:inline-grid;
  place-items:center;
  width:30px;
  height:30px;
  margin-left:8px;
  border-radius:50%;
  background:rgba(255,255,255,.86);
  color:var(--leaf);
  line-height:1;
}
.btn.secondary .btn-arrow{
  background:var(--leaf);
  color:white;
}
.btn{
  min-height:44px;
  padding:10px 18px;
  font-size:13px;
  border-radius:999px;
  box-shadow:0 12px 24px rgba(0,150,64,.18);
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  opacity:1!important;
  animation:fadeUpSolid .42s ease .08s both;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px rgba(0,150,64,.24);
}
.btn.secondary{
  background:rgba(255,255,255,.74);
}
.section{
  position:relative;
}
.section:nth-of-type(even){
  background:rgba(255,255,255,.32);
}
.home-strip{
  margin-top:0;
  position:relative;
  z-index:3;
}
.home-strip-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.home-strip article{
  min-height:120px;
  padding:24px;
  border-radius:22px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  box-shadow:0 18px 42px rgba(6,63,53,.14);
  display:grid;
  gap:8px;
  align-content:center;
  animation:fadeUpSolid .42s ease .14s both;
}
.home-strip strong{
  font-family:"Playfair Display",Georgia,serif;
  font-size:34px;
  line-height:1;
  color:var(--leaf);
}
.strip-icon{
  width:52px;
  height:52px;
  margin-bottom:6px;
}
.home-strip span{
  color:#24564a;
  font-weight:700;
}
.home-intro{
  padding-top:92px;
}
.intro-grid{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(320px,.75fr);
  gap:52px;
  align-items:start;
  margin-bottom:30px;
}
.intro-copy{
  font-size:15px;
  color:#244d43;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:20px;
}
.service-tile{
  display:block;
  min-height:230px;
  padding:28px;
  border-radius:24px;
  color:var(--teal);
  text-decoration:none;
  background:rgba(255,255,255,.78);
  border:1px solid var(--line);
  box-shadow:0 14px 36px rgba(6,63,53,.1);
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
}
.service-tile:hover{
  transform:translateY(-5px);
  background:#fff;
  box-shadow:0 24px 52px rgba(6,63,53,.16);
}
.service-tile span{
  margin-bottom:26px;
}
.tile-icon{
  width:58px;
  height:58px;
}
.service-tile h3{
  margin:0 0 12px;
  font-size:17px;
  line-height:1.18;
}
.service-tile p{
  margin:0;
  color:#41675d;
}
.news-preview{
  background:transparent;
}
.news-panel{
  padding:44px;
  border-radius:30px;
  background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(231,246,237,.78));
  border:1px solid var(--line);
  box-shadow:0 24px 70px rgba(6,63,53,.12);
}
.section-heading{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:24px;
  margin-bottom:26px;
}
.heading-with-icon{
  display:flex;
  align-items:center;
  gap:20px;
}
.round-icon{
  width:78px;
  height:78px;
}
.round-icon.small{
  width:58px;
  height:58px;
}
.eyebrow{
  color:var(--leaf-2);
}
.page-title{
  color:var(--teal);
  font-family:"Playfair Display",Georgia,serif;
  text-transform:none;
  font-size:34px;
  line-height:1.12;
  letter-spacing:.01em;
}
.panel{
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
}
.panel:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.9);
}
.panel a,.rich a{color:var(--green-dark);font-weight:800}
.feature-list li{
  border-radius:16px;
  border-left-color:var(--leaf);
  transition:transform .18s ease,background .18s ease;
}
.feature-list li:hover{
  transform:translateX(4px);
  background:rgba(255,255,255,.92);
}
.cards{
  align-items:stretch;
}
.card{
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.86);
  transition:transform .18s ease,box-shadow .18s ease;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 46px rgba(6,63,53,.19);
}
.card img{
  filter:saturate(.92);
}
.card-body{
  min-height:210px;
  font-size:14px;
}
.card time{
  color:var(--leaf-2);
}
.card h3{
  color:var(--teal);
  font-weight:800;
  font-size:18px;
}
.contacts .panel:first-child{
  border-top:8px solid var(--sun);
}
.contacts .panel:nth-child(2){
  border-top:8px solid var(--leaf);
}
.contact-form{
  border-top:8px solid var(--clay);
}
.contact-form input,.contact-form textarea{
  border:1px solid rgba(6,63,53,.15);
  border-radius:14px;
  transition:border-color .2s ease,box-shadow .2s ease;
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:0;
  border-color:var(--leaf);
  box-shadow:0 0 0 4px rgba(0,150,64,.12);
}
.privacy-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#45675c;
  font-size:14px;
}
.privacy-check input{
  width:auto;
  margin-top:4px;
  flex:0 0 auto;
}
.privacy-check a{
  color:var(--leaf-2);
  font-weight:800;
}
.hp-field{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}
.site-footer{
  margin-top:0;
  background:
    radial-gradient(circle at 12% 18%,rgba(199,213,43,.16),transparent 28%),
    linear-gradient(135deg,#007c3b 0,#063f35 54%,#042e27 100%);
  color:#ecfff3;
  padding:0 0 24px;
  font-size:14px;
}
.footer-cta{
  padding:42px 0 30px;
  background:linear-gradient(180deg,#f7fbf6,#e6f5ea);
  color:var(--teal);
}
.footer-cta-inner{
  min-height:118px;
  padding:24px 32px;
  border-radius:20px;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(235,247,239,.9));
  border:1px solid var(--line);
  box-shadow:0 18px 48px rgba(6,63,53,.11);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:36px;
}
.footer-cta-copy,.footer-cta-phone{
  display:flex;
  align-items:center;
  gap:20px;
}
.footer-cta h2{
  margin:0 0 10px;
  font-family:"Playfair Display",Georgia,serif;
  font-size:28px;
  line-height:1.12;
  color:var(--teal)!important;
}
.footer-cta p{
  margin:0;
  max-width:720px;
  font-size:14px;
}
.footer-cta-phone{
  padding-left:34px;
  border-left:1px solid rgba(6,63,53,.18);
}
.footer-cta-phone strong{
  display:block;
  font-size:18px;
  color:var(--teal);
}
.footer-cta-phone span:not(.round-icon){
  color:#45675e;
  white-space:nowrap;
}
.footer-cta .eyebrow{
  margin-bottom:8px;
}
.footer-cta-btn{
  flex:0 0 auto;
  gap:10px;
}
.footer-grid{
  padding:48px 0 32px;
  display:grid;
  grid-template-columns:1.22fr .9fr .96fr .78fr;
  gap:20px;
}
.site-footer .brand-text,
.site-footer .brand-text strong{
  color:white;
}
.footer-logo{
  margin-bottom:18px;
}
.footer-brand p{
  max-width:360px;
  color:#d8f2e3;
  line-height:1.55;
}
.footer-card{
  padding:24px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.055));
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
}
.footer-card h3,.footer-links h3{
  margin-top:0;
  margin-bottom:16px;
  color:white;
  font-size:17px;
}
.footer-card p{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:#e4f8eb;
  padding-bottom:12px;
  margin:0 0 12px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-card p:last-child{
  border-bottom:0;
  padding-bottom:0;
}
.mini-icon{
  display:inline-grid;
  place-items:center;
  width:28px;
  height:28px;
  flex:0 0 28px;
  color:#cfeabd;
}
.footer-links{
  display:grid;
  align-content:start;
  gap:6px;
  padding:24px 0 0;
}
.footer-links a,.footer-bottom a{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:#e8f6c0;
  text-decoration:none;
  font-weight:800;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-links a:hover,.footer-bottom a:hover{
  text-decoration:underline;
}
.footer-bottom{
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.16);
  display:flex;
  justify-content:space-between;
  gap:20px;
  color:#d8f2e3;
}
.footer-legal{
  display:inline-flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}
.footer-social{
  display:flex;
  align-items:center;
  gap:14px;
  padding:0 0 26px;
}
.footer-social strong{
  margin-right:10px;
}
.social-dot{
  display:inline-grid;
  place-items:center;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.24);
  color:#e8f6c0;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

/* Mockup refinement pass: proporzioni, contrasto e ritmo visivo. */
.wrap{
  width:min(1480px,calc(100% - 80px));
}
body{
  font-size:16px;
  line-height:1.58;
  background:#f7fbf6;
  color:#113c33;
}
.topbar{
  background:linear-gradient(90deg,#063f35 0,#006f3f 100%);
  font-size:13px;
  font-weight:600;
}
.topbar-inner{
  justify-content:space-between;
  min-height:38px;
}
.topbar-left{
  display:flex;
  align-items:center;
  gap:30px;
  min-width:0;
}
.topbar-social{
  display:flex;
  align-items:center;
  gap:14px;
  color:#ecfff3;
}
.topbar-social a{
  display:inline-grid;
  place-items:center;
  width:28px;
  height:28px;
  color:#ecfff3;
  text-decoration:none;
  transition:opacity .18s ease,transform .18s ease;
}
.topbar-social a:hover{
  opacity:.82;
  transform:translateY(-1px);
}
.site-header{
  background:#fff!important;
  box-shadow:0 8px 24px rgba(6,63,53,.075);
}
.header-inner{
  min-height:112px;
  gap:32px;
}
.brand{
  flex:0 0 auto;
  gap:20px;
}
.brand-mark{
  width:76px;
  height:76px;
}
.brand-text{
  font-size:28px;
  line-height:1.02;
  text-transform:none;
}
.brand-text strong{
  font-size:23px;
  font-weight:500;
  color:var(--leaf-2);
}
.site-nav{
  justify-content:center;
  gap:36px;
  font-size:14px;
  font-weight:600;
  letter-spacing:0;
  text-transform:uppercase;
}
.site-nav a,.nav-group>button{
  color:#17282d;
  padding:16px 0;
}
.nav-group>button{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.chevron{
  display:inline-block;
  width:7px;
  height:7px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:translateY(-2px) rotate(45deg);
  transform-origin:center;
  opacity:.72;
  transition:transform .18s ease,opacity .18s ease;
}
.nav-group:hover .chevron,
.nav-group:focus-within .chevron{
  opacity:1;
  transform:translateY(1px) rotate(225deg);
}
.header-call{
  min-height:52px;
  padding:0 24px;
  font-size:16px;
  font-weight:800;
  border-color:rgba(6,63,53,.16);
}
.hero{
  padding:34px 0 28px;
}
.hero-frame{
  min-height:578px;
  border-radius:24px;
  background:
    linear-gradient(90deg,rgba(247,251,246,.86) 0%,rgba(247,251,246,.6) 38%,rgba(247,251,246,.18) 72%,rgba(247,251,246,.03) 100%),
    url("../img/hero-servizio-civile-parma-piacenza.png") center 56%/cover;
  box-shadow:0 20px 52px rgba(6,63,53,.13);
}
.hero-grid{
  grid-template-columns:minmax(0,1.16fr) minmax(380px,.84fr);
  gap:56px;
  padding:64px;
}
.hero h1{
  max-width:760px;
  font-size:clamp(52px,5vw,74px);
  line-height:1.05;
  letter-spacing:0;
  margin-bottom:28px;
}
.hero p{
  max-width:520px;
  font-size:18px;
  line-height:1.72;
}
.hero-card{
  align-self:center;
  justify-self:end;
  max-width:470px;
  padding:42px;
  border-radius:18px;
  background:rgba(255,255,255,.94);
  box-shadow:0 28px 64px rgba(6,63,53,.16);
}
.hero-card h2{
  font-family:"Playfair Display",Georgia,serif;
  font-size:34px;
  line-height:1.1;
  margin:0 0 22px;
}
.hero-card p:not(.eyebrow){
  font-size:16px;
  line-height:1.7;
}
.hero-card a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid rgba(6,63,53,.16);
  border-bottom:0;
}
.card-icon{
  width:64px;
  height:64px;
  margin-bottom:24px;
}
.btn{
  min-height:56px;
  padding:12px 26px;
  font-size:15px;
  text-transform:none;
}
.btn.secondary{
  background:rgba(255,255,255,.72);
  box-shadow:inset 0 0 0 1.5px var(--leaf);
}
.home-strip{
  display:none;
}
.home-intro{
  padding-top:74px;
}
.intro-grid{
  grid-template-columns:minmax(0,.9fr) minmax(340px,.72fr);
}
.page-title{
  font-size:clamp(36px,3.1vw,46px);
}
.service-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.news-preview{
  padding-top:28px;
}
.news-panel{
  position:relative;
  padding:38px 44px 48px;
  border-radius:24px;
  background:linear-gradient(135deg,#f4fbf6 0,#edf8f2 100%);
}
.news-panel:before,.news-panel:after{
  content:"›";
  position:absolute;
  top:64%;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#fff;
  color:var(--leaf-2);
  border:1px solid rgba(6,63,53,.12);
  box-shadow:0 10px 24px rgba(6,63,53,.1);
  font-size:28px;
  line-height:1;
}
.news-panel:before{
  content:"‹";
  left:-20px;
}
.news-panel:after{
  right:-20px;
}
.news-panel .cards{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
}
.news-panel .card{
  border-radius:16px;
  background:#fff;
}
.news-panel .card img{
  aspect-ratio:16/8.5;
}
.news-panel .card-body{
  min-height:168px;
  padding:20px;
}
.news-panel .card time{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:12px;
  font-weight:500;
  color:#53665f;
  text-transform:none;
}
.news-panel .card time:before{
  content:"NEWS";
  padding:4px 11px;
  border-radius:999px;
  background:#dbf3e3;
  color:var(--leaf-2);
  font-size:12px;
  font-weight:800;
}
.news-panel .card h3{
  font-size:17px;
  line-height:1.35;
}
.news-panel .card p{
  display:none;
}
.site-footer{
  background:
    radial-gradient(circle at 10% 14%,rgba(199,213,43,.18),transparent 28%),
    linear-gradient(135deg,#064f38 0,#063f35 48%,#032d26 100%);
}
.footer-cta{
  padding:42px 0 32px;
  background:#fff;
}
.footer-cta-inner{
  min-height:136px;
  padding:30px 48px;
  border-radius:18px;
  background:linear-gradient(135deg,#f4fbf6 0,#eaf6ef 100%);
}
.footer-grid{
  padding:58px 0 40px;
  grid-template-columns:1.22fr .92fr .92fr .78fr;
  gap:34px;
}
.footer-card{
  padding:30px;
  border-radius:16px;
  background:rgba(255,255,255,.075);
}
.footer-links{
  padding-top:6px;
}
.footer-links a,.footer-bottom a{
  font-weight:600;
  color:#eef8de;
}
.footer-legal{
  display:inline-flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}
.btn.secondary{
  box-shadow:none;
  border:0;
  background:rgba(255,255,255,.82);
}
.header-call,
.hero-frame,
.hero-card,
.news-panel,
.panel,
.card,
.service-tile,
.footer-cta-inner,
.footer-card,
.contact-form input,
.contact-form textarea{
  border:0;
}
.hero-card,
.contacts .panel:first-child,
.contacts .panel:nth-child(2),
.contact-form{
  border-top:0;
}
.feature-list li{
  border-left:0;
}
.hero-card a,
.footer-card p,
.footer-links a,
.footer-bottom,
.footer-bottom a{
  border:0;
}
.footer-cta-phone{
  border-left:0;
  padding-left:0;
}
.social-dot{
  border:0;
  background:rgba(255,255,255,.1);
}
.news-panel:before,
.news-panel:after{
  border:0;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border:0;
}
.btn.secondary{
  box-shadow:inset 0 0 0 1.5px var(--leaf);
  border-radius:0;
}
.header-call,
.hero-frame,
.hero-card,
.news-panel,
.panel,
.card,
.service-tile,
.footer-cta-inner,
.footer-card,
.contact-form input,
.contact-form textarea{
  border:1px solid var(--line);
  border-radius:0;
}
.header-call{
  border-color:rgba(6,63,53,.16);
}
.hero-card,
.contacts .panel:first-child,
.contacts .panel:nth-child(2),
.contact-form{
  border-top:1px solid var(--line);
}
.feature-list li{
  border-left:1px solid var(--line);
  border-radius:0;
}
.hero-card a{
  border-top:1px solid rgba(6,63,53,.16);
}
.footer-card{
  border-color:rgba(255,255,255,.18);
}
.footer-card p,
.footer-links a,
.footer-bottom a{
  border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.16);
}
.footer-cta-phone{
  border-left:1px solid rgba(6,63,53,.18);
  padding-left:34px;
}
.social-dot{
  border:1px solid rgba(255,255,255,.24);
  background:transparent;
}
.news-panel:before,
.news-panel:after{
  border:1px solid rgba(6,63,53,.12);
  border-radius:0;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border:1px solid var(--leaf);
  border-radius:0;
}
.btn.secondary{
  box-shadow:inset 0 0 0 3px var(--leaf);
}
.header-call,
.hero-frame,
.hero-card,
.news-panel,
.panel,
.card,
.service-tile,
.footer-cta-inner,
.footer-card,
.contact-form input,
.contact-form textarea{
  border:3px solid var(--leaf);
}
.hero-card,
.contacts .panel:first-child,
.contacts .panel:nth-child(2),
.contact-form{
  border-top:3px solid var(--leaf);
}
.feature-list li{
  border-left:3px solid var(--leaf);
}
.contact-form input:focus,
.contact-form textarea:focus{
  border:3px solid var(--leaf);
}
.header-call,
.hero-frame,
.hero-card,
.news-panel,
.panel,
.card,
.service-tile,
.footer-cta-inner,
.contact-form input,
.contact-form textarea{
  border:1px solid var(--line);
}
.footer-card{
  border:1px solid rgba(255,255,255,.18);
}
.btn.secondary{
  box-shadow:inset 0 0 0 3px var(--leaf);
}
.feature-list li{
  border-left:3px solid var(--leaf);
}
.contacts .panel:first-child{
  border-top:3px solid var(--sun);
}
.contacts .panel:nth-child(2),
.contact-form,
.hero-card{
  border-top:3px solid var(--leaf);
}
.hero-card a{
  border-top:3px solid rgba(6,63,53,.16);
}
.contact-form input:focus,
.contact-form textarea:focus{
  border:3px solid var(--leaf);
}
.breadcrumb{
  min-height:0;
  background:#fff;
  border-top:1px solid rgba(6,63,53,.04);
}
.breadcrumb:empty{
  display:none;
}
.breadcrumb-inner{
  display:flex;
  align-items:center;
  gap:9px;
  min-height:42px;
  color:#527268;
  font-size:13px;
  font-weight:600;
}
.breadcrumb a{
  color:var(--leaf-2);
  text-decoration:none;
}
.breadcrumb a:hover{
  text-decoration:underline;
}
.breadcrumb-sep{
  color:#91a89f;
}
.policy-page .content-grid{
  align-items:start;
}
.policy-content section{
  padding:18px 0 4px;
  border-top:1px solid rgba(6,63,53,.1);
}
.policy-content section:first-of-type{
  margin-top:18px;
}
.policy-content h2{
  font-size:22px;
  margin-bottom:10px;
}
.policy-note{
  padding:18px 20px;
  background:#f2f8ef;
  border-left:3px solid var(--leaf);
  color:#355f52;
  font-weight:650;
}
.policy-sidebar{
  position:sticky;
  top:110px;
}
.policy-sidebar .feature-list li{
  background:#fff;
}
.policy-button{
  width:100%;
  text-align:left;
  border:0;
  background:transparent;
  color:var(--leaf-2);
  font:inherit;
  font-weight:800;
  cursor:pointer;
  padding:0;
}
.policy-button:hover{
  text-decoration:underline;
}
.policy-meta{
  display:grid;
  gap:4px;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid rgba(6,63,53,.12);
  color:#527268;
  font-size:13px;
}
.policy-meta strong{
  color:var(--teal);
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeUpSolid{
  from{opacity:.01;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes menuDrop{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion:reduce){
  *,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
@media (max-width:900px){
  .topbar-inner{justify-content:space-between;gap:16px}
  .topbar-hours{display:none}
  .header-inner{min-height:78px}
  .brand{flex:1 1 auto}
  .hero{min-height:auto;padding:54px 0}
  .hero-frame{min-height:auto}
  .hero-grid{grid-template-columns:1fr!important;gap:24px;padding:40px}
  .header-call{display:none}
  .header-inner{flex-wrap:wrap}
  .site-nav{
    position:static;
    width:100%;
    flex:1 0 100%;
    gap:8px;
    font-size:13px;
    box-shadow:none;
  }
  .nav-group>button{gap:7px}
  .chevron{width:6px;height:6px;border-width:1.8px}
  .wrap{width:min(100% - 40px,1180px)}
  .topbar-left{gap:18px}
  .topbar-social{display:none}
  .hero-grid{grid-template-columns:1fr!important}
  .hero-card{justify-self:start;max-width:100%}
  .news-panel .cards{grid-template-columns:1fr 1fr}
  .home-strip{margin-top:0;padding:22px 0 0}
  .home-strip-grid,.intro-grid,.service-grid,.footer-grid{grid-template-columns:1fr 1fr}
  .footer-cta-inner{display:grid}
  .footer-cta-phone{padding-left:0;border-left:0}
  .footer-bottom{display:grid;justify-content:start}
}
@media (max-width:620px){
  body{font-size:14px}
  .topbar{font-size:12px}
  .topbar-inner{display:flex;padding:8px 0;min-height:0}
  .wrap{width:min(100% - 28px,1180px)}
  .topbar-left{gap:8px;overflow:hidden}
  .topbar-item:nth-child(2){display:none}
  .topbar-item:first-child{padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.14)}
  .brand{gap:10px;min-width:0}
  .brand-mark{width:48px;height:48px;flex:0 0 48px}
  .brand-mark span,.brand-mark:before,.brand-mark:after{width:28px;height:7px;box-shadow:0 10px 0 #c56a2b,0 -10px 0 #008d4a}
  .brand-mark:after{transform:translateY(10px)}
  .brand-text{font-size:15px}
  .brand-text strong{font-size:16px}
  .header-inner{min-height:72px;gap:12px}
  .menu-toggle{border-radius:999px}
  .hero{min-height:auto;padding:40px 0 34px;background-position:center top}
  .hero-frame{border-radius:0;width:100%;box-shadow:none;border-left:0;border-right:0}
  .hero-grid{grid-template-columns:1fr!important;gap:20px;padding:34px 14px}
  .hero-copy{padding:0}
  .hero h1{font-size:28px}
  .hero .btn{display:flex;width:max-content;max-width:100%;margin-bottom:10px}
  .hero .btn.secondary{background:rgba(255,255,255,.55)}
  .hero-card{margin-top:0;padding:24px}
  .home-strip{margin-top:0;padding:18px 0 0}
  .home-strip-grid,.intro-grid,.service-grid,.footer-grid,.footer-cta-inner,.footer-bottom{grid-template-columns:1fr;display:grid}
  .home-strip article{min-height:auto}
  .home-strip strong{font-size:30px}
  .home-intro{padding-top:56px}
  .section-heading{display:grid;align-items:start}
  .news-panel{padding:28px 18px}
  .news-panel:before,.news-panel:after{display:none}
  .news-panel .cards{grid-template-columns:1fr}
  .heading-with-icon{gap:12px;align-items:flex-start}
  .section-heading .btn{width:100%;max-width:100%}
  .service-tile{min-height:auto}
  .page-title{font-size:29px}
  .footer-cta h2{font-size:24px}
  .footer-cta-inner{padding:22px;border-radius:18px}
  .footer-cta-copy,.footer-cta-phone{align-items:flex-start}
  .footer-social{display:grid;grid-template-columns:1fr repeat(4,40px);gap:8px}
  .footer-bottom{justify-content:start}
  .footer-legal{gap:10px}
}