/* styles.css */

/* =========================
  WhatsApp Floating Button
========================= */
.float-wa {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 24px;
    left: 24px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: none;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .3s ease, box-shadow .3s ease;
}
.float-wa:hover {
    transform: scale(1.1);
    box-shadow: none;
}
.wa-badge {
    position: absolute;
    top: 0;
    right: 0;
    width: 20px;
    height: 20px;
    background-color: #ff0000;
    color: #fff;
    border-radius: 50%;
    font-size: 12px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
/* =========================
  Color Variables & Theme
  - Black: #181A1D
  - Cream: #FBF7F2
  - Terracotta: #E46440
  - Sandstone: #D9B99B
  - Olive: #3F4F3C
========================= */
:root{
  --black:#181A1D;
  --cream:#FBF7F2;
  --terracotta:#E46440;
  --sandstone:#D9B99B;
  --olive:#3F4F3C;

  --text: var(--black);
  --muted: rgba(24,26,29,.65);

  --border: rgba(24,26,29,.12);
  --border-light: rgba(251,247,242,.14);

  --radius: 10px;
  --shadow: 0 18px 40px rgba(24,26,29,.10);

  --container: 1240px;

  --pad-m: 24px;
  --pad-t: 48px;
  --pad-d: 96px;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
}
body{
  margin:0;
  font-family: "Outfit", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--cream);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
  position: relative;
}

img{max-width:100%; display:block; height: auto;}
a{color:inherit; text-decoration:none}
button{font:inherit}

/* =========================
  Layout utilities
========================= */
.container{
  width: min(var(--container), calc(100% - 2*var(--pad-m)));
  margin-inline:auto;
  box-sizing: border-box;
  padding: 0 20px;
}
@media (min-width: 768px){
  .container{ 
    width: min(var(--container), calc(100% - 2*var(--pad-t))); 
    padding: 0 32px;
  }
}
@media (min-width: 1200px){
  .container{ 
    width: min(var(--container), calc(100% - 2*var(--pad-d))); 
    padding: 0 48px;
  }
}

.section{
  padding: 84px 0;
  width: 100%;
  box-sizing: border-box;
}
@media (min-width: 768px){
  .section{ padding: 110px 0; }
}

.section-cream{ background: var(--cream); }
.section-sandstone{ background: color-mix(in oklab, var(--sandstone) 30%, var(--cream)); }
.section-dark{ background: var(--black); }

.section-quote{
  background:
    radial-gradient(900px 500px at 30% 20%, color-mix(in oklab, var(--sandstone) 55%, transparent) 0%, transparent 60%),
    radial-gradient(700px 500px at 80% 40%, color-mix(in oklab, var(--sandstone) 35%, transparent) 0%, transparent 65%),
    linear-gradient(135deg, color-mix(in oklab, var(--sandstone) 40%, var(--cream)) 0%, var(--cream) 55%, color-mix(in oklab, var(--sandstone) 30%, var(--cream)) 100%);
}

.center{
  display:flex; 
  justify-content:center;
  padding: 0 20px;
}
@media (min-width: 768px) {
  .center {
    padding: 0 40px;
  }
}
.stack{display:grid; gap:14px}
.text-muted{color: var(--muted)}
.text-olive{color: var(--olive)}
.text-terracotta{color: var(--terracotta)}
.text-cream{color: var(--cream)}
.text-cream-muted{color: rgba(251,247,242,.70)}
.text-footer-muted{color: rgba(251,247,242,.50)}

/* =========================
  Typography scale
========================= */
.label-sm{
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 600;
}

.headline-xl{
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05;
  font-weight: 300;
  letter-spacing: -0.02em;
  margin: 12px 0 0;
}
.headline-lg{
  font-size: clamp(30px, 3.6vw, 52px);
  line-height: 1.12;
  font-weight: 300;
  letter-spacing: -0.02em;
  margin: 10px 0 0;
}
.headline-md{
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.18;
  font-weight: 300;
  letter-spacing: -0.02em;
  margin: 8px 0 0;
}
.body-lg{
  font-size: 18px;
  line-height: 1.8;
  font-weight: 300;
  margin: 0;
}
.body-md{
  font-size: 16px;
  line-height: 1.8;
  font-weight: 300;
  margin: 0;
}

.hide-mobile{display:none}
@media(min-width: 768px){ .hide-mobile{display:block} }

.section-head{
  text-align:center;
  max-width: 860px;
  margin: 0 auto 56px;
  padding: 0 20px;
}
@media (min-width: 768px) {
  .section-head {
    padding: 0 40px;
  }
}

/* =========================
  Buttons
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border: 1px solid transparent;
  padding: 14px 22px;
  border-radius: 0;
  cursor:pointer;
  transition: transform .25s ease, background-color .25s ease, border-color .25s ease, color .25s ease, opacity .25s ease;
  font-weight: 600;
  text-decoration: none;
  outline: none;
}
.btn:focus,
.btn:active{
  outline: none;
  box-shadow: none;
}
.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0px); }

.btn-primary{
  background: var(--terracotta);
  color: var(--cream);
}
.btn-primary:hover{ background: color-mix(in oklab, var(--terracotta) 92%, black); }

.btn-outline{
  background: transparent;
  color: var(--cream);
  border-color: rgba(251,247,242,.45);
}
.btn-outline:hover{
  background: rgba(251,247,242,.08);
  border-color: rgba(251,247,242,.75);
}

.btn-md{ padding: 12px 18px; font-size: 14px; }
.btn-xl{ padding: 16px 26px; font-size: 14px; letter-spacing: .06em; text-transform: uppercase; }
.btn-sm{ padding: 8px 14px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }

/* =========================
  Reveal animations
========================= */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
  will-change: auto;
}

/* =========================
  Header
========================= */
.site-header{
  position: fixed;
  top:0; left:0; right:0;
  z-index: 999;
  padding: 18px 0;
  transition: background-color .35s ease, box-shadow .35s ease, padding .35s ease, backdrop-filter .35s ease;
  background: transparent;
  width: 100%;
  max-width: 100vw;
}
.site-header.is-scrolled{
  padding: 14px 0;
  background: rgba(251,247,242,.95);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(24,26,29,.08);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 0 8px;
}

.logo{
    padding: 0 2px;
    gap: 8px;
  text-decoration: none;
  color: var(--cream);
  line-height: 1.2;
  min-width: 0;
  flex-shrink: 1;
}
.logo-main{
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--cream);
@media (max-width: 1023px){
  .logo{
    margin-left: 2px;
    flex: 1;
    min-width: 0;
  }
}
  text-shadow: 0 1px 2px rgba(0,0,0,0.3), 0 0 1px rgba(0,0,0,0.2);
  white-space: nowrap;
}
.site-header.is-scrolled .logo-main{
  color: var(--black);
  text-shadow: 0 1px 1px rgba(255,255,255,0.5), 0 0 1px rgba(0,0,0,0.1);
}
.logo-sub{
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: rgba(251,247,242,.75);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 180px;
}
.site-header.is-scrolled .logo-sub{
  color: rgba(24,26,29,.70);
}
@media (min-width: 480px) {
  .logo-main {
    font-size: 15px;
@media (max-width: 1023px){
  .logo-sub{
    margin-top: 2px;
    max-width: 240px;
  }
}
  }
  .logo-sub {
    font-size: 11px;
    max-width: 220px;
  }
}
@media (min-width: 768px) {
  .logo-main {
    font-size: 16px;
  }
  .logo-sub {
    font-size: 12px;
    max-width: 280px;
  }
}
@media (min-width: 1024px) {
  .logo-sub {
    max-width: none;
  }
}

.nav-desktop{
  display:none;
  gap: 18px;
  align-items:center;
}
.nav-desktop a{
  font-size: 11px;
  letter-spacing: .08em;
  color: rgba(251,247,242,.90);
  position: relative;
  text-transform: uppercase;
  white-space: nowrap;
}
.site-header.is-scrolled .nav-desktop a{
  color: rgba(24,26,29,.80);
}
.nav-desktop a:hover{
  color: var(--terracotta);
}

.header-actions{
  display:flex;
  align-items:center;
  gap: 8px;
  flex-shrink: 0;
}

.lang-toggle{
  background: transparent;
  border: 1px solid rgba(251,247,242,.25);
  padding: 5px 10px;
  font-size: 10px;
@media (max-width: 1023px){
  .header-actions{
    gap: 4px;
    padding-right: 0;
    flex-shrink: 0;
  }
}
  font-weight: 600;
  color: var(--cream);
  cursor: pointer;
  transition: var(--transition);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  min-width: 32px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.site-header.is-scrolled .lang-toggle{
  border-color: rgba(24,26,29,.18);
  color: var(--black);
}
.lang-toggle:hover{
  background: rgba(251,247,242,.1);
  border-color: var(--terracotta);
}
.site-header.is-scrolled .lang-toggle:hover{
  background: rgba(24,26,29,.05);
}

.icon-btn{
  background: transparent;
  border: 1px solid rgba(251,247,242,.25);
  width: 36px;
  height: 36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: var(--cream);
  cursor: pointer;
  flex-shrink: 0;
  outline: none;
}
.icon-btn:focus,
.icon-btn:active{
  outline: none;
  box-shadow: none;
}
.site-header.is-scrolled .icon-btn{
  border-color: rgba(24,26,29,.18);
  color: var(--black);
}

.nav-toggle{ display:inline-flex; flex-direction:column; gap:6px; padding: 0 10px; }
.nav-toggle-bar{
  display:block;
  width: 18px;
  height: 2px;
  background: currentColor;
  opacity:.9;
@media (max-width: 1023px){
  .nav-toggle{ padding: 0 2px; }
}
}

@media(min-width: 1024px){
  .nav-desktop{ display:flex; }
  .nav-toggle{ display:none; }
}

/* Mobile dropdown */
.nav-mobile{
  display:none;
  background: rgba(24,26,29,.95);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(251,247,242,.12);
  width: 100%;
  overflow: hidden;
}
.nav-mobile.is-open{ display:block; }
.nav-mobile-inner{
  padding: 18px 20px 18px;
  display:grid;
  gap: 14px;
  background: transparent !important;
}
.nav-mobile .container{
  background: transparent !important;
  padding: 0 !important;
}
.nav-mobile .btn{
  margin-top: 0;
  margin-bottom: 0;
  justify-self: stretch;
  width: 100%;
}
.nav-mobile a{
  color: rgba(251,247,242,.92);
  font-size: 14px;
  letter-spacing: .04em;
  background: transparent;
}
.nav-mobile .lang-toggle{
  justify-self: start;
  margin-bottom: 12px;
  margin-top: 8px;
  border: 1px solid rgba(251,247,242,.50) !important;
  color: var(--cream) !important;
  background: transparent !important;
}
.nav-mobile .lang-toggle .lang-code{
  color: var(--cream) !important;
}
.nav-mobile .lang-toggle:hover{
  background: rgba(251,247,242,.15) !important;
  border-color: var(--terracotta) !important;
}

/* =========================
  Hero
========================= */
.hero{
  position:relative;
  min-height: 100vh;
  display:flex;
  align-items:center;
  background: var(--black);
  overflow:hidden;
  padding-top: 80px;
}
.hero-bg{ position:absolute; inset:0; }
.hero-slide{
  position:absolute;
  inset:0;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  will-change: opacity;
}
.hero-slide.is-active{ opacity: 1; }
.hero-overlay{
  position:absolute;
  inset:0;
  background: rgba(24,26,29,.55);
}
.hero-content{
  position:relative;
  z-index: 2;
  text-align:center;
  padding-top: 92px;
  padding-bottom: 72px;
  width: 100%;
  box-sizing: border-box;
}
.hero-label{ color: rgba(251,247,242,.80); margin-bottom: 18px; }
.hero-content .headline-xl{ color: var(--cream); }
.hero-sub{ color: rgba(251,247,242,.80); max-width: 820px; margin: 20px auto 0; }

.hero-cta{
  margin-top: 34px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 14px;
  padding: 0 20px;
}
@media(min-width: 640px){
  .hero-cta{ 
    flex-direction:row; 
    gap: 16px;
    padding: 0 40px;
  }
}

.hero-indicators{
  margin-top: 34px;
  margin-bottom: 0;
  display:flex;
  gap: 10px;
  justify-content:center;
}
.dot{
  width: 24px;
  height: 4px;
  border-radius: 999px;
  border: 0;
  background: rgba(251,247,242,.35);
  cursor:pointer;
  transition: width .35s ease, background-color .35s ease;
}
.dot.is-active{
  width: 44px;
  background: var(--terracotta);
}

.hero-scroll{
  position:relative;
  margin-top: 40px;
  margin-inline:auto;
  width: fit-content;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 8px;
  color: rgba(251,247,242,.75);
}
.hero-scroll .chev{
  font-size: 20px;
  animation: float 2.2s ease-in-out infinite;
}
@keyframes float{
  0%,100%{ transform: translateY(0); opacity:.75; }
  50%{ transform: translateY(6px); opacity:1; }
}

/* =========================
  Trust strip
========================= */
.trust-strip{
  background: color-mix(in oklab, var(--cream) 92%, white);
  border-top: 1px solid rgba(217,185,155,.20);
  border-bottom: 1px solid rgba(217,185,155,.20);
  padding: 18px 0;
}
.trust-inner{
  display:flex;
  flex-direction:column;
  gap: 14px;
  align-items:center;
  justify-content:center;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 768px){
  .trust-inner{ flex-direction:row; gap: 38px; }
}
.trust-item{
  display:flex;
  align-items:center;
  gap: 10px;
  font-weight: 600;
  color: rgba(24,26,29,.80);
}
.trust-icon{ color: var(--terracotta); }

/* =========================
  Cards grids
========================= */
.grid{display:grid; gap: 18px; width: 100%; box-sizing: border-box; padding: 0 4px;}
@media (min-width: 768px) {
  .grid {
    padding: 0 8px;
  }
}
.cards-3{ grid-template-columns: 1fr; }
@media(min-width: 720px){ .cards-3{ grid-template-columns: repeat(2, 1fr); } }
@media(min-width: 1100px){ .cards-3{ grid-template-columns: repeat(3, 1fr); } }

.card{
  background: white;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid var(--border);
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transform: translateY(0);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  width: 100%;
  box-sizing: border-box;
}
.card:hover{
  transform: translateY(-6px);
  box-shadow: var(--shadow);
  border-color: rgba(228,100,64,.25);
}
.card-media{
  height: 220px;
  position:relative;
  background-image: var(--card-bg);
  background-size: cover;
  background-position:center;
}
.card-media-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(to top, rgba(24,26,29,.72), rgba(24,26,29,.18), transparent);
}
.card-title{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  margin:0;
  color: var(--cream);
  font-weight: 600;
  font-size: 18px;
}
.card-body{
  padding: 16px 18px 18px;
}
.card-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  margin-top: 12px;
  padding: 12px 20px;
  background: var(--terracotta);
  color: var(--cream);
  font-weight: 600;
  border-radius: 0;
  transition: transform .25s ease, background-color .25s ease;
  text-decoration: none;
}
.card-link:hover{ 
  background: color-mix(in oklab, var(--terracotta) 92%, black);
  transform: translateY(-1px);
}

.card.is-hidden{ display:none; }
.card.is-unhidden{ display:block; }

/* =========================
  Materials
========================= */
.materials{
  display:grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items:start;
  width: 100%;
  box-sizing: border-box;
  padding: 0 12px;
}
@media (min-width: 768px) {
  .materials {
    padding: 0 20px;
  }
}
@media(min-width: 1024px){
  .materials{
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.materials-tabs{
  display:none;
}
.tab{
  border: 2px solid transparent;
  background: transparent;
  padding: 14px 18px;
  text-align:left;
  font-weight: 600;
  color: rgba(24,26,29,.62);
  border-left: 2px solid transparent;
  cursor:pointer;
  transition: background-color .25s ease, color .25s ease, padding-left .25s ease, border-color .25s ease;
  flex: 0 0 auto;
  outline: none;
}
.tab:focus,
.tab:active{
  outline: none;
  box-shadow: none;
}
@media(min-width: 1024px){
  .tab{ width: 100%; border-left: 2px solid transparent; }
}
.tab:hover{
  color: rgba(24,26,29,.85);
  background: rgba(255,255,255,.55);
}
.tab.is-active{
  color: rgba(24,26,29,.90);
  background: white;
  border-left-color: var(--terracotta);
  padding-left: 24px;
}

.materials-panel{
  display:grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items:center;
  width: 100%;
  box-sizing: border-box;
  max-width: 1000px;
  margin: 0 auto;
}
@media(min-width: 768px){
  .materials-panel{
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
  }
}
.materials-media{
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(24,26,29,.10);
  background: rgba(24,26,29,.04);
  width: 100%;
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.materials-media a {
  display: block;
  width: 100%;
  height: 100%;
}
.materials-media img{ 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
  display: block;
}
.material-nav{
  display: none;
}
.materials-name-nav{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 8px;
  padding-bottom: 12px;
}
.material-name-nav-btn{
  background: transparent;
  border: 0;
  color: var(--terracotta);
  width: auto;
  height: auto;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: 300;
  cursor: pointer;
  transition: transform .25s ease, opacity .25s ease;
  flex-shrink: 0;
  padding: 8px;
  outline: none;
  -webkit-tap-highlight-color: transparent;
}
.material-name-nav-btn:focus,
.material-name-nav-btn:active{
  outline: none;
  border: none;
  box-shadow: none;
}
.material-name-nav-btn:hover{
  transform: scale(1.15);
  opacity: 0.8;
}
.materials-actions{
  margin-top: 28px;
  padding-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.materials-collection-btn{
  margin-bottom: 0;
}

.bullets{
  list-style:none;
  padding:0;
  margin: 18px 0 0;
  display:grid;
  gap: 10px;
}
.bullets li{
  display:flex;
  align-items:center;
  gap: 12px;
}
.bullet-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--terracotta);
  flex-shrink: 0;
}

/* =========================
  Why us
========================= */
.reasons-4{ grid-template-columns: 1fr; }
@media(min-width: 768px){ .reasons-4{ grid-template-columns: repeat(2, 1fr); } }
@media(min-width: 1100px){ .reasons-4{ grid-template-columns: repeat(4, 1fr); } }

.reason-card{
  border: 1px solid rgba(251,247,242,.10);
  padding: 22px;
  text-align:center;
  transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease, background-color .35s ease;
  width: 100%;
  box-sizing: border-box;
}
.reason-card:hover{
  border-color: rgba(228,100,64,.45);
  transform: translateY(-6px);
  box-shadow: 0 14px 30px rgba(228,100,64,.06);
}
.reason-icon{
  width: 64px;
  height: 64px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  margin: 0 auto 14px;
  background: rgba(251,247,242,.06);
  color: var(--terracotta);
  font-size: 22px;
}
.reason-icon svg{
  width: 24px;
  height: 24px;
  color: var(--terracotta);
}
.reason-title{
  margin: 0 0 10px;
  color: var(--cream);
  font-size: 18px;
  font-weight: 600;
}
.reason-desc{
  margin:0;
  color: rgba(251,247,242,.60);
  line-height: 1.7;
  font-size: 14px;
}

/* =========================
  Projects
========================= */
.projects-head{
  display:flex;
  flex-direction:column;
  gap: 18px;
  align-items:flex-start;
  justify-content:space-between;
  margin-bottom: 28px;
  padding: 0 12px;
}
@media (min-width: 768px) {
  .projects-head {
    padding: 0 20px;
  }
}
@media(min-width: 860px){
  .projects-head{
    flex-direction:row;
    align-items:flex-end;
  }
}
.chips{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  padding: 4px 0;
}
.chip{
  border: 1px solid rgba(251,247,242,.22);
  background: transparent;
  color: rgba(251,247,242,.60);
  padding: 10px 14px;
  cursor:pointer;
  transition: transform .25s ease, border-color .25s ease, color .25s ease, background-color .25s ease;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  outline: none;
}
.chip:focus,
.chip:active{
  outline: none;
  box-shadow: none;
}
.chip:hover{
  transform: translateY(-1px);
  border-color: rgba(251,247,242,.38);
  color: rgba(251,247,242,.85);
}
.chip.is-active{
  background: var(--terracotta);
  border-color: var(--terracotta);
  color: var(--cream);
}

.projects-grid{
  grid-template-columns: 1fr;
  gap: 18px;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 768px){ .projects-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(min-width: 1100px){ .projects-grid{ grid-template-columns: repeat(3, 1fr); } }

.project-card{
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
  cursor:pointer;
  transform: translateY(0);
  transition: transform .35s ease;
  width: 100%;
  box-sizing: border-box;
}
.project-card:hover{ transform: translateY(-6px); }
.project-card img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  transition: transform .7s ease;
}
.project-card:hover img{ transform: scale(1.08); }
.project-overlay{
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(24,26,29,.92), rgba(24,26,29,.22), transparent);
  opacity:.65;
  transition: opacity .35s ease;
}
.project-card:hover .project-overlay{ opacity:.82; }
.project-meta{
  position:absolute;
  left: 18px; right: 18px; bottom: 18px;
  color: var(--cream);
}
.project-meta h3{
  margin: 6px 0 0;
  font-size: 18px;
  font-weight: 600;
}
.project-meta p{
  margin: 6px 0 0;
  color: rgba(251,247,242,.62);
  font-size: 13px;
}
.project-card::after{
  content:"";
  position:absolute; inset:0;
  border: 2px solid transparent;
  transition: border-color .35s ease;
}
.project-card:hover::after{ border-color: rgba(228,100,64,.45); }
.project-card.is-hidden{ display:none; }

/* =========================
  Process steps
========================= */
.process-head{
  text-align:center; 
  margin-bottom: 30px;
  padding: 0 20px;
}
@media (min-width: 768px) {
  .process-head {
    padding: 0 40px;
  }
}
.process-steps{
  position:relative;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 768px){
  .process-steps{
    grid-template-columns: repeat(5, 1fr);
    gap: 18px;
  }
}
.process-line{
  display:none;
}
@media(min-width: 768px){
  .process-line{
    display:block;
    position:absolute;
    top: 32px;
    left: 10%;
    right: 10%;
    height: 1px;
    background: rgba(63,79,60,.20);
  }
}
.step{text-align:center}
.step-bubble{
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background: white;
  border: 2px solid rgba(228,100,64,.35);
  display:grid;
  place-items:center;
  margin: 0 auto 12px;
  transition: transform .3s ease, border-color .3s ease;
}
.step-bubble span{
  font-weight: 300;
  color: var(--terracotta);
  font-size: 18px;
}
.step-bubble:hover{ transform: scale(1.06); border-color: var(--terracotta); }
.step-title{
  font-weight: 600;
  margin-bottom: 6px;
}
.step-desc{
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}

/* =========================
  Testimonials
========================= */
.testimonials{
  max-width: 980px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
  padding: 0 20px;
}
@media (min-width: 768px) {
  .testimonials {
    padding: 0 40px;
  }
}
.testimonial{ display:none; }
.testimonial.is-active{ display:block; }
.testimonial-card{
  border-radius: 18px;
  background: rgba(251,247,242,.05);
  border: 1px solid rgba(251,247,242,.10);
  padding: 26px;
}
@media(min-width: 768px){
  .testimonial-card{ padding: 42px; }
}
.avatar-ghost{
  width: 92px;
  height: 92px;
  border-radius: 999px;
  border: 4px solid rgba(228,100,64,.30);
  background: rgba(24,26,29,.55);
  display:grid;
  place-items:center;
  color: var(--terracotta);
  font-size: 30px;
  margin: 0 auto 18px;
}
.avatar-ghost svg{
  width: 30px;
  height: 30px;
  color: var(--terracotta);
}
@media(min-width: 768px){
  .avatar-ghost{
    width: 122px;
    height: 122px;
    font-size: 44px;
    margin: 0 0 18px;
  }
  .avatar-ghost svg{
    width: 44px;
    height: 44px;
  }
  .testimonial-card{ display:grid; gap: 12px; }
}
.stars{
  color: var(--terracotta);
  letter-spacing: 2px;
  text-align:center;
}
@media(min-width: 768px){ .stars{ text-align:left; } }

blockquote{
  margin: 14px 0 0;
  color: rgba(251,247,242,.90);
  font-weight: 300;
  line-height: 1.6;
  font-size: 20px;
  font-style: italic;
  text-align:center;
}
@media(min-width: 768px){
  blockquote{ font-size: 26px; text-align:left; }
}
.author{
  margin-top: 16px;
  font-weight: 600;
  color: var(--cream);
  text-align:center;
}
@media(min-width: 768px){ .author{ text-align:left; } }

.testimonial-nav{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 16px;
}
.circle-btn{
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(251,247,242,.30);
  color: rgba(251,247,242,.70);
  cursor:pointer;
  transition: transform .25s ease, border-color .25s ease, color .25s ease;
  font-size: 22px;
}
.circle-btn:hover{
  transform: scale(1.06);
  border-color: rgba(228,100,64,.70);
  color: var(--terracotta);
}
.dots{
  display:flex;
  gap: 8px;
}
.dots button{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 0;
  background: rgba(251,247,242,.30);
  cursor:pointer;
  transition: width .35s ease, background-color .35s ease;
}
.dots button.is-active{
  width: 34px;
  background: var(--terracotta);
}

/* =========================
  FAQ
========================= */
.faq{
  max-width: 860px;
  margin: 0 auto;
  display:grid;
  gap: 12px;
  width: 100%;
  box-sizing: border-box;
  padding: 0 20px;
}
@media (min-width: 768px) {
  .faq {
    padding: 0 40px;
  }
}
.faq-item{
  background: white;
  border: 1px solid var(--border);
  padding: 0 18px;
  transition: border-color .25s ease, box-shadow .25s ease;
  user-select: none;
  -webkit-user-select: none;
}
.faq-item[open]{
  border-color: rgba(63,79,60,.35);
  box-shadow: 0 12px 30px rgba(24,26,29,.06);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding: 18px 30px 18px 0;
  font-weight: 600;
  font-size: 18px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content: '›';
  position: absolute;
  right: 0;
  color: var(--terracotta);
  font-size: 24px;
  font-weight: 300;
  transition: transform .25s ease;
}
.faq-item[open] summary::after{
  transform: rotate(90deg);
}
.faq-item summary:hover{ color: var(--terracotta); }
.faq-body{
  padding: 0 0 18px;
  color: var(--muted);
  line-height: 1.8;
}

/* =========================
  Quote form
========================= */
.quote-card{
  max-width: 980px;
  margin: 0 auto;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(24,26,29,.10);
  border-radius: 18px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(8px);
  width: 100%;
  box-sizing: border-box;
  padding: 0 8px;
}
@media (min-width: 768px) {
  .quote-card {
    padding: 0 16px;
  }
}
.quote-form{ padding: 22px; }
@media(min-width: 768px){
  .quote-form{ padding: 42px; }
}
.form-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 768px){
  .form-grid{
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}
.field{ display:grid; gap: 8px; }
.field label{ font-weight: 600; font-size: 13px; color: rgba(24,26,29,.88); }
.field input,
.field select,
.field textarea{
  padding: 14px 14px;
  border-radius: 14px;
  border: 2px solid rgba(24,26,29,.12);
  background: var(--cream);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
  font-size: 14px;
  width: 100%;
  box-sizing: border-box;
  font-family: inherit;
}
.field textarea{ resize: none; }
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color: rgba(228,100,64,.75);
  box-shadow: 0 10px 24px rgba(228,100,64,.10);
}
.field-error{
  min-height: 16px;
  font-size: 12px;
  color: color-mix(in oklab, var(--terracotta) 80%, black);
}

.field-span-2{ grid-column: 1 / -1; }

.pill-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media(min-width: 640px){
  .pill-grid{ grid-template-columns: repeat(4, 1fr); }
}
@media(min-width: 1024px){
  .pill-grid{ grid-template-columns: repeat(7, 1fr); }
}
.pill{
  padding: 12px 10px;
  border-radius: 14px;
  border: 2px solid rgba(24,26,29,.12);
  background: var(--cream);
  color: rgba(24,26,29,.62);
  font-weight: 600;
  cursor:pointer;
  transition: border-color .2s ease, background-color .2s ease, color .2s ease, transform .2s ease;
  font-size: 13px;
}
.pill:hover{
  transform: translateY(-1px);
  border-color: rgba(63,79,60,.35);
  color: rgba(24,26,29,.85);
}
.pill.is-active{
  border-color: rgba(228,100,64,.75);
  background: rgba(228,100,64,.08);
  color: var(--terracotta);
}

.form-actions{
  margin-top: 18px;
  display:grid;
  gap: 10px;
  justify-items:center;
}
.fineprint{
  margin: 0;
  font-size: 12px;
  text-align:center;
}
.toast{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(63,79,60,.25);
  background: rgba(63,79,60,.08);
  color: rgba(24,26,29,.82);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

/* =========================
  Contact
========================= */
.contact-grid{
  grid-template-columns: 1fr;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 640px){ .contact-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(min-width: 1100px){ .contact-grid{ grid-template-columns: repeat(4, 1fr); } }

.contact-card{
  border: 1px solid rgba(251,247,242,.10);
  padding: 20px;
  text-align:center;
  transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
  text-decoration: none;
  display: block;
  width: 100%;
  box-sizing: border-box;
}
.contact-card:hover{
  transform: translateY(-6px);
  border-color: rgba(228,100,64,.50);
  box-shadow: 0 14px 28px rgba(228,100,64,.07);
}
.contact-icon{
  width: 52px; height: 52px;
  border-radius: 999px;
  margin: 0 auto 12px;
  display:grid;
  place-items:center;
  background: rgba(251,247,242,.05);
  color: var(--terracotta);
  font-size: 18px;
}
.contact-icon svg{
  width: 24px;
  height: 24px;
  color: var(--terracotta);
}
.contact-label{ color: rgba(251,247,242,.55); font-size: 12px; margin-bottom: 8px; }
.contact-value{ color: var(--cream); font-weight: 600; }

/* =========================
  Footer
========================= */
.footer{
  background: rgba(24,26,29,1);
  padding: 64px 0 30px;
  border-top: 1px solid rgba(251,247,242,.08);
  width: 100%;
  box-sizing: border-box;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 28px;
  width: 100%;
  box-sizing: border-box;
}
@media(min-width: 900px){
  .footer-grid{
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr;
    align-items:start;
    gap: 24px;
  }
}
.logo-footer{ color: var(--cream); }
.footer-col h4{
  margin: 0 0 12px;
  color: var(--cream);
  font-weight: 600;
}
.footer-col a{
  display:block;
  padding: 6px 0;
  color: rgba(251,247,242,.50);
  transition: color .2s ease, transform .2s ease;
}
.footer-col a:hover{
  color: var(--terracotta);
  transform: translateX(2px);
}
.footer-brand p{ margin: 12px 0 0; line-height: 1.7; }

.footer-bottom{
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(251,247,242,.10);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 10px;
}
@media(min-width: 768px){
  .footer-bottom{
    flex-direction:row;
    justify-content:space-between;
  }
}
.footer-legal{ display:flex; gap: 18px; }
.footer-legal a:hover{ color: var(--terracotta); }

/* Provide breathing room under fixed header when jumping to anchors */
:target{ scroll-margin-top: 88px; }

/* Accessibility */
button:focus,
a:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
  box-shadow: none;
}
button:active,
a:active {
  outline: none;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
}
* {
  -webkit-tap-highlight-color: transparent;
}

/* Smooth scroll */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  
  * {
    transition: none !important;
    animation: none !important;
  }
}
