
:root{
  --bg:#f5f1ec;
  --ink:#26231f;
  --muted:#726b64;
  --line:#ddd3c9;
  --accent:#8ea8b6;
  --shadow:0 18px 50px rgba(34,27,20,.08);
  --max:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:linear-gradient(180deg,#f7f3ee 0%, #f2ede8 100%);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(var(--max),92vw);margin:0 auto}

.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(16px);
  background:rgba(247,243,238,.78);
  border-bottom:1px solid rgba(221,211,201,.85);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0;
}
.brand{display:flex;align-items:center;gap:16px;min-width:0}
.brand img{width:64px;height:auto}
.brand-name{
  font-size:clamp(18px,2vw,24px);
  letter-spacing:.20em;
  text-transform:uppercase;
  font-weight:500;
  white-space:nowrap;
}
.nav-links{display:flex;gap:24px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.nav-links a{color:#57514a}
.nav-links .cta{
  padding:12px 18px;border-radius:999px;background:var(--accent);color:white;box-shadow:var(--shadow)
}

.hero{padding:34px 0 14px}
.hero-card,
.intro-copy,
.project,
.service,
.instagram-widget-card,
.instagram-fallback a,
.footer-card{
  background:rgba(255,255,255,.76);
  border:1px solid rgba(221,211,201,.9);
  box-shadow:var(--shadow);
}
.hero-card{
  border-radius:30px;
  padding:42px;
}
.eyebrow{
  font-size:12px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:#827b73;
  margin-bottom:16px;
}
.hero-services{
  margin:0 0 32px 0;
  font-size:13px;
  font-weight:400;
  letter-spacing:.12em;
  color:#90867d;
  text-transform:uppercase;
}
h1,h2,h3{
  margin:0;
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  line-height:.96;
  letter-spacing:-.03em;
}
h1{font-size:clamp(54px,7vw,88px);margin-bottom:20px}
.lead{
  color:#5e5852;
  line-height:1.85;
  font-size:clamp(16px,1.9vw,20px);
  max-width:62ch;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.btn{
  padding:14px 20px;border-radius:999px;border:1px solid var(--line);background:white;color:#2d2926;font-weight:500
}
.btn.primary{background:var(--accent);border-color:var(--accent);color:white}

.intro{
  padding:20px 0 42px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
  align-items:stretch;
}
.intro-copy{
  border-radius:30px;
  padding:38px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.intro-copy h2{font-size:clamp(40px,5vw,72px);margin-bottom:16px}
.intro-copy p{
  margin:0;
  color:var(--muted);
  font-size:18px;
  line-height:1.9;
}
.intro-copy .spaced{margin-top:16px}
.intro-photo{
  overflow:hidden;
  border-radius:30px;
  min-height:560px;
}
.intro-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 12%;
}
.names{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 0}
.chip{
  padding:10px 14px;border-radius:999px;background:#f3eee8;border:1px solid var(--line);color:#615b55;font-size:14px
}

.section{padding:18px 0 40px}
.section-head{
  display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:end;margin-bottom:24px
}
.section-head p{margin:0;color:var(--muted);line-height:1.8;font-size:18px}
.section-title{font-size:clamp(40px,5vw,68px)}
.services{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px
}
.service{
  border-radius:22px;
  padding:22px;
}
.service-icon{font-size:22px;margin-bottom:10px}
.service h4{margin:0 0 8px;font-size:18px}
.service p{margin:0;color:var(--muted);line-height:1.7;font-size:15px}

.project{
  display:grid;grid-template-columns:1.28fr .92fr;gap:24px;
  border-radius:30px;
  overflow:hidden;
  margin-bottom:28px;
}
.slider-wrap{position:relative;min-height:560px;background:#ebe4dc}
.slides{display:flex;height:100%;transition:transform .55s ease}
.slide{min-width:100%;height:560px}
.slide img{width:100%;height:100%;object-fit:cover}
.controls{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;pointer-events:none;
}
.controls button{
  pointer-events:auto;width:48px;height:48px;border-radius:50%;
  border:none;background:rgba(255,255,255,.94);color:#222;cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.12);font-size:22px;
}
.project-copy{padding:34px 34px 34px 6px;display:flex;flex-direction:column;justify-content:center}
.project-kicker{
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:#8a837c;margin-bottom:12px
}
.project-copy h3{font-size:50px;margin-bottom:14px}
.project-copy p{margin:0 0 18px;color:#5e5953;line-height:1.9;font-size:17px}
.meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.meta-card{
  border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:rgba(255,255,255,.6)
}
.meta-card span{
  display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#8c867f;margin-bottom:8px
}
.meta-card strong{font-size:14px;color:#38332e}

.section-head.center{
  text-align:center;
  justify-items:center;
}

.instagram-full{
  margin-top:24px;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(221,211,201,.9);
  background:rgba(255,255,255,.75);
  box-shadow:0 18px 50px rgba(34,27,20,.08);
  padding:20px;
}

/* hace que el widget ocupe todo el ancho bonito */
.instagram-full .elfsight-app-1d91bc57-309e-4e02-83c4-3c9df1b73f38{
  width:100% !important;
}
}
.instagram-widget-card{
  border-radius:30px;
  overflow:hidden;
  padding:18px;
}
.instagram-note{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:6px 8px 16px;
  border-bottom:1px solid rgba(221,211,201,.8);
  margin-bottom:16px;
  flex-wrap:wrap;
}
.instagram-note span{
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#8a837c;
}
.instagram-note strong{
  font-size:15px;
  font-weight:500;
  color:#4a443f;
}
.instagram-widget-card .elfsight-app-1d91bc57-309e-4e02-83c4-3c9df1b73f38{
  min-height:420px;
}
.instagram-fallback{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.instagram-fallback a{
  display:block;
  overflow:hidden;
  border-radius:22px;
}
.instagram-fallback img{
  width:100%;
  height:220px;
  object-fit:cover;
  transition:transform .45s ease, opacity .3s ease;
}
.instagram-fallback a:hover img{
  transform:scale(1.03);
  opacity:.96;
}

.footer{padding:10px 0 64px;color:#706a63}
.footer-card{
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:24px;border-radius:26px;
}
.footer-line{font-size:18px;color:#3a3835}
.footer-actions{display:flex;gap:12px;flex-wrap:wrap}

@media (max-width: 1080px){
  .intro,.section-head,.project,.instagram-shell{grid-template-columns:1fr}
  .project-copy{padding:28px}
  .services{grid-template-columns:repeat(2,1fr)}
  .instagram-fallback{grid-template-columns:repeat(3,1fr)}
  .slide,.slider-wrap{height:460px;min-height:auto}
  .intro-photo{min-height:420px}
}
@media (max-width: 700px){
  .nav-inner{flex-direction:column;align-items:flex-start}
  .nav-links{gap:14px}
  .hero-card,.intro-copy{padding:28px}
  .services{grid-template-columns:1fr}
  .instagram-fallback{grid-template-columns:repeat(2,1fr)}
  .intro-photo{min-height:360px}
  .slide,.slider-wrap{height:300px}
  .meta{grid-template-columns:1fr}
  .project-copy h3{font-size:40px}
  .section-head p,.intro-copy p{font-size:16px}
}
