
:root{
  --purple:#211947;
  --purple-dark:#1a1438;
  --gold:#bd985e;
  --gold-soft:#e3c891;
  --cream:#f8f4ed;
  --soft:#d8c8bd;
  --text:#171717;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;min-height:100%;overflow-x:hidden;background:var(--cream);font-family:"Montserrat",Arial,Helvetica,sans-serif;color:var(--text)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.jh-topbar{
  width:100%;
  height:50px;
  background:var(--gold);
  border-top:2px solid #111;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 42px;
  color:#fff;
}
.jh-topbar .cotizar{font-size:18px;text-decoration:underline;text-underline-offset:4px}
.jh-social{display:flex;gap:22px;align-items:center}
.jh-social a{color:#fff;font-size:18px}

.jh-header{background:var(--cream);padding:42px 38px 34px}
.jh-menu{display:grid;grid-template-columns:1fr 280px 1fr;align-items:center;width:100%;gap:24px}
.jh-menu-left,.jh-menu-right{display:flex;align-items:center}
.jh-menu-left{justify-content:flex-start;gap:74px}
.jh-menu-right{justify-content:flex-end;gap:74px}
.jh-menu a{font-size:16px;font-weight:600;color:#111;text-transform:uppercase}
.jh-menu a.active{color:var(--gold);position:relative}
.jh-menu a.active:after{content:"";position:absolute;left:50%;bottom:-18px;width:5px;height:5px;border-radius:50%;background:var(--gold);transform:translateX(-50%)}
.jh-logo{display:flex;justify-content:center}
.jh-logo img{width:235px;height:auto}

.editorial-title,
.editorial-title *,
.hero-title,
.hero-title *,
.section-title,
.section-title *{
  font-family:"Bodoni Moda","Bodoni 72","Bodoni MT",Didot,Georgia,serif!important;
  font-weight:400!important;
  line-height:.9;
  letter-spacing:-1.4px;
}
.editorial-title em,
.hero-title em,
.section-title em{font-style:italic!important}

.page-hero{
  padding:0 38px 42px;
  background:var(--cream);
}
.page-hero-box{
  position:relative;
  min-height:330px;
  overflow:hidden;
}
.page-hero-box img{
  width:100%;
  height:330px;
  object-fit:cover;
  object-position:center;
  filter:contrast(.95) saturate(.9);
}
.page-hero-box:after{
  content:"";
  position:absolute;inset:0;
  background:rgba(20,16,36,.22);
}
.page-hero-content{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  z-index:2;
  padding:20px;
}
.hero-title{
  color:#fff8ed;
  font-size:clamp(44px,6vw,88px);
  text-shadow:0 8px 28px rgba(0,0,0,.35);
}
.words-bar{
  background:#d8c8bd;
  min-height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:clamp(18px,4vw,62px);
  padding:10px 22px;
  flex-wrap:wrap;
}
.words-bar span{font-size:14px;color:#1f1f1f}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:235px;
  min-height:50px;
  background:var(--purple);
  color:#fff;
  font-weight:600;
  transition:.25s ease;
}
.btn.gold{background:var(--gold);color:var(--purple)}
.btn:hover{transform:translateY(-2px);background:var(--gold);color:#fff}

.about-page-intro{
  padding:86px 8% 70px;
  background:var(--cream);
}
.about-grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.05fr .8fr;
  gap:72px;
  align-items:center;
}
.rings{width:64px;margin-bottom:28px}
.about-title-img{width:100%;max-width:690px;margin-bottom:34px}
.about-title-img img{width:100%;height:auto}
.lead{font-size:18px;line-height:1.45;font-weight:600;margin-bottom:26px;max-width:700px}
.text{font-size:17px;line-height:1.48;margin-bottom:22px;max-width:700px}
.about-photo img{width:100%;height:570px;object-fit:cover;object-position:center top}

.team-band{
  position:relative;
  min-height:300px;
  background:url("team.jpg"), url("c7.jpeg");
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:0 20px;
}
.team-band:before{content:"";position:absolute;inset:0;background:rgba(248,244,237,.08)}
.team-avatar{
  width:142px;height:142px;border-radius:50%;overflow:hidden;position:relative;transform:translateY(50%);z-index:2;border:6px solid var(--cream)
}
.team-avatar img{width:100%;height:100%;object-fit:cover}
.long-way{padding:105px 8% 90px;text-align:center;background:var(--cream)}
.long-way .section-title{font-size:clamp(42px,5vw,70px);color:var(--purple);margin-bottom:32px}
.long-way p{max-width:820px;margin:0 auto 18px;font-size:16px;line-height:1.6}

.services-page{background:var(--cream)}
.service-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:480px;
}
.service-info{
  background:var(--purple);
  color:#fff;
  padding:72px 10%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.service-info.gold-card{background:#d9b875;color:var(--purple)}
.service-icon{font-size:34px;color:#d9b875;margin-bottom:22px}
.gold-card .service-icon{color:var(--purple)}
.service-info .section-title{font-size:clamp(42px,5.2vw,76px);margin-bottom:22px}
.service-info p{font-size:16px;line-height:1.55;max-width:430px}
.service-image img{width:100%;height:100%;min-height:480px;object-fit:cover}
.service-block.reverse .service-info{order:2}
.service-block.reverse .service-image{order:1}

.gallery-intro{
  padding:76px 8% 58px;
  text-align:center;
  background:var(--cream);
}
.gallery-intro .section-title{font-size:clamp(48px,6vw,82px);margin-bottom:24px}
.gallery-intro p{max-width:700px;margin:0 auto;font-size:16px;line-height:1.45}
.work-collage{
  position:relative;
  max-width:1220px;
  min-height:620px;
  margin:0 auto;
  padding:0 20px;
}
.work-item{position:absolute;overflow:hidden;background:#ddd}
.work-item img{width:100%;height:100%;object-fit:cover}
.work-item:nth-child(1){left:20px;top:60px;width:260px;height:360px}
.work-item:nth-child(2){left:250px;top:250px;width:280px;height:230px}
.work-item:nth-child(3){left:390px;top:40px;width:390px;height:410px;z-index:2}
.work-item:nth-child(4){right:250px;top:230px;width:280px;height:220px}
.work-item:nth-child(5){right:40px;top:70px;width:260px;height:360px}
.work-item:nth-child(6){left:620px;top:410px;width:280px;height:160px}
.work-tag{position:absolute;top:20px;right:0;background:var(--gold);color:var(--purple);font-size:12px;font-weight:600;padding:9px 14px}
.gold-banner{
  background:#bd985e;
  color:#fff8ed;
  min-height:300px;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  overflow:hidden;
}
.gold-banner .copy{padding:60px 10%}
.gold-banner .section-title{font-size:clamp(38px,5vw,70px);margin-bottom:22px}
.gold-banner .flower-bg{height:100%;min-height:300px;background:url("flores1.png") center/contain no-repeat;opacity:.28}

.image-strip{display:grid;grid-template-columns:repeat(6,1fr);background:var(--purple)}
.image-strip img{width:100%;height:170px;object-fit:cover}

.clients-intro{text-align:center;padding:82px 8% 60px;background:var(--cream)}
.clients-intro .section-title{font-size:clamp(48px,6vw,82px);color:var(--purple);margin-bottom:26px}
.clients-intro p{max-width:780px;margin:0 auto 18px;font-size:16px;line-height:1.55}
.clients-photo img{width:100%;height:340px;object-fit:cover;filter:grayscale(1);opacity:.75}
.client-icons{
  background:var(--purple);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:42px;
  min-height:74px;
  flex-wrap:wrap;
  padding:18px;
}
.client-icons i{font-size:22px;color:#fff}

.contact-section{padding:76px 8% 90px;background:var(--cream)}
.contact-grid{
  max-width:1180px;margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start
}
.contact-grid .section-title{font-size:clamp(44px,5vw,76px);color:var(--purple);margin-bottom:24px}
.contact-grid p{font-size:16px;line-height:1.55;margin-bottom:20px}
.form{
  background:#fff;
  padding:34px;
  box-shadow:0 18px 50px rgba(33,25,71,.08);
}
.form label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--purple)}
.form input,.form textarea{
  width:100%;border:1px solid #d8c8bd;background:#f8f4ed;padding:14px 15px;margin-bottom:18px;font-family:"Montserrat";font-size:14px
}
.form textarea{min-height:130px;resize:vertical}
.map{
  min-height:260px;background:#d8c8bd;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--purple);padding:30px
}
.contact-cta{
  min-height:360px;background:url("sol.jpg") center/cover no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;padding:70px 22px;position:relative
}
.contact-cta:before{content:"";position:absolute;inset:0;background:rgba(248,244,237,.25)}
.contact-cta-content{position:relative;z-index:2}
.contact-cta .section-title{font-size:clamp(44px,6vw,84px);color:var(--purple);margin-bottom:24px}
.contact-cta p{max-width:650px;margin:0 auto 28px;font-size:17px;line-height:1.45;color:var(--purple)}

.footer{
  width:100%;
  background:var(--purple);
  color:#fff;
  overflow:hidden;
}
.footer-cafe{height:38px;background:url("eventos-cafe.png") center top/cover no-repeat}
.footer-main{position:relative;padding:52px 7% 46px}
.footer-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.7fr .9fr 1.05fr .72fr;gap:clamp(38px,6vw,96px)}
.footer-logo img{width:255px}
.footer-title{font-size:19px;font-weight:700;margin-bottom:22px}
.footer-social{display:flex;gap:30px;font-size:28px}
.footer p,.footer-menu a{font-size:15px;line-height:1.55;margin-bottom:5px;color:#fff}
.whatsapp-float{
  position:absolute;right:7%;top:84px;width:68px;height:68px;border-radius:50%;background:#d9b875;color:#fff;display:flex;align-items:center;justify-content:center;font-size:38px
}
.footer-legal{background:#e1c389;color:var(--purple);display:flex;align-items:center;justify-content:center;gap:clamp(18px,3vw,44px);padding:12px 6%;flex-wrap:wrap;font-size:10.5px;text-align:center}
.footer-legal a,.footer-legal span{color:var(--purple)}
.footer-bottom{background:var(--gold);min-height:58px;padding:0 7%;display:flex;align-items:center}
.footer-bottom-inner{width:100%;max-width:1320px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-bottom .cotizar{text-decoration:underline;text-underline-offset:4px;color:#fff}
.footer-bottom-social{display:flex;gap:24px;color:#fff}

@media(max-width:1000px){
  .jh-menu{grid-template-columns:1fr;gap:24px}
  .jh-logo{order:-1}
  .jh-menu-left,.jh-menu-right{justify-content:center;flex-wrap:wrap;gap:24px}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-photo{max-width:560px;margin:0 auto}
  .service-block{grid-template-columns:1fr}
  .service-block.reverse .service-info,.service-block.reverse .service-image{order:initial}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .jh-topbar{height:42px;padding:0 16px}
  .jh-header{padding:24px 16px}
  .jh-menu a{font-size:13px}
  .jh-logo img{width:210px}
  .page-hero{padding:0 16px 28px}
  .page-hero-box img{height:300px}
  .hero-title{font-size:42px}
  .about-page-intro,.gallery-intro,.clients-intro,.contact-section{padding:58px 22px}
  .about-title-img{max-width:100%}
  .about-photo img{height:500px}
  .service-info{padding:58px 24px}
  .service-image img{min-height:360px}
  .work-collage{display:grid;grid-template-columns:1fr;gap:20px;min-height:auto;padding:0 22px 50px}
  .work-item{position:relative!important;left:auto!important;right:auto!important;top:auto!important;width:100%!important;height:360px!important}
  .gold-banner{grid-template-columns:1fr}
  .image-strip{grid-template-columns:repeat(2,1fr)}
  .footer-main{text-align:center;padding:42px 24px 40px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-logo img{margin:0 auto;width:230px}
  .footer-social{justify-content:center}
  .whatsapp-float{position:relative;right:auto;top:auto;margin:32px auto 0;width:64px;height:64px;font-size:34px}
  .footer-bottom{padding:15px 22px}
  .footer-bottom-inner{flex-direction:column;gap:12px}
}
