@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:wght@500;600;700&display=swap');

:root{
  --cream:#f4eee6;
  --paper:#fffaf3;
  --tan:#c9ab8d;
  --brown:#6f5844;
  --dark:#171411;
  --muted:#6f655d;
}

*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:Inter, sans-serif;
  color:var(--dark);
  background:var(--cream);
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  width:100%;
  display:block;
}

/* HEADER */

.header{
  height:90px;
  padding:0 7%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(255,250,243,.92);
  backdrop-filter:blur(14px);
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:1px solid rgba(111,88,68,.14);
}

.logo{
  display:flex;
  flex-direction:column;
  align-items:center;
  line-height:.95;
  letter-spacing:6px;
}

.logo span{
  font-family:"Playfair Display", serif;
  font-size:34px;
}

.logo small{
  margin-top:8px;
  font-size:11px;
  letter-spacing:5px;
}

.nav{
  display:flex;
  gap:38px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  letter-spacing:1.3px;
}

.nav a{
  position:relative;
}

.nav a::after{
  content:"";
  position:absolute;
  height:1px;
  left:0;
  right:100%;
  bottom:-8px;
  background:var(--dark);
  transition:.25s ease;
}

.nav a:hover::after{
  right:0;
}

.header-btn,
.btn,
.contact-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 25px;
  border-radius:2px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  letter-spacing:.8px;
}

.header-btn,
.primary,
.contact-btn{
  background:var(--dark);
  color:white;
}

/* HERO */

.hero{
  min-height:720px;
  display:flex;
  align-items:center;
  padding:90px 9%;
  background:
    linear-gradient(90deg, rgba(20,16,12,.94), rgba(32,26,20,.72) 45%, rgba(32,26,20,.15)),
    url("https://images.unsplash.com/photo-1600566753190-17f0baa2a6c3?auto=format&fit=crop&w=1900&q=85");
  background-size:cover;
  background-position:center;
}

.hero-content{
  max-width:580px;
  color:white;
}

.tag,
.section-label{
  text-transform:uppercase;
  color:var(--tan);
  font-size:12px;
  font-weight:800;
  letter-spacing:5px;
  margin-bottom:18px;
}

.center{
  text-align:center;
}

.hero h1{
  font-family:"Playfair Display", serif;
  font-size:76px;
  line-height:.96;
  font-weight:500;
  margin-bottom:22px;
}

.hero p{
  font-size:17px;
  line-height:1.8;
}

.slogan{
  margin-top:20px;
  font-family:"Playfair Display", serif;
  font-style:italic;
  color:#f2dfc8;
}

.hero-buttons{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  margin-top:34px;
}

.secondary{
  border:1px solid rgba(255,255,255,.8);
  color:white;
}

/* GENERAL */

.section{
  padding:78px 7%;
}

/* SERVICIOS */

.services{
  background:#f4eee6;
  padding:90px 7%;
  text-align:center;
}

.services h2{
  max-width:780px;
  margin:0 auto 65px;
  text-align:center;
  font-family:"Playfair Display", serif;
  font-size:54px;
  line-height:1.08;
  font-weight:500;
}

.service-list,
.service-grid{
  max-width:1100px;
  margin:60px auto 0;
  display:flex;
  flex-direction:column;
  gap:0;
}

/* Oculta fotos dentro de servicios */
#servicios img{
  display:none !important;
}

/* Sirve para service-list y service-grid */
.service-item,
.service-grid article{
  display:grid;
  grid-template-columns:110px 1fr;
  gap:55px;
  align-items:center;
  text-align:left;
  padding:34px 0;
  border-left:0;
  border-top:0;
  border-bottom:1px solid rgba(80,60,45,.18);
}

/* Iconos */
.icon,
.service-grid .icon{
  width:90px;
  height:90px;
  background:#eee7dd;
  color:#765d4b;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:48px;
  line-height:1;
  margin:0;
  min-height:0;
}

/* Títulos de servicios */
.service-item h3,
.service-grid h3{
  font-size:22px;
  text-transform:uppercase;
  letter-spacing:.4px;
  line-height:1.25;
  margin-bottom:12px;
  color:#171513;
  text-align:left;
}

/* Descripción de servicios */
.service-item p,
.service-grid p{
  font-size:16px;
  line-height:1.7;
  color:#4e4740;
  max-width:720px;
  text-align:left;
}

/* SOBRE NOSOTROS */

.about{
  display:grid;
  grid-template-columns:44% 56%;
  background:#e8ddd0;
}

.about-text{
  padding:85px 12%;
}

.about h2,
.contact h2{
  font-family:"Playfair Display", serif;
  font-size:44px;
  line-height:1.08;
  font-weight:500;
  margin-bottom:22px;
}

.about p{
  color:#4f463e;
  line-height:1.8;
  margin-bottom:15px;
}

.about-image{
  min-height:520px;
  background:url("https://images.unsplash.com/photo-1600210491369-e753d80a41f3?auto=format&fit=crop&w=1500&q=85") center/cover;
}

/* CONTACTO */

.contact{
  display:grid;
  grid-template-columns:1.3fr .7fr;
  align-items:center;
  gap:35px;
  padding:75px 7%;
  background:var(--dark);
  color:white;
}

.contact p{
  color:#dfd0be;
  font-size:17px;
  line-height:1.9;
}

.contact-btn{
  background:#ead5bd;
  color:var(--dark);
  width:max-content;
  justify-self:end;
}

/* FOOTER */

.footer{
  background:#0f0d0b;
  color:#d9cbbb;
  padding:32px 7%;
  display:flex;
  justify-content:space-between;
  gap:20px;
  font-size:14px;
}

/* TABLET */

@media(max-width:950px){
  .nav{
    display:none;
  }

  .hero h1{
    font-size:58px;
  }

  .services h2{
    font-size:42px;
  }

  .about,
  .contact{
    grid-template-columns:1fr;
  }

  .contact-btn{
    justify-self:start;
  }
}

/* MOBILE */

@media(max-width:650px){
  .header{
    height:auto;
    padding:18px 5%;
  }

  .logo span{
    font-size:27px;
  }

  .header-btn{
    display:none;
  }

  .hero{
    min-height:660px;
    padding:70px 7%;
  }

  .hero h1{
    font-size:46px;
  }

  .section{
    padding:58px 6%;
  }

  .services{
    padding:70px 7%;
  }

  .services h2{
    font-size:36px;
    margin-bottom:35px;
  }

  .service-list,
  .service-grid{
    margin-top:45px;
  }

  .service-item,
  .service-grid article{
    grid-template-columns:1fr;
    gap:22px;
    text-align:center;
    padding:45px 0;
  }

  .icon,
  .service-grid .icon{
    margin:0 auto;
    width:82px;
    height:82px;
    font-size:44px;
  }

  .service-item h3,
  .service-item p,
  .service-grid h3,
  .service-grid p{
    text-align:center;
  }

  .service-item h3,
  .service-grid h3{
    font-size:23px;
  }

  .service-item p,
  .service-grid p{
    font-size:18px;
  }

  .about-text{
    padding:58px 7%;
  }

  .about h2,
  .contact h2{
    font-size:35px;
  }

  .footer{
    flex-direction:column;
    text-align:center;
  }
}
.icon{
  width:90px;
  height:90px;
  background:#eee7dd;
  color:#765d4b;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:48px;
  line-height:1;
  margin:0;
  min-height:0;
}
.header-socials{
  display:flex;
  gap:12px;
}

.facebook-btn{
  background:#1877F2;
  color:white;
  padding:16px 25px;
  border-radius:2px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  letter-spacing:.8px;
  display:flex;
  align-items:center;
  justify-content:center;
}