:root{
  --bg:#0b0b0b;
  --bg-soft:#121212;
  --panel:#161616;
  --panel-2:#1a1a1a;
  --text:#f7f1e8;
  --muted:#b8b0a2;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);
  --gold:#c9a56a;
  --beige:#eadfcb;
  --wood:#8c6d4f;
  --shadow:0 30px 80px rgba(0,0,0,.45);
  --radius:28px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Montserrat",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(201,165,106,.12), transparent 24%),
    radial-gradient(circle at 85% 10%, rgba(234,223,203,.08), transparent 20%),
    linear-gradient(180deg, #0a0a0a 0%, #111111 40%, #0b0b0b 100%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%}

.page-noise{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.1;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at center, black 25%, transparent 80%);
}

.site-shell{position:relative;overflow:hidden;padding:0 32px}
.topbar{
  position:sticky;top:0;z-index:30;
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 0;
  backdrop-filter:blur(18px);
  background:linear-gradient(180deg, rgba(11,11,11,.88), rgba(11,11,11,.55));
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  flex-shrink:0;
  min-width:max-content;
}
.brand-mark{
  width:50px;
  height:50px;
  display:grid;
  place-items:center;
  border-radius:16px;
  border:1px solid rgba(201,165,106,.38);
  background:
    linear-gradient(135deg, rgba(234,223,203,.12), rgba(201,165,106,.18)),
    rgba(255,255,255,.02);
  box-shadow:0 16px 36px rgba(0,0,0,.24);
  color:var(--beige);
  font-size:.98rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.brand-lockup{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.brand-lockup strong{
  display:block;
  color:var(--text);
  font-size:1rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  line-height:1;
}
.brand-lockup small{
  display:block;
  color:var(--muted);
  font-size:.66rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  line-height:1;
}
.main-nav{display:flex;gap:22px;align-items:center}
.main-nav a{font-size:.95rem;color:rgba(247,241,232,.88)}
.nav-dropdown{position:relative}
.nav-dropdown-toggle{
  border:none;
  background:none;
  color:rgba(247,241,232,.88);
  font:inherit;
  font-size:.95rem;
  cursor:pointer;
  padding:0;
}
.nav-dropdown-menu{
  position:absolute;
  top:calc(100% + 18px);
  left:0;
  min-width:260px;
  display:none;
  padding:14px;
  border-radius:20px;
  background:rgba(18,18,18,.98);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.nav-dropdown-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
}
.nav-dropdown-menu a:hover{background:rgba(255,255,255,.04)}
.nav-dropdown.is-open .nav-dropdown-menu{display:block}
.nav-cta,.button{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:15px 22px;transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
}
.nav-cta,.button.primary{
  background:linear-gradient(135deg, var(--beige), var(--gold));
  color:#111;
  box-shadow:0 14px 36px rgba(201,165,106,.24);
  font-weight:700;
}
.button.secondary{
  background:rgba(255,255,255,.02);
  border:1px solid var(--line-strong);
  color:var(--text);
}
.button:hover,.nav-cta:hover{transform:translateY(-2px);box-shadow:0 20px 48px rgba(0,0,0,.32)}
.menu-toggle{display:none}

.hero{
  position:relative;
  min-height:100vh;
  margin:0 -32px;
  padding:140px 32px 72px;
}
.hero-backdrop{
  position:absolute;inset:28px 32px 0;
  border-radius:36px;
  background-size:cover;background-position:center;
  filter:saturate(.85) contrast(.95);
}
.hero-backdrop::before,
.hero-backdrop::after{
  content:"";
  position:absolute;inset:0;border-radius:inherit;
}
.hero-backdrop::before{
  background:linear-gradient(90deg, rgba(8,8,8,.92) 0%, rgba(8,8,8,.58) 45%, rgba(8,8,8,.22) 100%);
}
.hero-backdrop::after{
  background:linear-gradient(180deg, rgba(12,12,12,.18), rgba(12,12,12,.7) 100%);
}
.hero-content{
  position:relative;z-index:1;
  display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.62fr);
  align-items:end;gap:32px;min-height:calc(100vh - 212px);
}
.hero-copy{
  max-width:820px;
  padding:48px 0 24px;
}
.eyebrow,.section-head span{
  display:inline-block;
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.78rem;
}
.hero h1,
.section-head h2,
.detail-hero h1,
.cta-band h2{
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  letter-spacing:-.05em;
}
.hero h1{
  margin:20px 0 22px;
  font-size:clamp(3.3rem, 7vw, 7.2rem);
  line-height:.9;
  max-width:11ch;
}
.hero p{
  margin:0;
  max-width:640px;
  color:rgba(247,241,232,.8);
  font-size:1.12rem;
  line-height:1.9;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.hero-panel{
  align-self:end;
  padding:28px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:30px 30px 0 0;
  background:linear-gradient(180deg, rgba(20,20,20,.84), rgba(12,12,12,.98));
  box-shadow:var(--shadow);
}
.hero-panel span{display:block;color:var(--gold);font-size:.82rem;text-transform:uppercase;letter-spacing:.2em;margin-bottom:14px}
.hero-panel strong{display:block;font-size:1.35rem;line-height:1.45}
.hero-metrics{display:grid;gap:12px;margin-top:22px}
.metric-chip{
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.03);
  color:var(--muted);
  border:1px solid rgba(255,255,255,.08);
}

.section{position:relative;padding:110px 0}
.section-overlap{margin-top:-70px;z-index:2}
.section-head{max-width:860px;margin-bottom:32px}
.section-head h2{
  margin:12px 0 0;
  font-size:clamp(2.3rem, 4.7vw, 4.8rem);
  line-height:.98;
}

.about-stage{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:32px;
  align-items:start;
}
.panel-elevated,
.panel-lite,
.testimonial-card,
.blog-card,
.bullet,
.contact-form,
.faq-list details{
  background:linear-gradient(180deg, rgba(28,28,28,.88), rgba(18,18,18,.96));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.panel-elevated,
.panel-lite{border-radius:30px;padding:32px}
.lead{
  margin:0 0 18px;
  font-size:1.35rem;
  line-height:1.6;
  color:var(--beige);
}
.richtext p,
.testimonial-card p,
.blog-card p,
.contact-panel p,
.faq-list p{
  color:var(--muted);
  line-height:1.9;
}
.about-stack{display:grid;gap:22px}
.image-card,
.service-media,
.gallery-card{
  background-size:cover;
  background-position:center;
}
.image-card.large{
  min-height:560px;
  border-radius:36px;
  box-shadow:var(--shadow);
}
.stat-panel{
  margin-left:auto;
  width:min(78%, 420px);
  padding:24px;
  border-radius:28px;
  background:linear-gradient(140deg, rgba(201,165,106,.18), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.1);
}
.stat-panel span{display:block;color:var(--gold);font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;margin-bottom:10px}
.stat-panel strong{font-family:"Montserrat",sans-serif;font-size:1.8rem;line-height:1.15;font-weight:800}

.service-rows{display:grid;gap:34px}
.service-row{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(340px,.9fr);
  gap:24px;
  align-items:center;
}
.service-row.reverse{grid-template-columns:minmax(340px,.9fr) minmax(0,1.1fr)}
.service-row.reverse .service-media{order:2}
.service-row.reverse .service-body{order:1}
.service-media{
  min-height:460px;
  border-radius:34px;
  box-shadow:var(--shadow);
  transform:translateZ(0);
}
.service-body{
  padding:38px 34px;
  border-radius:34px;
  background:linear-gradient(180deg, rgba(23,23,23,.95), rgba(16,16,16,.98));
  border:1px solid var(--line);
}
.service-index{
  display:block;
  margin-bottom:18px;
  color:var(--gold);
  font-size:.88rem;
  letter-spacing:.24em;
}
.service-body h3{
  margin:0 0 14px;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:clamp(2rem,3vw,3.1rem);
  line-height:.98;
}
.service-body h2{
  margin:0 0 14px;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:clamp(2rem,3vw,3.1rem);
  line-height:.98;
}
.service-body p{margin:0;color:var(--muted);line-height:1.9}
.feature-line{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.feature-line span{
  padding:10px 14px;border-radius:999px;border:1px solid var(--line);color:var(--beige);font-size:.92rem
}
.inline-link{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:24px;
  color:var(--gold);
  font-weight:600;
}
.inline-link::after{content:"";width:34px;height:1px;background:currentColor;transition:width .35s ease}
.inline-link:hover::after{width:52px}

.accent{
  padding:80px 34px;
  border-radius:40px;
  background:
    radial-gradient(circle at top left, rgba(201,165,106,.15), transparent 35%),
    linear-gradient(180deg, rgba(28,28,28,.96), rgba(15,15,15,.98));
  border:1px solid rgba(255,255,255,.08);
}
.bullet-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
}
.bullet{
  padding:24px;
  border-radius:24px;
  font-size:1.05rem;
  font-weight:600;
  line-height:1.6;
}

.project-masonry{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}
.project-cover{
  position:relative;
  display:block;
  min-height:380px;
  height:380px;
  border-radius:32px;
  overflow:hidden;
  background-size:cover;
  background-position:center center;
  box-shadow:var(--shadow);
}
.project-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;
  background:linear-gradient(180deg, rgba(7,7,7,.08), rgba(7,7,7,.84) 78%);
  transition:transform .45s ease, background .45s ease;
}
.project-cover:hover .project-overlay{transform:translateY(-8px);background:linear-gradient(180deg, rgba(7,7,7,.08), rgba(7,7,7,.92) 82%)}
.project-overlay small{color:var(--gold);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}
.project-overlay h3{
  margin:14px 0 10px;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:2rem;
  line-height:1.02;
}
.project-overlay p{margin:0;color:rgba(247,241,232,.78);line-height:1.75}

.testimonial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.testimonial-card{
  margin:0;
  border-radius:26px;
  padding:28px;
}
.testimonial-card footer{
  margin-top:24px;
  display:flex;flex-direction:column;gap:6px;
  font-size:.95rem;
  color:var(--beige);
}
.testimonial-card footer span{color:var(--muted)}

.split-faq-gallery{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(340px,.88fr);
  gap:28px;
  align-items:start;
}
.split-faq-gallery .section-head{grid-column:1/-1}
.faq-list details{
  border-radius:24px;
  padding:20px 22px;
  margin-bottom:14px;
}
.faq-list summary{
  cursor:pointer;
  list-style:none;
  font-size:1.06rem;
  font-weight:700;
}
.gallery-stack{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.gallery-card{
  min-height:220px;
  border-radius:24px;
  display:flex;align-items:flex-end;
  padding:20px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.gallery-card::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(11,11,11,.05), rgba(11,11,11,.82));
}
.gallery-card span{
  position:relative;z-index:1;
  font-family:"Montserrat",sans-serif;
  font-weight:700;
  font-size:1.28rem;
}
.gallery-card-2,.gallery-card-3{min-height:280px}

.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.blog-card{
  border-radius:28px;
  padding:28px;
}
.blog-card small{
  color:var(--gold);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.blog-card h3{
  margin:18px 0 12px;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:2rem;
  line-height:1.05;
}

.cta-stage{padding-top:120px}
.cta-band{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:28px;
  align-items:end;
  margin-bottom:26px;
}
.cta-band h2{
  margin:14px 0 0;
  max-width:15ch;
  font-size:clamp(2.2rem, 4.5vw, 4.6rem);
  line-height:.95;
}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}
.cta-form{max-width:920px}

.contact-grid{
  display:grid;
  grid-template-columns:minmax(320px,.75fr) minmax(0,1fr);
  gap:24px;
}
.contact-panel strong{color:var(--beige)}
.contact-form{
  display:grid;
  gap:14px;
  border-radius:30px;
  padding:28px;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--text);
  font:inherit;
  padding:16px 18px;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:#9d9588}

.footer{
  display:grid;
  grid-template-columns:1.1fr .7fr .8fr;
  gap:24px;
  padding:52px 0 82px;
  border-top:1px solid var(--line);
}
.footer h3,.footer h4{
  margin:0 0 12px;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
}
.footer p,.footer a,.footer span{
  color:var(--muted);
  line-height:1.9;
}

.flash{
  margin:16px 0 0;
  padding:14px 18px;
  border-radius:18px;
  background:#17331f;
  color:#d7f5df;
}
.detail-hero{padding:100px 0 30px}
.detail-hero h1{margin:0 0 14px;font-size:clamp(2.8rem,5vw,5rem);line-height:.95}
.detail-hero p{margin:0;color:var(--muted);font-size:1.08rem;line-height:1.8}
.detail-hero-rich{max-width:980px}
.detail-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.detail-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:28px;align-items:start}
.service-gallery-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr .9fr;
  gap:16px;
  align-items:stretch;
}
.service-gallery-card{
  min-height:240px;
  border-radius:26px;
  background-size:cover;
  background-position:center;
  box-shadow:var(--shadow);
}
.service-gallery-card-1,
.service-gallery-card-4{grid-row:span 2;min-height:520px}
.service-gallery-card-3,
.service-gallery-card-6{min-height:300px}
.section-toplink{margin:-6px 0 26px}
.map-frame{
  margin-top:22px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  min-height:320px;
}
.map-frame iframe{display:block;width:100%;height:320px;border:0}
.whatsapp-float{
  position:fixed;right:18px;bottom:18px;z-index:40;
  background:linear-gradient(135deg,#35d978,#1fb65e);
  color:#0c1510;
  padding:15px 19px;border-radius:999px;font-weight:800;
  box-shadow:0 22px 45px rgba(0,0,0,.28);
}

[data-reveal]{
  opacity:0;
  transform:translate3d(0,40px,0);
  transition:opacity .9s ease, transform .9s cubic-bezier(.22,1,.36,1);
}
[data-reveal="left"]{transform:translate3d(-40px,0,0)}
[data-reveal="right"]{transform:translate3d(40px,0,0)}
[data-reveal].is-visible{opacity:1;transform:translate3d(0,0,0)}

@media (max-width: 1140px){
  .hero-content,
  .about-stage,
  .service-row,
  .service-row.reverse,
  .split-faq-gallery,
  .contact-grid,
  .cta-band,
  .footer,
  .detail-grid,
  .service-gallery-grid,
  .project-masonry,
  .card-grid,
  .testimonial-grid,
  .bullet-grid{
    grid-template-columns:1fr;
  }
  .service-row.reverse .service-media,
  .service-row.reverse .service-body{order:initial}
  .project-cover{min-height:360px}
}

@media (max-width: 920px){
  .site-shell{padding:0 18px}
  .hero{margin:0 -18px;padding:122px 18px 46px}
  .hero-backdrop{inset:18px 18px 0}
  .hero h1{font-size:clamp(2.8rem,14vw,4.5rem)}
  .section{padding:82px 0}
  .brand-lockup small{display:none}
  .main-nav{
    display:none;position:absolute;top:76px;right:0;
    width:min(280px, calc(100vw - 36px));
    padding:18px;border-radius:22px;
    background:rgba(17,17,17,.98);border:1px solid var(--line);
    flex-direction:column;align-items:flex-start;
  }
  .nav-dropdown{width:100%}
  .nav-dropdown-menu{
    position:static;
    min-width:0;
    margin-top:10px;
    width:100%;
  }
  .main-nav.is-open{display:flex}
  .menu-toggle{
    display:inline-flex;background:none;color:var(--text);
    border:1px solid var(--line);border-radius:999px;padding:10px 14px
  }
  .gallery-stack{grid-template-columns:1fr}
}
