/* =========================
   1) Variables
========================= */
:root{
  --bg-main:#111111;
  --bg-alt:#181818;
  --bg-header:#111111cc;
  --border-subtle:#333333;
  --text-main:#f5f5f5;
  --text-muted:#a0a0a0;
  --accent:#ffffff;
  --radius-large:24px;
  --radius-medium:16px;
  --shadow-soft:0 16px 40px rgba(0,0,0,0.45);
  --transition-fast:0.18s ease-out;
  --transition-slow:0.8s ease-out;
}

/* =========================
   2) Reset + base
========================= */
*,
*::before,
*::after{ box-sizing:border-box; }

html,body{ margin:0; padding:0; }

body{
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg-main);
  color:var(--text-main);
  line-height:1.6;
}

a{ color:var(--text-main); text-decoration:none; }

.text-justify{
  text-align:justify;
  text-justify:inter-word;
}

/* =========================
   3) Layout
========================= */
.container{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:0 4px;
}

.container-large{
  width:100%;
  max-width:1820px;
  margin:0 auto;
  padding:0 10px;
}

.section{
  padding:80px 0;
  background:var(--bg-main);
}

.section-alt{ background:var(--bg-alt); }

.evolution-section{ padding:140px 0; }

.section-inner{
  display:flex;
  flex-direction:column;
  gap:40px;
}

.section-inner-large{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.section-header{ max-width:640px; }

.section-header h2{
  font-size:24px;
  font-weight:500;
  margin:0 0 8px;
}

.section-header p{
  margin:0;
  color:var(--text-muted);
}

.section-intro{
  max-width:560px;
  color:var(--text-muted);
}

.section-split{
  flex-direction:row;
  align-items:flex-start;
  gap:80px;
}

.section-split > div{ flex:1; }

/* =========================
   4) Header + navigation
========================= */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter:blur(12px);
  background:var(--bg-header);
  border-bottom:1px solid var(--border-subtle);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
}

/* logo */
.logo{
  font-size:16px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-weight:500;
  text-decoration:none;
  color:var(--text-main);
}

.site-header .logo{
  padding:12px 0;
  display:flex;
  align-items:center;
}

.logo img{
  height:28px;
  width:auto;
  max-height:28px;
  display:block;
}

/* nav */
.main-nav{
  display:flex;
  gap:24px;
  align-items:center;
}

.main-nav ul{
  display:flex;
  gap:24px;
  align-items:center;
  margin:0;
  padding:0;
  list-style:none;
}

.nav-item{
  position:relative;
  display:flex;
  align-items:center;
}

.main-nav .nav-item{
  position:relative;
  display:flex;
  align-items:center;
}

.main-nav a,
.nav-link{
  font-size:14px;
  text-decoration:none;
  color:var(--text-muted);
  padding-bottom:3px;
  border-bottom:1px solid transparent;
  transition:color var(--transition-fast),
  border-color var(--transition-fast);
}

.main-nav a:hover,
.nav-link:hover{
  color:var(--text-main);
  border-color:var(--text-main);
}

.main-nav a.is-active{
  color:var(--text-main);
  border-color:var(--text-main);
}

/* dropdown */
.has-dropdown{ position:relative; }

.nav-dropdown{
  position:absolute;
  top:100%;
  left:0;
  display:flex;
  flex-direction:column;
  background:var(--bg-main);
  border:1px solid var(--border-subtle);
  padding:6px 0;
  min-width:180px;
  border-radius:0;
  box-shadow:none;
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
  transition:opacity 0.25s cubic-bezier(0.25,0.1,0.25,1),
             transform 0.25s cubic-bezier(0.25,0.1,0.25,1);
}

.nav-dropdown a{
  padding:6px 14px;
  font-size:13px;
  color:var(--text-main);
  opacity:0.85;
  text-decoration:none;
  transition:opacity 0.15s ease, background 0.15s ease;
}

.nav-dropdown a:hover{
  opacity:1;
  background:var(--bg-alt);
}

/* burger */
.nav-toggle{
  display:none;
  background:transparent;
  border:0;
  padding:4px;
  cursor:pointer;
}

.nav-toggle span{
  display:block;
  width:20px;
  height:2px;
  background:var(--text-main);
  margin:4px 0;
}

/* =========================
   5) Hero
========================= */
.hero-ft{
  position:relative;
  width:100%;
  height:35vh;
  min-height:220px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-bgft{
  position:absolute;
  inset:0;
  height:120%;
  background-image:url("../img/hero.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  will-change:transform;
  pointer-events:none;
}

.hero-large{
  position:relative;
  width:100%;
  height:125vh;
  min-height:820px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-bg{
  position:absolute;
  left:0;
  right:0;
  top:-10%;
  height:120%;
  background-image:url("../img/hero.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  will-change:transform;
  z-index:0;
  pointer-events:none;
}

.hero-overlay{
  position:relative;
  z-index:2;
  text-align:center;
  color:#ffffff;
  text-shadow:0 8px 24px rgba(0,0,0,0.4);
  padding:20px;
  background:transparent !important;
}

.hero-overlay-project{
  position:relative;
  z-index:2;
  text-align:left;
  color:#ffffff;
  text-shadow:0 8px 24px rgba(0,0,0,0.4);
  padding:20px;
  background:transparent !important;
}

.hero-large h1{
  font-size:56px;
  font-weight:500;
  letter-spacing:0.04em;
  margin:0 0 12px;
}

.hero-large p{
  font-size:20px;
  font-weight:300;
  margin:0;
  opacity:0.9;
}

.hero-logo{
  position:relative;
  z-index:3;
  margin:0 0 16px;
  display:flex;
  justify-content:center;
}

.hero-logo img{
  width:auto !important;
  height:auto !important;
  max-width:min(360px, 30vw);
  max-height:120px;
  display:block;
  margin:0 auto;
}

/* =========================
   6) Composants
========================= */
/* grids */
.grid{ display:grid; gap:24px; }
.grid.two{ grid-template-columns:repeat(2, minmax(0,1fr)); }
.grid.three{ grid-template-columns:repeat(3, minmax(0,1fr)); }

/* cards */
.card{
  background:var(--bg-alt);
  border-radius:var(--radius-medium);
  padding:24px;
  border:1px solid var(--border-subtle);
  box-shadow:0 10px 24px rgba(0,0,0,0.02);
}

.card h3{
  margin:0 0 8px;
  padding 5px;
  font-weight:500;
  font-size:18px;
}

.card p{
  margin:20;
  color:var(--text-muted);
}

/* buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  border-radius:999px;
  font-size:14px;
  border:1px solid transparent;
  text-decoration:none;
  cursor:pointer;
  transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}

.btn.primary{
  background:var(--accent);
  color:#111111;
}

.btn.primary:hover{
  box-shadow:0 10px 30px rgba(0,0,0,0.18);
  transform:translateY(-1px);
}

.btn.ghost{
  background:transparent;
  border-color:var(--border-subtle);
  color:var(--text-main);
}

.btn.ghost:hover{ border-color:var(--text-main); }

.link-arrow{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  text-decoration:none;
  color:var(--text-main);
  border-bottom:1px solid transparent;
  padding-bottom:2px;
  transition:border-color var(--transition-fast), transform var(--transition-fast);
}

.link-arrow::after{ content:"->"; font-size:14px; }

.link-arrow:hover{
  border-color:var(--text-main);
  transform:translateX(2px);
}

/* =========================
   7) Animations sections
========================= */
.approach-card{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 0.5s ease-out, transform 0.5s ease-out;
}

.approach-card.is-visible{
  opacity:1;
  transform:translateY(0);
}

.approach-card:nth-child(1){ transition-delay:0s; }
.approach-card:nth-child(2){ transition-delay:0.15s; }
.approach-card:nth-child(3){ transition-delay:0.3s; }

/* evolution */
.evolution-layout{
  display:grid;
  grid-template-columns:minmax(0,0.8fr) minmax(0,1.5fr) minmax(0,0.8fr);
  column-gap:40px;
  row-gap:180px;
  align-items:flex-start;
}

.evo-sticky{
  grid-column:2;
  position:sticky;
  top:120px;
  height:70vh;
  min-height:320px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.evo-image{
  width:100%;
  aspect-ratio:1/1;
  max-width:680px;
  height:auto;
  border-radius:var(--radius-large);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  box-shadow:none;
  filter:invert(1);
  transition:background-image 0.5s ease-out,
             transform 0.4s ease-out,
             opacity 0.3s ease-out;
}

.evo-step-0{ background-image:url("../img/evo-base.jpg"); }
.evo-step-1{ background-image:url("../img/evo-urbanisme.jpg"); }
.evo-step-2{ background-image:url("../img/evo-architecture.jpg"); }
.evo-step-3{ background-image:url("../img/evo-design.jpg"); }

.evo-step{
  max-width:420px;
  min-height:150vh;
  opacity:0.35;
  color:var(--text-muted);
  transform:translateY(12px);
  transition:color 0.3s ease-out, opacity 0.3s ease-out, transform 0.3s ease-out;
}

.evo-step-inner{
  position:sticky;
  top:30vh;
}

.evo-step h3{
  font-size:16px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  margin:0 0 8px;
  color:var(--text-muted);
  transition:color 0.3s ease-out;
}

.evo-step p{ margin:0; color:var(--text-muted); }

.evo-step.is-centered,
.evo-step.is-active{ opacity:1; }

.evo-step.is-centered h3,
.evo-step.is-centered p,
.evo-step.is-active h3,
.evo-step.is-active p{ color:var(--text-main) !important; }

.evo-step:nth-of-type(1){
  grid-column:1;
  grid-row:1;
  text-align:right;
  margin-left:auto;
}

.evo-step:nth-of-type(2){
  grid-column:3;
  grid-row:2;
  text-align:left;
  margin-right:auto;
}

.evo-step:nth-of-type(3){
  grid-column:1;
  grid-row:3;
  text-align:right;
  margin-left:auto;
}

.evo-step:nth-of-type(4){
  grid-column:3;
  grid-row:4;
  text-align:left;
  margin-right:auto;
}

/* =========================
   8) Projets
========================= */
/* cards */
																																					
.project-card .project-meta{
  padding:16px 20px !important;
}

.project-card .project-meta h3{
  margin:0 0 6px !important;
}

.project-card .project-meta p{
  margin:0 !important;
  color:var(--text-muted);
}


.project-card,
.project-card-large{
  background:var(--bg-alt);
  border-radius:var(--radius-medium);
  border:1px solid var(--border-subtle);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.project-card:hover,
.project-card-large:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
  border-color:#d0d0d0;
}

.project-card.is-hovered,
.project-card-large.is-hovered{
  transform:translateY(-6px) scale(1.03);
  box-shadow:var(--shadow-soft);
  border-color:#d0d0d0;
}

.project-img{
  width:100%;
  height:210px;
  border-radius:18px;
  display:block;
  object-fit:cover;
  object-position:center;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transition:transform 0.35s ease-out, filter 0.25s ease-out;
}

.project-card.is-hovered .project-img{ transform:scale(1.03); }

.thumb-placeholder{
  border-radius:18px;
  background:linear-gradient(135deg,#d6d6d6,#efefef);
  height:180px;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:14px;
}

.project-location{
  margin:0 0 12px;
  font-size:13px;
  color:var(--text-muted);
}

.project-text{
  margin:0;
  color:var(--text-muted);
  font-size:14px;
}

/* hero projets */
.projects-hero{
  position:relative;
  width:100%;
  height:60vh;
  min-height:420px;
  overflow:hidden;
}

.projects-hero-track{
  position:absolute;
  inset:0;
  display:flex;
  width:300%;
  transform:translateX(0);
  transition:transform 2s ease;
}

.projects-hero-image{
  position:relative;
  flex:0 0 33.3333%;
  height:100%;
  background-size:cover;
  background-position:center;
}

.projects-hero-image.active{
  opacity:1;
  z-index:1;
}

.img-2{ background-image:url("../img/HERO/project-hero-2.jpg"); }
.img-3{ background-image:url("../img/HERO/project-hero-3.jpg"); }

.projects-hero-image.is-video{ overflow:hidden; }

.projects-hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* grille projets */
.projects-section{ padding:50px 0; }

.projects-section h2{ margin-bottom:48px; }

.projects-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:275px;
  gap:35px;
}

/* thumbnails */
.project-thumb{
  position:relative;
  overflow:hidden;
  border-radius:0;
  background-size:cover;
  background-position:center;
  cursor:pointer;
  transition:transform 0.5s ease;
}

.project-thumb::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,17,17,0) 40%, rgba(5,5,5,0.55) 100%);
  z-index:2;
}

.project-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,17,17,0.5) 40%, rgba(5,5,5,0.75) 100%);
  opacity:0;
  transition:opacity var(--transition-fast);
  z-index:1;
}

.project-thumb:hover{ transform:scale(1.04); }

.project-thumb:hover::after{ opacity:0.3; }

.project-thumb-title{
  position:absolute;
  left:24px;
  bottom:16px;
  z-index:3;
  font-size:16px;
  font-weight:300;
  color:#ffffff;
  opacity:0;
  transform:translateY(8px);
  transition:opacity var(--transition-fast), transform var(--transition-fast);
}

.project-thumb:hover .project-thumb-title{
  opacity:1;
  transform:translateY(0);
}

.project-thumb-video{ background:none; }

.project-thumb-media{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
}

.thumb-wide3{ grid-column:span 3; }
.thumb-wide{ grid-column:span 2; }

.thumb-large{
  grid-column:span 2;
  grid-row:span 2;
}

/* =========================
   9) Pages + formulaires
========================= */
.page-hero{ padding:96px 0 48px; }

.page-hero h1{
  font-size:32px;
  margin:0 0 8px;
  font-weight:500;
}

.page-hero p{
  margin:16px;
  color:var(--text-muted);
}

/* forms */
.contact-form{
  display:flex;
  flex-direction:column;
  gap:16px;
  width:100%;
  max-width:none;
  align-self:stretch;
}



.form-row{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.form-row label{ font-size:13px; }

.form-row input,
.form-row textarea{
  font-family:inherit;
  font-size:14px;
  padding:9px 11px;
  border-radius:10px;
  border:1px solid var(--border-subtle);
  background:#ffffff;
}

.form-note{
  margin-top:12px;
  font-size:13px;
  color:var(--text-muted);
}

/* map */
.map-wrapper{
  width:100%;
  border-radius:0px;
  overflow:hidden;
}

/* =========================
   10) Liens dans le contenu
========================= */
.section p a,
.section li a,
.section-intro a,
.card p a,
.project-text a,
.project-location a,
.form-note a,
.site-footer a{
  color:var(--text-main);
  border-bottom:1px solid rgba(245,245,245,0.4);
  padding-bottom:1px;
  transition:opacity 0.15s ease, border-color 0.15s ease;
}

.section p a:hover,
.section li a:hover,
.section-intro a:hover,
.card p a:hover,
.project-text a:hover,
.project-location a:hover,
.form-note a:hover,
.site-footer a:hover{
  opacity:0.9;
  border-bottom-color:rgba(245,245,245,0.95);
}

/* =========================
   11) Contact hero
========================= */
.contact-hero-wrapper{
  background:transparent;
  padding:0;
}

.contact-hero{
  position:relative;
  width:160vw;
  min-height:620px;
  max-height:700px;
  margin-left:50%;
  transform:translateX(-50%);
  background-image:url("../img/contact.png");
  background-size:auto 190%;
  background-position:center 50%;
  background-repeat:no-repeat;
  will-change:background-position;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-radius:0;
}

.contact-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,17,17,0.15), rgba(17,17,17,0.8));
}

.contact-hero-content{
  position:relative;
  z-index:1;
  padding:600px 20px 120px;
  color:#ffffff;
  text-shadow:0 8px 24px rgba(0,0,0,0.4);
}
																																																				
.container.contact-hero-content{
  padding-left:24px;
}


/* =========================
   12) Footer
========================= */
.site-footer{
  padding:32px 0 40px;
  border-top:1px solid var(--border-subtle);
  background:var(--bg-alt);
}

.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  font-size:13px;
}

.footer-logo{
  font-size:13px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  margin:0 0 6px;
}

.footer-copy{
  margin:0;
  color:var(--text-muted);
}

/* =========================
   13) Infomaniak overrides
========================= */
html body a,
html body a:link,
html body a:visited,
html body a:hover,
html body a:active,
html body a:focus{
  color:var(--text-main) !important;
  text-decoration:none !important;
}

html body .section a,
html body .site-footer a,
html body .page-hero a,
html body .card a,
html body .project-meta a,
html body .form-note a{
  border-bottom:1px solid rgba(245,245,245,0.4) !important;
  padding-bottom:1px;
}

html body .section a:hover,
html body .site-footer a:hover,
html body .page-hero a:hover,
html body .card a:hover,
html body .project-meta a:hover,
html body .form-note a:hover{
  border-bottom-color:rgba(245,245,245,0.95) !important;
  opacity:0.9;
}

html body .main-nav a,
html body .nav-link,
html body .nav-dropdown a,
html body .btn,
html body .link-arrow{
  border-bottom:0 !important;
}

/* =========================
   14) Responsive
========================= */

@media (min-width:769px){
  .has-dropdown::after{
    content:"";
    position:absolute;
    left:0;
    top:100%;
    width:100%;
    height:12px;
  }

  .has-dropdown:hover .nav-dropdown{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
  }
}

@media (min-width:880px){
  .evo-step-inner{
    position:sticky;
    top:30vh;
  }
}

@media (max-width:900px){
  .main-nav ul{
    display:flex;
    flex-direction:column;
    gap:16px;
    align-items:center;
    width:100%;
  }

  .main-nav .nav-item{
    display:flex;
    flex-direction:column;
    align-items:center;
    width:100%;
  }

  .main-nav .nav-link{
    width:100%;
    text-align:center;
  }

  .main-nav .nav-dropdown{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    width:fit-content;
    margin-top:8px;
    margin-left:132px;
  }

  .main-nav .nav-dropdown a{
    display:block;
    text-align:left;
  }

  .projects-grid{
    grid-template-columns:repeat(2, 1fr);
    grid-auto-rows:auto;
  }

  #urbanisme .projects-grid{
    grid-template-columns:repeat(2, 1fr);
    grid-auto-flow:row;
  }

  #urbanisme .projects-grid .project-thumb:nth-child(6){
    grid-column:1 / -1;
    grid-row:4;
  }

  #urbanisme .projects-grid .project-thumb:nth-child(7){
    grid-column:2;
    grid-row:3;
  }

  #urbanisme .projects-grid .project-thumb:nth-child(5){
    grid-column:1;
    grid-row:3;
  }

  #architecture{ overflow-x:hidden; }

  #architecture .projects-grid{
    width:100%;
    box-sizing:border-box;
    grid-auto-flow:dense;
  }

  #architecture .projects-grid .thumb-wide3{
    grid-column:1 / -1;
    width:auto;
    max-width:100%;
    margin:0;
    left:auto;
    right:auto;
    transform:none;
    aspect-ratio:6 / 2;
  }

  .projects-grid > .project-thumb:nth-child(9){ display:none; }

  .project-thumb{
    height:auto;
    min-height:0;
    aspect-ratio:3 / 2;
  }

  .project-thumb img,
  .project-thumb video{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }

  .contact-hero-wrapper{
    margin:0;
    padding:0;
    overflow:hidden;
  }

  .contact-hero{
    width:100%;
    margin:0;
    left:0;
    right:0;
    transform:none;
    min-height:0;
    height:70svh;
    margin:16px 0;
    border-radius:0;
    background-size:cover;
    background-position:center;
  }
}

@media (max-width:880px){
  .section-split{
    flex-direction:column;
    gap:40px;
  }
}

@media (max-width:768px){
  .logo img{ height:32px; }

  .grid.three{ grid-template-columns:minmax(0,1fr); }
  .grid.two{ grid-template-columns:minmax(0,1fr); }

  .header-inner{ height:64px; }

  .main-nav{
    position:absolute;
    inset:64px 0 auto 0;
    background:var(--bg-main);
    flex-direction:column;
    padding:16px 24px 24px;
    border-bottom:1px solid var(--border-subtle);
    display:none;
    z-index:9999;
  }

  .main-nav a{ color:var(--text-main); }

  .main-nav.is-open{ display:flex; }
  .nav-toggle{ display:inline-flex; }

  .has-dropdown{
    flex-direction:column;
    align-items:flex-start;
  }

  .nav-dropdown{
    position:static;
    opacity:1;
    transform:none;
    pointer-events:auto;
    padding:4px 0 0;
    background:transparent;
    border:none;
  }

  .nav-dropdown a{ color:var(--text-main); }

  .hero-large h1{ font-size:36px; }
  .hero-large p{ font-size:16px; }
  .hero-logo img{ max-width:280px; max-height:90px; }

  .evo-step p{
    display:none;
  }

  .evolution-layout{
    grid-template-columns:1fr;
    row-gap:140px;
    overflow:visible;
  }

  .evo-sticky{
    grid-column:1;
    position:sticky;
    top:96px;
    height:44vh;
    min-height:220px;
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:2;
  }

  .evo-image{
    max-width:360px;
    width:100%;
    margin:0 auto;
  }

  .evo-step{
    grid-column:1;
    max-width:100%;
    margin:0 auto;
    text-align:center;
    min-height:120vh;
  }

  .evo-step:nth-of-type(1),
  .evo-step:nth-of-type(2),
  .evo-step:nth-of-type(3),
  .evo-step:nth-of-type(4){
    grid-column:1;
    grid-row:auto;
    margin:0 auto;
    text-align:center;
  }

  .evo-step-inner{
    position:sticky;
    top:62vh;
  }

  .container,
  .container-large,
  .section-inner,
  .section-inner-large{
    padding-left:20px;
    padding-right:20px;
  }

  .section-split{
    flex-direction:column;
    gap:40px;
  }

  .contact-form{
    width:100%;
    max-width:none;
    align-self:stretch;
  }

  .form-row input,
  .form-row textarea{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
  }

  .map-wrapper{
    width:100%;
    max-width:100%;
  }
.section-split > div{
  min-width:0;
  }

}

@media (max-width:600px){
  .contact-hero-content{
    padding:220px 0 64px;
	padding-left: 20px;
	margin: 20px;
  }
}

@media (min-width:600px) and (max-width:900px){
  .form-row label{
    font-size:14px;
  }

  .form-row input,
  .form-row textarea{
    font-size:16px;
    padding:12px 14px;
  }

  .btn.primary{
    padding:12px 18px;
  }
  .contact-form{
  gap:18px;
  }

}
@media (min-width:769px){
  .project-meta{
    padding:18px 24px;
  }
}

