/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#111110;--white:#faf9f7;--grey:#8a8a85;
  --light:#f0ede8;--accent:#c8b89a;
  --font-serif:'Cormorant Garamond',serif;
  --font-sans:'Inter',sans-serif;
  --nav-h:72px;
}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--black);font-family:var(--font-sans);font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 4vw;background:rgba(250,249,247,0.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,0.06)}
.nav-links{list-style:none;display:flex;gap:2.5rem}
.nav-links a{font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey);transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--black)}
.menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--black)}

/* HERO */
.hero{margin-top:var(--nav-h);min-height:calc(100vh - var(--nav-h));display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:6vw 4vw;gap:4vw}
.hero-content{max-width:560px}
.hero-tag{font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--grey);margin-bottom:1.4rem}
.hero-title{font-family:var(--font-serif);font-size:clamp(2.8rem,5.5vw,5rem);font-weight:300;line-height:1.1;margin-bottom:1.2rem}
.hero-sub{font-size:0.85rem;letter-spacing:0.12em;color:var(--grey);text-transform:uppercase;margin-bottom:2.5rem}
.hero-img-wrap{height:78vh;overflow:hidden;border-radius:2px}
.hero-img{height:100%;width:100%;object-fit:cover;transition:transform 8s ease}
.hero-img:hover{transform:scale(1.03)}

/* BUTTONS */
.btn{display:inline-block;padding:0.85rem 2.2rem;background:var(--black);color:var(--white);font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;border:none;cursor:pointer;transition:background 0.2s,color 0.2s}
.btn:hover{background:var(--accent);color:var(--black)}
.btn-light{background:var(--white);color:var(--black)}
.btn-light:hover{background:var(--accent);color:var(--black)}
.link-arrow{font-size:0.78rem;letter-spacing:0.08em;color:var(--grey);border-bottom:1px solid var(--grey);padding-bottom:2px;transition:color 0.2s,border-color 0.2s}
.link-arrow:hover{color:var(--black);border-color:var(--black)}

/* SECTIONS */
.section{padding:6vw 4vw}
.section-title{font-family:var(--font-serif);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:400;margin-bottom:1.5rem}
.section-title.center{text-align:center}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem}

/* INTRO */
.intro{background:var(--light)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center}
.intro-grid p{color:#444;margin-bottom:1rem;font-size:0.95rem}
.intro-stats{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;line-height:1}
.stat-label{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey);margin-top:0.4rem}

/* FEATURED GRID */
.featured-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;grid-template-rows:60vh;gap:0.8rem}
.feat-card{position:relative;overflow:hidden;cursor:pointer}
.feat-card img{height:100%;transition:transform 0.6s ease}
.feat-card:hover img{transform:scale(1.05)}
.feat-info{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;background:linear-gradient(transparent,rgba(0,0,0,0.55));color:#fff}
.feat-cat{font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;opacity:0.8;display:block;margin-bottom:0.3rem}
.feat-card h3{font-family:var(--font-serif);font-size:1.3rem;font-weight:400}

/* IG CTA */
.ig-cta{background:var(--light);text-align:center}
.ig-cta-inner{max-width:540px;margin:0 auto}
.ig-sub{color:var(--grey);font-size:0.9rem;margin-bottom:2rem}

/* PAGE HEADER */
.page-header{margin-top:var(--nav-h);padding:6vw 4vw 4vw;border-bottom:1px solid rgba(0,0,0,0.08)}
.page-tag{font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--grey);margin-bottom:1rem}
.breadcrumb{color:var(--grey)}
.breadcrumb:hover{color:var(--black)}
.page-title{font-family:var(--font-serif);font-size:clamp(2.5rem,6vw,5.5rem);font-weight:300;line-height:1.05;margin-bottom:0.8rem}
.page-sub{color:var(--grey);font-size:0.9rem;max-width:500px}

/* CATEGORIES GRID */
.categories-section{padding-top:4vw}
.categories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.cat-card{position:relative;overflow:hidden;height:55vh;cursor:pointer;display:block}
.cat-card img{height:100%;transition:transform 0.7s ease;filter:brightness(0.75)}
.cat-card:hover img{transform:scale(1.06);filter:brightness(0.6)}
.cat-overlay{position:absolute;bottom:0;left:0;right:0;padding:2rem 1.8rem;color:#fff;background:linear-gradient(transparent 0%,rgba(0,0,0,0.5) 100%);transition:padding 0.3s ease}
.cat-card:hover .cat-overlay{padding-bottom:2.5rem}
.cat-count{display:block;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;opacity:0.7;margin-bottom:0.5rem}
.cat-name{font-family:var(--font-serif);font-size:clamp(1.4rem,2.2vw,2rem);font-weight:400;margin-bottom:0.6rem}
.cat-desc{font-size:0.8rem;opacity:0;transform:translateY(8px);transition:opacity 0.3s ease,transform 0.3s ease;line-height:1.5;max-width:320px}
.cat-card:hover .cat-desc{opacity:0.85;transform:translateY(0)}
.cat-cta{display:inline-block;margin-top:1rem;font-size:0.75rem;letter-spacing:0.1em;border-bottom:1px solid rgba(255,255,255,0.5);padding-bottom:2px;opacity:0;transition:opacity 0.3s ease 0.05s}
.cat-card:hover .cat-cta{opacity:1}

/* FILTER BAR */
.filter-bar{padding:1.5rem 4vw;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(0,0,0,0.07);flex-wrap:wrap}
.filter-label{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey)}
.filter-btn{background:none;border:1px solid rgba(0,0,0,0.15);padding:0.4rem 1rem;font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;color:var(--grey);transition:all 0.2s}
.filter-btn:hover,.filter-btn.active{background:var(--black);color:var(--white);border-color:var(--black)}
.no-projects{padding:2rem 0;color:var(--grey);font-size:0.9rem}
.loading-msg{padding:2rem 0;color:var(--grey);font-size:0.9rem}

/* PROJECTS GRID */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.proj-card{display:block;cursor:pointer}
.proj-img-wrap{height:42vh;overflow:hidden;margin-bottom:1rem}
.proj-img-wrap img{height:100%;transition:transform 0.6s ease}
.proj-card:hover .proj-img-wrap img{transform:scale(1.04)}
.proj-title{font-family:var(--font-serif);font-size:1.2rem;font-weight:400;margin-bottom:0.25rem}
.proj-meta{font-size:0.75rem;color:var(--grey)}

/* CTA STRIP */
.cta-strip{background:var(--light);padding:4vw;text-align:center}
.cta-strip-inner{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}
.cta-strip-inner p{font-family:var(--font-serif);font-size:1.4rem;font-weight:400}

/* DETAIL PAGE */
.detail-hero {
  margin-top: var(--nav-h);
  width: 100%;
  height: 70vh;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.detail-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 4.5rem 4vw 5rem;
}

.detail-breadcrumb {
  font-size: 0.75rem;
  color: var(--grey);
  margin-bottom: 2.5rem;
  letter-spacing: 0.04em;
}
.detail-breadcrumb a {
  color: var(--grey);
}
.detail-breadcrumb a:hover {
  color: var(--black);
}

.detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) 320px;
  gap: 5rem;
  align-items: flex-start;
}

/* Left text block */
.detail-title {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 4.8vw, 4rem);
  font-weight: 300;
  letter-spacing: 0.04em;
  line-height: 1.05;
  margin-bottom: 2.5rem;
}

.detail-body {
  max-width: 640px;
}
.detail-body p {
  font-size: 0.98rem;
  color: #444;
  line-height: 1.9;
  margin-bottom: 1.1rem;
}

/* Right meta block */
.detail-meta {
  position: sticky;
  top: calc(var(--nav-h) + 3rem);
  border-left: 1px solid rgba(0, 0, 0, 0.08);
  padding: 0 0 0 2.3rem;
  background: transparent;
}

.meta-row {
  padding: 1rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.meta-row:last-of-type {
  border-bottom: none;
}
.meta-label {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 0.3rem;
}
.meta-val {
  font-size: 0.9rem;
  color: var(--black);
}

/* Enquire button */
.enquire-btn {
  display: block;
  margin-top: 2.3rem;
  padding: 1rem 1.6rem;
  background: var(--black);
  color: var(--white);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  border-radius: 0;
  transition: background 0.2s;
}
.enquire-btn:hover {
  background: #333;
}

/* Gallery under the text, image pair like reference */
.detail-gallery {
  margin-top: 3.5rem;
  display: grid;
  grid-template-columns: 1.4fr 1.4fr;
  gap: 1rem;
}
.detail-gallery .g-full {
  grid-column: 1 / -1;
}
.detail-gallery img,
.detail-gallery .g-full img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  display: block;
}
.detail-gallery .g-full img {
  height: 520px;
}

/* Mobile */
@media (max-width: 900px) {
  .detail-wrap {
    padding: 3.5rem 4vw 4rem;
  }
  .detail-layout {
    grid-template-columns: 1fr;
    gap: 2.8rem;
  }
  .detail-meta {
    position: static;
    border-left: none;
    padding-left: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    padding-top: 1.8rem;
  }
  .detail-gallery {
    grid-template-columns: 1fr;
  }
  .detail-gallery img,
  .detail-gallery .g-full img {
    height: 62vw;
  }
}


/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center;margin-bottom:5vw}
.about-img-wrap{height:65vh;overflow:hidden}
.about-text p{color:#444;margin-bottom:1rem;font-size:0.95rem}
.values-section{background:var(--light)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem}
.value-card{padding:2rem 0}
.value-icon{font-size:1.5rem;display:block;margin-bottom:1rem;color:var(--accent)}
.value-card h3{font-family:var(--font-serif);font-size:1.15rem;font-weight:400;margin-bottom:0.7rem}
.value-card p{font-size:0.85rem;color:#555;line-height:1.7}
.team-section{padding-top:5vw}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:2.5rem}
.team-card img{height:320px;margin-bottom:1rem;filter:grayscale(30%);transition:filter 0.3s}
.team-card:hover img{filter:grayscale(0%)}
.team-card h3{font-family:var(--font-serif);font-size:1.1rem;font-weight:400}
.team-card p{font-size:0.78rem;color:var(--grey);text-transform:uppercase;letter-spacing:0.08em;margin-top:0.2rem}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:6vw;align-items:start}
.contact-info p{color:#444;margin-bottom:1rem;font-size:0.9rem;line-height:1.8}
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group label{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey)}
.form-group input,.form-group select,.form-group textarea{background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,0.15);padding:0.6rem 0;font-family:var(--font-sans);font-size:0.9rem;color:var(--black);outline:none;transition:border-color 0.2s;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-bottom-color:var(--black)}
.form-group textarea{resize:vertical;min-height:100px}
.form-btn{align-self:flex-start;margin-top:0.5rem}
.form-success{display:none;font-size:0.82rem;color:#5a8a6a;letter-spacing:0.05em;margin-top:0.5rem}

/* FOOTER */
.footer{background:var(--black);color:var(--white);padding:4vw}
.footer-inner{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:2rem;margin-bottom:2.5rem}
.footer-sub{font-size:0.72rem;color:rgba(255,255,255,0.4);letter-spacing:0.08em;text-transform:uppercase}
.footer-nav{display:flex;flex-direction:column;gap:0.6rem}
.footer-nav a{font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.5);transition:color 0.2s}
.footer-nav a:hover{color:var(--white)}
.footer-copy{font-size:0.72rem;color:rgba(255,255,255,0.25);margin-top:2.5rem;border-top:1px solid rgba(255,255,255,0.08);padding-top:1.5rem;width:100%}

/* MOBILE */
@media(max-width:900px){
  .nav-links{display:none;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--white);padding:1.5rem 4vw 2rem;border-bottom:1px solid rgba(0,0,0,0.08);gap:1.2rem}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  .hero{grid-template-columns:1fr;padding:8vw 4vw 6vw;min-height:auto}
  .hero-img-wrap{height:45vw;order:-1}
  .hero-content{max-width:100%}
  .intro-grid{grid-template-columns:1fr;gap:3rem}
  .featured-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .feat-card{height:55vw}
  .categories-grid{grid-template-columns:1fr 1fr}
  .cat-card{height:50vw}
  .projects-grid{grid-template-columns:1fr 1fr;gap:1.2rem}
  .proj-img-wrap{height:35vw}
  .detail-layout{grid-template-columns:1fr}
  .detail-meta{position:static}
  .detail-gallery{grid-template-columns:1fr}
  .detail-gallery .g-full{grid-column:1}
  .detail-gallery img,.detail-gallery .g-full img{height:62vw}
  .related-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .about-img-wrap{height:55vw}
  .values-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;gap:1.5rem}
  .cta-strip-inner{flex-direction:column;gap:1.2rem}
}
@media(max-width:560px){
  .categories-grid{grid-template-columns:1fr}
  .cat-card{height:65vw}
  .projects-grid{grid-template-columns:1fr}
  .proj-img-wrap{height:60vw}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .section-header{flex-direction:column;align-items:flex-start;gap:0.8rem}
}



/* ===== LOGO IMAGE ===== */
.logo {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  text-decoration: none;
}
.logo-img {
  width: auto;
  height: 38px;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}
.logo-dark  { filter: none; }
.logo-white { filter: invert(1) brightness(2); }
.logo-text {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.18em;
}
.logo-footer-wrap {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.4rem;
}
.footer-brand .logo-text { color: var(--white); }
.navbar .logo { display: flex; align-items: center; }

/* ===== MAP SECTION ===== */
.map-section { padding: 5vw 4vw; background: var(--white); }
.map-header { margin-bottom: 2.5rem; }
.map-wrapper {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 4vw;
  align-items: start;
}
.map-info-block {
  padding: 0.9rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.map-info-block:last-of-type { border-bottom: none; }
.map-val {
  font-size: 0.9rem;
  color: #333;
  margin-top: 0.2rem;
  line-height: 1.6;
}
.map-val a {
  color: var(--black);
  border-bottom: 1px solid rgba(0,0,0,0.2);
  padding-bottom: 1px;
  transition: border-color 0.2s;
}
.map-val a:hover { border-color: var(--black); }
.map-embed {
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.08);
  line-height: 0;
}
.map-embed iframe { display: block; width: 100%; height: 480px; }

/* Map responsive */
@media (max-width: 900px) {
  .map-wrapper { grid-template-columns: 1fr; }
  .map-embed iframe { height: 360px; }
}
@media (max-width: 560px) {
  .map-embed iframe { height: 280px; }
}

/* ===== MAP SECTION ===== */
.map-section { padding: 5vw 4vw; background: var(--white); }
.map-header { margin-bottom: 2.5rem; }
.map-wrapper {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 4vw;
  align-items: start;
}
.map-info-block {
  padding: 0.9rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.map-info-block:last-of-type { border-bottom: none; }
.map-val {
  font-size: 0.9rem;
  color: #333;
  margin-top: 0.2rem;
  line-height: 1.6;
}
.map-val a {
  color: var(--black);
  border-bottom: 1px solid rgba(0,0,0,0.2);
  padding-bottom: 1px;
  transition: border-color 0.2s;
}
.map-val a:hover { border-color: var(--black); }
.map-embed {
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.08);
  line-height: 0;
}
.map-embed iframe { display: block; width: 100%; height: 480px; }

/* Map responsive */
@media (max-width: 900px) {
  .map-wrapper { grid-template-columns: 1fr; }
  .map-embed iframe { height: 360px; }
}
@media (max-width: 560px) {
  .map-embed iframe { height: 280px; }
}

/* DETAIL PAGE */
.detail-hero{
  margin-top:var(--nav-h);
  width:100%;
  height:70vh;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.detail-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:4.5rem 4vw 5rem;
}

.detail-layout{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) 320px;
  gap:5rem;
  align-items:flex-start;
}

/* Left text block */
.detail-title{
  font-family:var(--font-serif);
  font-size:clamp(3rem,4.8vw,4rem);
  font-weight:300;
  letter-spacing:0.04em;
  line-height:1.05;
  margin-bottom:2.5rem;
}

.detail-body{
  max-width:640px;
}

.detail-body p{
  font-size:0.98rem;
  color:#444;
  line-height:1.9;
  margin-bottom:1.1rem;
}

/* Right meta block */
.detail-meta{
  position:sticky;
  top:calc(var(--nav-h) + 3rem);
  border-left:1px solid rgba(0,0,0,0.08);
  border-right:none;
  border-top:none;
  border-bottom:none;
  padding:0 0 0 2.3rem;
  background:transparent;
}

.meta-row{
  padding:1rem 0;
  border-bottom:1px solid rgba(0,0,0,0.06);
}

.meta-label{
  display:block;
  font-size:0.7rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:0.3rem;
}

.meta-val{
  font-size:0.9rem;
  color:var(--black);
}

/* Enquire button */
.enquire-btn{
  display:block;
  margin-top:2.3rem;
  padding:1rem 1.6rem;
  background:var(--black);
  color:var(--white);
  font-size:0.7rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  text-align:center;
  text-decoration:none;
  border-radius:0;
  transition:background 0.2s;
}
.enquire-btn:hover{background:#333;}

/* Gallery under the text, full-width cards */
.detail-gallery{
  margin-top:3.5rem;
  display:grid;
  grid-template-columns:1.4fr 1.4fr;
  gap:1rem;
}
.detail-gallery .g-full{grid-column:1/-1;}
.detail-gallery img{
  width:100%;
  height:360px;
  object-fit:cover;
  display:block;
}
.detail-gallery .g-full img{height:520px;}

/* Mobile */
@media(max-width:900px){
  .detail-wrap{padding:3.5rem 4vw 4rem;}
  .detail-layout{
    grid-template-columns:1fr;
    gap:2.8rem;
  }
  .detail-meta{
    position:static;
    border-left:none;
    padding-left:0;
    border-top:1px solid rgba(0,0,0,0.08);
    padding-top:1.8rem;
  }
  .detail-gallery{
    grid-template-columns:1fr;
  }
  .detail-gallery img,
  .detail-gallery .g-full img{
    height:62vw;
  }
}
