/* ===================================================
   RUANGARSA STUDIO — Main Stylesheet
   Colors: Warm White #F7F5F2 | Charcoal #222222
           Warm Sand #C6A77B | Olive Green #7D8A6A
   Fonts: Cormorant Garamond (headings) | Inter (body)
   =================================================== */

/* ===== VARIABLES ===== */
:root {
  --warm-white: #F7F5F2;
  --charcoal:   #222222;
  --warm-sand:  #C6A77B;
  --olive:      #7D8A6A;
  --olive-dark: #5e6b51;
  --dark-bg:    #1a1a1a;
  --card-dark:  #2a2a2a;
  --text-body:  #666;
  --border:     #e4dfd7;
  --transition: all 0.3s ease;
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 15px;
  line-height: 1.75;
  color: var(--text-body);
  background: var(--warm-white);
  -webkit-font-smoothing: antialiased;
}
img { max-width:100%; display:block; height:auto; }
a { text-decoration:none; color:inherit; transition: var(--transition); }
ul { list-style:none; }
button { cursor:pointer; font-family: inherit; }

/* ===== LAYOUT ===== */
.container { max-width:1180px; margin:0 auto; padding:0 28px; }
.section { padding: 88px 0; }
.section-sm { padding: 60px 0; }
.dark-section { background: var(--charcoal); }

/* ===== TYPOGRAPHY ===== */
h1, h2, h3, h4, h5 {
  font-family: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  color: var(--charcoal);
  line-height: 1.15;
}
.section-label {
  display: block;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--olive);
  margin-bottom: 14px;
}
.section-label.light { color: var(--warm-sand); }
.section-label.center { text-align:center; }
.section-title {
  font-size: clamp(30px, 3.5vw, 46px);
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 44px;
}
.section-title.center { text-align:center; }
.section-title.light { color:#fff; }
.section-cta { text-align:center; margin-top: 44px; }

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 13px 30px;
  font-family: 'Inter', sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  border: 1.5px solid transparent;
  transition: var(--transition);
}
.btn-olive { background: var(--olive); color:#fff; border-color: var(--olive); }
.btn-olive:hover { background: var(--olive-dark); border-color: var(--olive-dark); }
.btn-outline-dark { background:transparent; color:var(--charcoal); border-color:var(--charcoal); }
.btn-outline-dark:hover { background:var(--charcoal); color:#fff; }
.btn-outline-light { background:transparent; color:#fff; border-color:rgba(255,255,255,.45); }
.btn-outline-light:hover { background:rgba(255,255,255,.1); border-color:#fff; }
.btn-hero-wa {
  background: var(--olive);
  color:#fff;
  border-color: var(--olive);
  padding: 15px 30px;
  font-size: 11.5px;
}
.btn-hero-wa:hover { background: var(--olive-dark); }
.btn-hero-outline {
  background: transparent;
  color:#fff;
  border: 1.5px solid rgba(255,255,255,.55);
  padding: 15px 30px;
  font-size: 11.5px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
}
.btn-hero-outline:hover { background:rgba(255,255,255,.1); border-color:#fff; }

/* ===== HEADER ===== */
.header {
  position: fixed;
  top:0; left:0; right:0;
  z-index: 1000;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,.055);
  transition: box-shadow 0.3s;
}
.header.scrolled { box-shadow: 0 3px 24px rgba(0,0,0,.09); }
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}
/* Logo */
.logo { display:flex; flex-direction:column; line-height:1; }
.logo-main {
  font-family: 'Cormorant Garamond', serif;
  font-size: 23px;
  font-weight: 600;
  color: var(--charcoal);
  letter-spacing: .5px;
}
.logo-sub {
  font-family: 'Inter', sans-serif;
  font-size: 8.5px;
  font-weight: 600;
  letter-spacing: 4.5px;
  color: var(--warm-sand);
  text-transform: uppercase;
  margin-top: 1px;
}
/* Nav links */
.nav-menu { display:flex; align-items:center; gap:28px; }
.nav-link {
  font-size: 12.5px;
  color: #666;
  position: relative;
  padding-bottom: 3px;
}
.nav-link::after {
  content:'';
  position:absolute;
  bottom:0; left:0;
  width:0; height:1px;
  background: var(--warm-sand);
  transition: var(--transition);
}
.nav-link:hover, .nav-link.active { color: var(--charcoal); }
.nav-link:hover::after, .nav-link.active::after { width:100%; }
/* Nav actions */
.nav-actions { display:flex; align-items:center; gap:22px; }
.lang-toggle { display:flex; align-items:center; gap:6px; font-size:12px; color:#aaa; }
.lang-btn { font-size:12px; color:#aaa; font-weight:500; }
.lang-btn.active { color:var(--charcoal); font-weight:600; }
.lang-btn:hover { color:var(--charcoal); }
.nav-wa {
  display:flex; align-items:center; gap:7px;
  background: var(--olive);
  color:#fff;
  padding: 8px 16px;
  font-size:12px; font-weight:500;
  border-radius:2px;
}
.nav-wa:hover { background: var(--olive-dark); color:#fff; }
/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--charcoal); transition: var(--transition); }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ===== HERO ===== */
.hero {
  position: relative;
  height: 100vh;
  min-height: 620px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset:0;
  /* Beautiful warm-tropical gradient placeholder – replace with actual photo */
  background: linear-gradient(150deg,
    #3a3028 0%, #5c4535 20%,
    #8a7258 40%, #6e7c5a 65%,
    #4a5840 85%, #2e3520 100%);
}
.hero-bg img {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
}
.hero-overlay {
  position:absolute; inset:0;
  background: linear-gradient(
    105deg,
    rgba(15,12,9,.78) 0%,
    rgba(15,12,9,.55) 50%,
    rgba(15,12,9,.18) 100%
  );
}
.hero-content {
  position: relative;
  z-index:2;
  padding-top: 72px;
  max-width: 640px;
}
.hero-label {
  display:block;
  font-size:10.5px; font-weight:600;
  letter-spacing:3.5px; text-transform:uppercase;
  color: rgba(198,167,123,.8);
  margin-bottom:18px;
}
.hero-title { margin-bottom:20px; }
.hero-title-main {
  display:block;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(42px, 6.5vw, 80px);
  font-weight: 700;
  color:#fff;
  line-height:1.0;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.hero-title-sub {
  display:block;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 4vw, 52px);
  font-weight: 400;
  font-style: italic;
  color: var(--warm-sand);
  line-height:1.25;
  margin-top: 6px;
}
.hero-desc {
  color: rgba(255,255,255,.78);
  font-size:14.5px;
  line-height:1.75;
  margin-bottom:36px;
  max-width:420px;
}
.hero-btns { display:flex; gap:16px; flex-wrap:wrap; }
.hero-scroll {
  position:absolute; bottom:32px; left:50%;
  transform:translateX(-50%);
  z-index:2;
  animation: scrollBounce 2.4s ease-in-out infinite;
  color: rgba(255,255,255,.5);
}
@keyframes scrollBounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  55%      { transform: translateX(-50%) translateY(9px); }
}

/* ===== ABOUT PREVIEW ===== */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.about-title {
  font-size: clamp(28px, 3.2vw, 42px);
  font-weight: 600;
  line-height:1.18;
  color: var(--charcoal);
  margin-bottom: 20px;
}
.about-text {
  font-size:14.5px;
  color:#777;
  line-height:1.85;
  margin-bottom:34px;
  max-width:420px;
}
.about-img-wrap {
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background: linear-gradient(140deg,#c8b89a 0%,#8a7560 55%,#5c4535 100%);
}
.about-img-wrap img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.about-img-wrap::after {
  content:'';
  position:absolute;
  bottom:-1px; right:-1px;
  width:60%; height:60%;
  border:2px solid var(--warm-sand);
  transform: translate(16px,16px);
  pointer-events:none;
}

/* ===== PORTFOLIO ===== */
.portfolio-filter {
  display:flex; justify-content:center;
  gap:8px; margin-bottom:40px; flex-wrap:wrap;
}
.filter-btn {
  padding: 7px 20px;
  font-size: 12px; font-weight:500;
  border: 1.5px solid rgba(255,255,255,.2);
  background:transparent; color:rgba(255,255,255,.6);
  transition: var(--transition);
  letter-spacing:.3px;
}
.filter-btn:hover, .filter-btn.active {
  background:#fff; border-color:#fff; color:var(--charcoal);
}
.portfolio-grid {
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap:16px;
  margin-bottom:40px;
}
.portfolio-card {
  background: var(--card-dark);
  overflow:hidden;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.portfolio-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.35); }
.portfolio-card[style*="none"] { display:none; }
.p-card-img {
  aspect-ratio:3/4; overflow:hidden;
  position:relative;
}
.p-card-img-bg {
  position:absolute; inset:0;
  background: linear-gradient(160deg,#8a7258 0%,#5c4535 60%,#3a3028 100%);
  transition: transform 0.5s ease;
}
.portfolio-card:hover .p-card-img-bg { transform:scale(1.06); }
.p-card-img img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition: transform 0.5s ease;
}
.portfolio-card:hover .p-card-img img { transform:scale(1.06); }

/* Different gradients per project for visual variety */
.p-card-img-bg.variant-2 { background:linear-gradient(160deg,#6e7c5a 0%,#4a5840 55%,#2e3520 100%); }
.p-card-img-bg.variant-3 { background:linear-gradient(160deg,#7a6e5a 0%,#58503a 55%,#383020 100%); }
.p-card-img-bg.variant-4 { background:linear-gradient(160deg,#5a6858 0%,#3c4a38 55%,#242e22 100%); }

.p-card-info {
  padding: 16px 18px;
  display:flex; justify-content:space-between; align-items:flex-end;
}
.p-card-text h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size:18px; font-weight:600;
  color:#fff; margin-bottom:4px;
}
.p-card-meta { display:flex; flex-direction:column; gap:1px; }
.p-card-location { font-size:11px; color:rgba(255,255,255,.45); }
.p-card-cat { font-size:10.5px; color:var(--warm-sand); letter-spacing:.5px; margin-top:2px; }
.p-card-arrow { font-size:22px; color:var(--warm-sand); line-height:1; }
.p-card-arrow:hover { color:#fff; }

/* ===== SERVICES ===== */
.services-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-bottom:44px;
}
.service-card {
  text-align:center;
  padding: 36px 22px;
  border: 1px solid var(--border);
  transition: var(--transition);
  background:#fff;
}
.service-card:hover {
  border-color: var(--warm-sand);
  box-shadow:0 6px 28px rgba(0,0,0,.07);
  transform:translateY(-3px);
}
.service-icon {
  width:60px; height:60px;
  margin:0 auto 22px;
}
.service-card h3 {
  font-size:19px; font-weight:600;
  color:var(--charcoal);
  margin-bottom:10px;
}
.service-card p {
  font-size:13px; color:#888; line-height:1.7;
}

/* ===== WHY US ===== */
.why-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:48px;
  margin-top:10px;
}
.why-card { display:flex; align-items:flex-start; gap:20px; }
.why-icon { width:48px; height:48px; flex-shrink:0; }
.why-card h3 {
  font-size:20px; font-weight:600;
  color:#fff; margin-bottom:8px;
}
.why-card p { font-size:13px; color:rgba(255,255,255,.55); line-height:1.75; }

/* ===== TESTIMONIALS ===== */
.testi-team-wrap {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:start;
}
.testi-cards { display:flex; flex-direction:column; gap:18px; margin-bottom:20px; }
.testi-card {
  background:#fff;
  border:1px solid var(--border);
  padding:24px 26px;
}
.testi-quote {
  font-family:'Cormorant Garamond',serif;
  font-size:52px; line-height:.4;
  color:var(--warm-sand); opacity:.4;
  margin-bottom:14px;
}
.testi-card p {
  font-size:13.5px; color:#666;
  line-height:1.75; font-style:italic;
  margin-bottom:18px;
}
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--warm-sand); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; flex-shrink:0;
  overflow:hidden;
}
.testi-avatar img { width:100%; height:100%; object-fit:cover; }
.testi-author strong {
  display:block; font-size:14px;
  font-family:'Cormorant Garamond',serif;
  color:var(--charcoal); font-weight:600;
}
.testi-author span { font-size:11.5px; color:#aaa; }
.testi-dots { display:flex; gap:6px; }
.dot { width:8px; height:8px; border-radius:50%; background:var(--border); cursor:pointer; transition:var(--transition); }
.dot.active { background:var(--warm-sand); }

/* ===== TEAM ===== */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.team-card { text-align:center; }
.team-photo {
  aspect-ratio:3/4; overflow:hidden;
  position:relative; margin-bottom:14px;
  background:linear-gradient(160deg,#c8b8a0 0%,#9a8870 100%);
}
.team-photo img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.team-initials {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif;
  font-size:36px; color:rgba(255,255,255,.45);
}
.team-card h4 {
  font-size:16.5px; font-weight:600;
  color:var(--charcoal); margin-bottom:4px;
}
.team-card span { font-size:12px; color:#aaa; }

/* ===== CTA SECTION ===== */
.cta-section {
  position:relative; padding:80px 0;
  background:linear-gradient(150deg,#4a3d32 0%,#7a6350 45%,#3d4535 100%);
  overflow:hidden;
}
.cta-section::before {
  content:'';
  position:absolute; inset:0;
  background:rgba(20,16,12,.55);
}
.cta-inner {
  position:relative; z-index:2;
  display:flex; align-items:center;
  justify-content:space-between; gap:40px;
}
.cta-text h2 {
  font-size:clamp(28px,3.5vw,44px);
  font-weight:700; color:#fff;
  margin-bottom:10px;
}
.cta-text p { color:rgba(255,255,255,.72); font-size:14.5px; line-height:1.75; }
.cta-btns { display:flex; gap:14px; flex-wrap:wrap; }
.cta-btn {
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  padding:16px 24px; color:#fff;
  transition:var(--transition);
  min-width:170px;
  backdrop-filter:blur(8px);
}
.cta-btn:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.4); color:#fff; }
.cta-btn strong { display:block; font-size:14px; font-weight:600; }
.cta-btn small { display:block; font-size:11px; opacity:.65; margin-top:1px; }

/* ===== FOOTER ===== */
.footer { background:var(--dark-bg); padding:64px 0 0; color:rgba(255,255,255,.55); }
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1.6fr 1.4fr;
  gap:48px;
  padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-logo { margin-bottom:16px; display:block; }
.footer-logo .logo-main { color:#fff; font-size:22px; }
.footer-brand p { font-size:13px; line-height:1.85; margin-bottom:22px; }
.footer-social { display:flex; gap:10px; }
.s-icon {
  width:34px; height:34px;
  border:1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.s-icon:hover { border-color:var(--warm-sand); color:var(--warm-sand); }
.footer-col h5 {
  font-family:'Inter',sans-serif;
  font-size:11px; font-weight:600;
  letter-spacing:2.5px; text-transform:uppercase;
  color:#fff; margin-bottom:22px;
}
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,.5); }
.footer-links a:hover { color:var(--warm-sand); }
.footer-contact-list { display:flex; flex-direction:column; gap:14px; }
.footer-contact-item { display:flex; gap:10px; align-items:flex-start; }
.footer-contact-item svg { margin-top:2px; flex-shrink:0; opacity:.45; }
.footer-contact-item a, .footer-contact-item span { font-size:13px; color:rgba(255,255,255,.5); line-height:1.6; }
.footer-contact-item a:hover { color:var(--warm-sand); }
.footer-hours p { font-size:13px; line-height:1.8; }
.footer-hours .hours-label { color:#fff; font-weight:500; margin-bottom:2px; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 0; font-size:12px; color:rgba(255,255,255,.28);
}

/* ===== PAGE HERO (inner pages) ===== */
.page-hero {
  padding-top: 72px;
  background: var(--charcoal);
  position:relative; overflow:hidden;
}
.page-hero-inner {
  padding: 80px 0 72px;
  position:relative; z-index:2;
}
.page-hero h1 {
  font-size:clamp(36px,5vw,60px);
  color:#fff; font-weight:600;
  margin-bottom:12px;
}
.page-hero p { font-size:15px; color:rgba(255,255,255,.65); max-width:520px; }

/* ===== PROJECT DETAIL ===== */
.project-hero {
  padding-top:72px;
  height:70vh; min-height:480px;
  position:relative; overflow:hidden;
  background:linear-gradient(150deg,#5c4535 0%,#8a7258 50%,#3a3028 100%);
}
.project-hero img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.project-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(15,12,9,.85) 0%,rgba(15,12,9,.2) 100%);
}
.project-hero-content {
  position:absolute; bottom:40px; left:0; right:0;
  padding:0 28px; z-index:2;
}
.project-tag {
  display:inline-block;
  background:var(--warm-sand);
  color:#fff;
  padding:5px 14px; font-size:10.5px;
  font-weight:600; letter-spacing:2px;
  text-transform:uppercase; margin-bottom:12px;
}
.project-hero-content h1 {
  font-size:clamp(32px,5vw,58px);
  color:#fff; font-weight:600;
  margin-bottom:8px;
}
.project-hero-content p { color:rgba(255,255,255,.65); font-size:14px; }
.project-meta-bar {
  background:#fff; padding:28px 0;
  border-bottom:1px solid var(--border);
}
.project-meta-inner {
  display:flex; gap:48px; flex-wrap:wrap;
}
.project-meta-item strong {
  display:block;
  font-size:10px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:#aaa; margin-bottom:4px;
}
.project-meta-item span { font-size:14.5px; color:var(--charcoal); font-weight:500; }
.project-body { padding: 72px 0; }
.project-body-grid {
  display:grid; grid-template-columns:2fr 1fr; gap:64px; align-items:start;
}
.project-desc h2 {
  font-size:32px; margin-bottom:18px;
}
.project-desc p { margin-bottom:16px; font-size:15px; color:#666; line-height:1.85; }
.project-sidebar {}
.sidebar-box {
  background:#fff;
  border:1px solid var(--border);
  padding:28px;
  margin-bottom:20px;
}
.sidebar-box h4 {
  font-size:11px; letter-spacing:2px;
  text-transform:uppercase; color:#aaa;
  margin-bottom:14px; font-family:'Inter',sans-serif;
}
.sidebar-list { display:flex; flex-direction:column; gap:8px; }
.sidebar-list li { font-size:14px; color:var(--charcoal); font-weight:500; }
.sidebar-list li span { color:#aaa; font-weight:400; float:right; font-size:13px; }
.project-gallery { padding:60px 0; background:var(--warm-white); }
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.gallery-item {
  aspect-ratio:4/3; overflow:hidden; position:relative;
  background:linear-gradient(160deg,#c0aa8a 0%,#8a7258 55%,#5c4535 100%);
}
.gallery-item.tall { aspect-ratio:3/4; }
.gallery-item img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.5s ease;
}
.gallery-item:hover img { transform:scale(1.04); }

/* ===== SERVICES PAGE ===== */
.service-detail-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;
  margin-bottom:72px;
}
.service-detail-grid:nth-child(even) .service-detail-img { order:-1; }
.service-detail-img {
  aspect-ratio:4/3; position:relative; overflow:hidden;
  background:linear-gradient(140deg,#c8b89a 0%,#8a7560 55%,#5c4535 100%);
}
.service-detail-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.service-detail-content {}
.service-detail-content h2 { font-size:34px; margin-bottom:16px; }
.service-detail-content p { font-size:14.5px; color:#777; line-height:1.85; margin-bottom:16px; }
.service-list { margin:20px 0; }
.service-list li {
  padding:10px 0;
  font-size:14px; color:#666;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:10px;
}
.service-list li::before {
  content:'';
  width:6px; height:6px; border-radius:50%;
  background:var(--warm-sand); flex-shrink:0;
}

/* ===== ABOUT PAGE ===== */
.philosophy-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.philosophy-card {
  padding:32px 28px;
  border:1px solid var(--border);
  background:#fff;
}
.philosophy-card h3 { font-size:22px; margin-bottom:12px; }
.philosophy-card p { font-size:13.5px; color:#777; line-height:1.8; }
.philosophy-num {
  font-family:'Cormorant Garamond',serif;
  font-size:48px; font-weight:300;
  color:var(--warm-sand); opacity:.4;
  display:block; margin-bottom:8px;
  line-height:1;
}

/* ===== FAQ PAGE ===== */
.faq-list { max-width:760px; margin:0 auto; }
.faq-item {
  border-bottom:1px solid var(--border);
}
.faq-q {
  display:flex; justify-content:space-between; align-items:center;
  padding:22px 0; cursor:pointer; gap:20px;
}
.faq-q h3 {
  font-size:18px; font-weight:500;
  color:var(--charcoal); font-family:'Cormorant Garamond',serif;
}
.faq-icon {
  width:28px; height:28px; flex-shrink:0;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.faq-item.open .faq-icon { background:var(--warm-sand); border-color:var(--warm-sand); }
.faq-icon svg { transition:transform .3s; }
.faq-item.open .faq-icon svg { transform:rotate(45deg); }
.faq-a {
  display:none;
  padding-bottom:22px;
  font-size:14px; color:#777; line-height:1.85;
}
.faq-item.open .faq-a { display:block; }

/* ===== CONTACT PAGE ===== */
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:64px; }
.contact-info-item {
  display:flex; gap:18px; align-items:flex-start;
  margin-bottom:32px;
}
.contact-icon {
  width:48px; height:48px; flex-shrink:0;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--olive);
}
.contact-info-item h4 {
  font-size:11px; font-weight:600; letter-spacing:2px;
  text-transform:uppercase; color:#aaa;
  margin-bottom:5px; font-family:'Inter',sans-serif;
}
.contact-info-item p, .contact-info-item a {
  font-size:14.5px; color:var(--charcoal); font-weight:500; line-height:1.6;
}
.contact-info-item a:hover { color:var(--olive); }
/* Contact form */
.contact-form {}
.form-group { margin-bottom:18px; }
.form-group label {
  display:block; font-size:11px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase;
  color:#aaa; margin-bottom:8px;
}
.form-group input, .form-group textarea, .form-group select {
  width:100%;
  border:1px solid var(--border);
  background:#fff;
  padding:13px 16px;
  font-size:14px; color:var(--charcoal);
  font-family:'Inter',sans-serif;
  transition:border-color .25s;
  outline:none;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  border-color:var(--warm-sand);
}
.form-group textarea { resize:vertical; min-height:130px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-success {
  display:none; padding:18px 24px;
  background:#f0f5ed; border:1px solid #c5d9b5;
  color:#3d6130; font-size:14px;
  margin-bottom:16px;
}
.form-success.show { display:block; }

/* ===== UTILITY ===== */
.text-center { text-align:center; }
.mt-8 { margin-top:8px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mb-0 { margin-bottom:0 !important; }
.separator {
  width:50px; height:2px;
  background:var(--warm-sand);
  margin:20px 0;
}
.separator.center { margin:20px auto; }

/* ===== BREADCRUMB ===== */
.breadcrumb {
  display:flex; gap:8px; align-items:center;
  font-size:12px; color:rgba(255,255,255,.4);
  margin-bottom:12px;
}
.breadcrumb a { color:rgba(255,255,255,.55); }
.breadcrumb a:hover { color:var(--warm-sand); }
.breadcrumb span { opacity:.4; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .portfolio-grid { grid-template-columns:repeat(2,1fr); }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .about-grid { gap:40px; }
  .project-body-grid { grid-template-columns:1fr; }
  .service-detail-grid { grid-template-columns:1fr; }
  .service-detail-grid:nth-child(even) .service-detail-img { order:unset; }
  .contact-grid { grid-template-columns:1fr; }
}

@media (max-width: 768px) {
  .nav-menu {
    display:none; position:fixed;
    top:72px; left:0; right:0;
    background:#fff; flex-direction:column;
    padding:24px 28px; gap:20px;
    border-top:1px solid var(--border);
    box-shadow:0 12px 24px rgba(0,0,0,.1);
  }
  .nav-menu.open { display:flex; }
  .hamburger { display:flex; }
  .nav-actions { display:none; }
  .about-grid { grid-template-columns:1fr; gap:36px; }
  .about-image { order:-1; }
  .about-img-wrap::after { display:none; }
  .why-grid { grid-template-columns:1fr; gap:28px; }
  .testi-team-wrap { grid-template-columns:1fr; gap:48px; }
  .team-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
  .cta-inner { flex-direction:column; }
  .cta-btns { flex-direction:column; }
  .cta-btn { min-width:unset; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:6px; text-align:center; }
  .philosophy-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .hero-btns { flex-direction:column; }
  .hero-content { max-width:100%; }
  .project-meta-inner { gap:28px; }
  .project-body-grid { gap:32px; }
  .form-row { grid-template-columns:1fr; }
}

@media (max-width: 480px) {
  .portfolio-grid { grid-template-columns:1fr; }
  .services-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; }
  .testi-cards .testi-card:nth-child(2) { display:none; }
  .section { padding:60px 0; }
}
