/* ═══════════════════════════════════════════════════════════════
   TLS KITCHENS — Premium Stylesheet
   Design language: timeless · crafted · architectural
   Palette: off-black · charcoal · walnut · stone · cream · aged brass
   Type: Cormorant Garamond (display serif) + Inter (sans body)

   To add a hero photograph: drop it in /images/ and set
   --hero-img below to url('images/your-photo.jpg').
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* ── Core palette ── */
  --ink:        #1a1815;   /* warm off-black */
  --char:       #24211c;   /* deep charcoal */
  --char-2:     #312d27;   /* raised charcoal (cards on dark) */
  --walnut:     #5b4632;   /* warm walnut */
  --walnut-lt:  #7c6044;   /* lighter walnut */
  --stone:      #8b8378;   /* muted stone-grey (body text on light) */
  --stone-lt:   #a9a094;   /* lighter stone */
  --cream:      #f4f0e8;   /* page background */
  --paper:      #faf7f0;   /* raised surfaces on light */
  --line:       #e2dccf;   /* hairline on light */
  --line-dk:    rgba(255,255,255,.12); /* hairline on dark */
  --brass:      #9c7b46;   /* aged brass accent */
  --brass-lt:   #b89766;   /* lit brass */

  --hero-img:   url('images/kitchen-08.jpg');

  --maxw:       1240px;
  --ease:       cubic-bezier(.33,0,.2,1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Inter', system-ui, sans-serif;
  color:var(--char); background:var(--cream);
  font-size:17px; line-height:1.7; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
a { color:inherit; text-decoration:none; transition:color .3s var(--ease); }

/* ── Display type ── */
h1, h2, h3, .serif {
  font-family:'Cormorant Garamond', Georgia, serif;
  font-weight:500; line-height:1.08; letter-spacing:.005em; color:var(--ink);
}
h1 { font-size:clamp(2.7rem, 6vw, 5rem); }
h2 { font-size:clamp(2rem, 4.2vw, 3.4rem); }
h3 { font-size:clamp(1.4rem, 2.4vw, 1.9rem); }

/* ── Eyebrow label ── */
.eyebrow {
  display:inline-block; font-family:'Inter',sans-serif;
  font-size:.72rem; font-weight:600; letter-spacing:.28em;
  text-transform:uppercase; color:var(--brass);
  margin-bottom:22px;
}
.eyebrow.center { display:block; text-align:center; }
.lead { font-size:1.12rem; color:var(--stone); line-height:1.8; }

/* ── Scroll reveal ── */
.reveal { opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal.d1 { transition-delay:.08s; }
.reveal.d2 { transition-delay:.16s; }
.reveal.d3 { transition-delay:.24s; }

/* ── Layout ── */
.section { padding:120px 32px; }
.section.tight { padding:88px 32px; }
.inner { max-width:var(--maxw); margin:0 auto; }
.narrow { max-width:760px; margin:0 auto; }
.bg-cream { background:var(--cream); }
.bg-paper { background:var(--paper); }
.bg-ink   { background:var(--ink);  color:var(--cream); }
.bg-char  { background:var(--char); color:var(--cream); }
.bg-ink h1, .bg-ink h2, .bg-ink h3,
.bg-char h1, .bg-char h2, .bg-char h3 { color:var(--paper); }
.bg-ink .lead, .bg-char .lead { color:var(--stone-lt); }

.section-head { max-width:640px; margin-bottom:64px; }
.section-head.center { margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2 { margin-bottom:20px; }
.rule { width:54px; height:1px; background:var(--brass); margin-bottom:26px; }
.rule.center { margin-left:auto; margin-right:auto; }

/* ══════════════════════════════════
   TOP BAR
══════════════════════════════════ */
.top-bar {
  background:var(--ink); color:var(--stone-lt);
  text-align:center; font-size:.74rem; font-weight:400;
  padding:11px 24px; letter-spacing:.12em; text-transform:uppercase;
}
.top-bar a { color:var(--brass-lt); font-weight:600; }
.top-bar a:hover { color:#fff; }

/* ══════════════════════════════════
   NAVIGATION (transparent → solid on scroll)
══════════════════════════════════ */
nav {
  position:sticky; top:0; z-index:200;
  background:transparent; transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav-inner {
  max-width:var(--maxw); margin:0 auto; padding:0 32px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  font-family:'Cormorant Garamond',serif; font-weight:600;
  font-size:1.7rem; letter-spacing:.02em; color:var(--cream);
  padding:26px 0; line-height:1; transition:color .4s var(--ease);
}
.nav-logo .amp { color:var(--brass-lt); }
.nav-links { display:flex; align-items:center; gap:38px; }
.nav-links a {
  font-size:.78rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:rgba(255,255,255,.82);
  padding:6px 0; position:relative; transition:color .3s var(--ease);
}
.nav-links a::after {
  content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brass-lt); transition:width .35s var(--ease);
}
.nav-links a:hover, .nav-links a.active { color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-cta {
  border:1px solid rgba(255,255,255,.4); padding:13px 24px !important;
  color:#fff !important; letter-spacing:.16em; transition:all .35s var(--ease);
}
.nav-cta::after { display:none; }
.nav-cta:hover { background:var(--brass); border-color:var(--brass); color:var(--ink) !important; }

/* Solid state */
nav.scrolled {
  background:var(--cream); border-bottom-color:var(--line);
  box-shadow:0 6px 30px rgba(26,24,21,.06);
}
nav.scrolled .nav-logo { color:var(--ink); }
nav.scrolled .nav-links a { color:var(--char); }
nav.scrolled .nav-links a:hover, nav.scrolled .nav-links a.active { color:var(--ink); }
nav.scrolled .nav-cta { border-color:var(--ink); color:var(--ink) !important; }
nav.scrolled .nav-cta:hover { background:var(--ink); border-color:var(--ink); color:var(--cream) !important; }
nav.scrolled .hamburger span { background:var(--ink); }

.hamburger { display:none; flex-direction:column; gap:6px; cursor:pointer; padding:10px 0; }
.hamburger span { width:26px; height:1.5px; background:#fff; display:block; transition:.3s; }
.mobile-menu { display:none; background:var(--ink); border-top:1px solid var(--line-dk); }
.mobile-menu a {
  display:block; color:rgba(255,255,255,.85); padding:17px 32px;
  border-bottom:1px solid var(--line-dk); font-size:.8rem;
  letter-spacing:.14em; text-transform:uppercase; font-weight:500;
}
.mobile-menu a:hover { background:rgba(255,255,255,.05); color:var(--brass-lt); }
.mobile-menu.open { display:block; }

/* ══════════════════════════════════
   BUTTONS
══════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:12px;
  font-family:'Inter',sans-serif; font-size:.78rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; cursor:pointer;
  padding:18px 38px; border:1px solid transparent;
  transition:all .4s var(--ease);
}
.btn-dark   { background:var(--ink); color:var(--cream); border-color:var(--ink); }
.btn-dark:hover { background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-brass  { background:var(--brass); color:var(--ink); border-color:var(--brass); }
.btn-brass:hover { background:var(--brass-lt); border-color:var(--brass-lt); }
.btn-line   { background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-line:hover { background:var(--ink); color:var(--cream); }
.btn-light  { background:transparent; color:var(--cream); border-color:rgba(255,255,255,.45); }
.btn-light:hover { background:var(--cream); color:var(--ink); border-color:var(--cream); }
.btn-solid-light { background:var(--cream); color:var(--ink); border-color:var(--cream); }
.btn-solid-light:hover { background:transparent; color:var(--cream); border-color:rgba(255,255,255,.6); }

/* Text link with arrow */
.link-arrow {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.76rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); padding-bottom:4px; border-bottom:1px solid var(--brass);
}
.link-arrow:hover { color:var(--walnut); border-color:var(--walnut); }

/* ══════════════════════════════════
   ICONS (thin line, inherit colour)
══════════════════════════════════ */
.ico { width:34px; height:34px; stroke:var(--brass); fill:none; stroke-width:1.25; stroke-linecap:round; stroke-linejoin:round; }
.ico-sm { width:22px; height:22px; }

/* ══════════════════════════════════
   HERO (homepage)
══════════════════════════════════ */
.hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  margin-top:-89px; padding:160px 32px 110px;
  color:var(--cream); overflow:hidden;
  background:
    linear-gradient(180deg, rgba(20,18,15,.55) 0%, rgba(20,18,15,.35) 40%, rgba(20,18,15,.82) 100%),
    var(--hero-img),
    linear-gradient(150deg, #2a2620 0%, #1c1916 55%, #15120f 100%);
  background-size:cover; background-position:center; background-repeat:no-repeat;
}
.hero::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 30% 40%, rgba(156,123,70,.10), transparent 70%);
}
.hero-inner { position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; width:100%; }
.hero-content { max-width:760px; }
.hero .eyebrow { color:var(--brass-lt); }
.hero h1 { color:#fff; margin-bottom:30px; font-weight:500; }
.hero h1 em { font-style:italic; color:var(--brass-lt); font-weight:400; }
.hero p { font-size:1.25rem; color:rgba(255,255,255,.85); max-width:560px; margin-bottom:46px; line-height:1.75; font-weight:300; }
.hero-btns { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.hero-scroll {
  position:absolute; bottom:38px; left:50%; transform:translateX(-50%);
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.55); display:flex; flex-direction:column; align-items:center; gap:12px; z-index:1;
}
.hero-scroll .bar { width:1px; height:46px; background:linear-gradient(var(--brass-lt), transparent); }

/* ══════════════════════════════════
   PILLARS (three columns)
══════════════════════════════════ */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.pillar { padding:8px 44px; border-left:1px solid var(--line); }
.pillar:first-child { padding-left:0; border-left:none; }
.pillar .ico { margin-bottom:28px; }
.pillar h3 { margin-bottom:14px; }
.pillar p { color:var(--stone); font-size:.98rem; line-height:1.8; }

/* ══════════════════════════════════
   FEATURED PROJECTS (editorial rows)
══════════════════════════════════ */
.project { display:grid; grid-template-columns:1.15fr 1fr; gap:72px; align-items:center; margin-bottom:120px; }
.project:last-child { margin-bottom:0; }
.project.reverse .project-media { order:2; }
.project-media {
  position:relative; aspect-ratio:4/3; overflow:hidden;
  background:linear-gradient(150deg, var(--walnut) 0%, var(--char) 70%);
}
.project-media.alt { background:linear-gradient(150deg, #3a342c 0%, var(--ink) 75%); }
.project-media.alt2 { background:linear-gradient(150deg, var(--walnut-lt) 0%, var(--walnut) 60%, var(--char) 100%); }
.project-media img { position:absolute; inset:0; z-index:2; width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.project:hover .project-media img { transform:scale(1.04); }
.project-caption {
  position:absolute; left:26px; bottom:24px; z-index:1;
  color:rgba(255,255,255,.92); font-family:'Cormorant Garamond',serif;
  font-style:italic; font-size:1.15rem; letter-spacing:.01em; pointer-events:none;
  text-shadow:0 1px 20px rgba(0,0,0,.5); padding-right:24px;
}
.project-body .eyebrow { margin-bottom:16px; }
.project-body h3 { font-size:clamp(1.7rem,2.6vw,2.3rem); margin-bottom:18px; }
.project-body p { color:var(--stone); margin-bottom:28px; line-height:1.85; }

/* ══════════════════════════════════
   THE DIFFERENCE (numbered list, dark)
══════════════════════════════════ */
.diff-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.diff-item { padding:40px 32px 8px; border-left:1px solid var(--line-dk); }
.diff-item:first-child { padding-left:0; border-left:none; }
.diff-num {
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-style:italic;
  color:var(--brass-lt); margin-bottom:20px; letter-spacing:.1em;
}
.diff-item h3 { font-size:1.45rem; margin-bottom:12px; color:var(--paper); }
.diff-item p { color:var(--stone-lt); font-size:.95rem; line-height:1.8; }

/* ══════════════════════════════════
   TESTIMONIALS (minimal, editorial)
══════════════════════════════════ */
.quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:56px; }
.quote { position:relative; padding-top:36px; border-top:1px solid var(--line); }
.quote .mark { font-family:'Cormorant Garamond',serif; font-size:3.4rem; line-height:.5; color:var(--brass); position:absolute; top:30px; left:0; }
.quote-text { font-family:'Cormorant Garamond',serif; font-size:1.45rem; font-style:italic; line-height:1.5; color:var(--ink); margin:22px 0 26px; font-weight:500; }
.quote-name { font-size:.74rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--walnut); }
.quote-src { font-size:.8rem; color:var(--stone); margin-top:5px; letter-spacing:.04em; }
.quote-stars { color:var(--brass); letter-spacing:4px; font-size:.8rem; }

.feature-quote { max-width:880px; margin:0 auto; text-align:center; }
.feature-quote p { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:clamp(1.7rem,3.2vw,2.5rem); line-height:1.4; color:var(--ink); font-weight:500; margin-bottom:30px; }
.feature-quote .quote-name { letter-spacing:.2em; }

/* ══════════════════════════════════
   PROCESS (numbered steps)
══════════════════════════════════ */
.process { display:grid; grid-template-columns:repeat(4,1fr); gap:0; counter-reset:step; }
.step { padding:0 36px; border-left:1px solid var(--line); position:relative; }
.step:first-child { padding-left:0; border-left:none; }
.step-num { font-family:'Cormorant Garamond',serif; font-size:3.2rem; font-weight:500; color:var(--brass); line-height:1; margin-bottom:22px; }
.step h3 { font-size:1.5rem; margin-bottom:12px; }
.step p { color:var(--stone); font-size:.95rem; line-height:1.8; }
.bg-char .step { border-color:var(--line-dk); }
.bg-char .step h3 { color:var(--paper); }
.bg-char .step p { color:var(--stone-lt); }

/* ══════════════════════════════════
   CTA BANNER
══════════════════════════════════ */
.cta { position:relative; text-align:center; padding:130px 32px; background:var(--ink); color:var(--cream); overflow:hidden; }
.cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 80% at 50% 0%, rgba(156,123,70,.16), transparent 65%); }
.cta-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
.cta .eyebrow { color:var(--brass-lt); }
.cta h2 { color:#fff; margin-bottom:22px; }
.cta p { color:rgba(255,255,255,.82); font-size:1.12rem; line-height:1.8; margin-bottom:40px; font-weight:300; }
.cta-btns { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }

/* ══════════════════════════════════
   PAGE HERO (inner pages)
══════════════════════════════════ */
.page-hero {
  position:relative; margin-top:-89px; padding:200px 32px 90px;
  color:var(--cream); text-align:center;
  background:linear-gradient(160deg, #2a2620 0%, #1c1916 60%, #15120f 100%);
}
.page-hero::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 30%, rgba(156,123,70,.12), transparent 70%); }
.page-hero-inner { position:relative; z-index:1; max-width:760px; margin:0 auto; }
.page-hero .eyebrow { color:var(--brass-lt); }
.page-hero h1 { color:#fff; margin-bottom:20px; }
.page-hero p { color:rgba(255,255,255,.82); font-size:1.1rem; line-height:1.75; font-weight:300; }
.breadcrumb { font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.55); margin-bottom:26px; }
.breadcrumb a { color:var(--brass-lt); }

/* ══════════════════════════════════
   ABOUT / SPLIT
══════════════════════════════════ */
.split { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.split.reverse .split-media { order:2; }
.split-media { position:relative; aspect-ratio:3/4; overflow:hidden; background:linear-gradient(150deg, var(--walnut) 0%, var(--char) 75%); }
.split-media img { position:absolute; inset:0; z-index:2; width:100%; height:100%; object-fit:cover; }
.split-caption { position:absolute; left:24px; bottom:22px; color:rgba(255,255,255,.9); font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.1rem; text-shadow:0 1px 18px rgba(0,0,0,.5); }
.split-body h2 { margin-bottom:24px; }
.split-body p { color:var(--stone); margin-bottom:18px; line-height:1.85; }

/* ══════════════════════════════════
   SERVICES GRID
══════════════════════════════════ */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.service-card { background:var(--paper); padding:48px 38px; transition:background .4s var(--ease); }
.service-card:hover { background:var(--cream); }
.s-icon { margin-bottom:26px; }
.s-icon .ico { width:32px; height:32px; }
.service-card h3 { font-size:1.5rem; margin-bottom:14px; }
.service-card p { color:var(--stone); font-size:.96rem; line-height:1.8; }

/* ══════════════════════════════════
   WHY / FEATURE ITEMS
══════════════════════════════════ */
.why-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:48px; }
.why-item { display:flex; gap:24px; align-items:flex-start; }
.why-icon { flex-shrink:0; width:52px; height:52px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; }
.why-icon .ico { width:26px; height:26px; }
.why-item h4 { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:500; color:var(--ink); margin-bottom:8px; }
.why-item p { color:var(--stone); font-size:.95rem; line-height:1.75; }

/* ══════════════════════════════════
   GALLERY
══════════════════════════════════ */
.photo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.photo-card { position:relative; overflow:hidden; aspect-ratio:4/3; background:linear-gradient(150deg, var(--walnut) 0%, var(--char) 75%); }
.photo-card:nth-child(3n+2) { background:linear-gradient(150deg, #3a342c 0%, var(--ink) 75%); }
.photo-card:nth-child(3n+3) { background:linear-gradient(150deg, var(--walnut-lt) 0%, var(--char) 80%); }
.photo-card.tall { aspect-ratio:3/4; }
.photo-card.wide { grid-column:span 2; aspect-ratio:16/9; }
.photo-card img { position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.photo-card:hover img { transform:scale(1.05); }
.photo-overlay { position:absolute; inset:0; z-index:3; background:linear-gradient(to top, rgba(20,18,15,.7) 0%, transparent 55%); opacity:0; transition:opacity .5s var(--ease); display:flex; align-items:flex-end; padding:24px; }
.photo-card:hover .photo-overlay { opacity:1; }
.photo-overlay span { color:#fff; font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.15rem; line-height:1.4; }
.photo-tag { position:absolute; left:22px; bottom:20px; z-index:0; color:rgba(255,255,255,.85); font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.05rem; text-shadow:0 1px 16px rgba(0,0,0,.45); pointer-events:none; }
.photo-card:hover .photo-tag { opacity:0; }

/* ══════════════════════════════════
   AREAS
══════════════════════════════════ */
.areas-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.area-card { background:var(--paper); border:1px solid var(--line); padding:34px 20px; text-align:center; transition:all .4s var(--ease); display:flex; flex-direction:column; align-items:center; gap:14px; }
.area-card .ico { stroke:var(--brass); }
.area-card:hover { background:var(--ink); border-color:var(--ink); }
.area-card:hover .ico { stroke:var(--brass-lt); }
.area-card:hover h4 { color:var(--cream); }
.area-card h4 { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:500; color:var(--ink); transition:color .4s var(--ease); }

/* ══════════════════════════════════
   TRUST BAR (restrained)
══════════════════════════════════ */
.trust-bar { background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust-bar-inner { max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; justify-content:center; }
.trust-item { display:flex; align-items:center; gap:12px; padding:26px 34px; font-size:.74rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--walnut); border-right:1px solid var(--line); }
.trust-item:last-child { border-right:none; }
.trust-item .ico { width:20px; height:20px; }

/* ══════════════════════════════════
   CONTACT
══════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.15fr; gap:72px; align-items:start; }
.contact-info h3 { font-size:1.9rem; margin-bottom:16px; }
.contact-info > p { color:var(--stone); margin-bottom:36px; }
.contact-detail { display:flex; gap:20px; margin-bottom:26px; align-items:flex-start; }
.ci-icon { flex-shrink:0; width:48px; height:48px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; }
.ci-icon .ico { width:22px; height:22px; }
.contact-detail h4 { font-size:.7rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--stone); margin-bottom:5px; }
.contact-detail p, .contact-detail a { font-size:1.02rem; color:var(--ink); font-weight:500; }
.contact-detail a:hover { color:var(--brass); }

.contact-form { background:var(--paper); border:1px solid var(--line); padding:52px; }
.contact-form h3 { font-size:1.8rem; margin-bottom:30px; }
.form-group { margin-bottom:22px; }
.form-group label { display:block; font-size:.7rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--char); margin-bottom:9px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:15px 16px; border:1px solid var(--line); background:var(--cream);
  font-family:inherit; font-size:.98rem; color:var(--ink); transition:all .3s var(--ease);
}
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--stone-lt); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline:none; border-color:var(--brass); background:#fff; box-shadow:0 0 0 3px rgba(156,123,70,.1);
}
.form-group textarea { height:120px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }

.creds-bar { display:flex; gap:36px; flex-wrap:wrap; align-items:center; padding:26px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cred-item { text-align:center; }
.cred-item .ico { margin:0 auto 8px; width:26px; height:26px; }
.cred-item p { font-size:.72rem; font-weight:600; letter-spacing:.06em; color:var(--walnut); line-height:1.5; text-transform:uppercase; }

/* ══════════════════════════════════
   WREN TRADE
══════════════════════════════════ */
.wren-callout { display:grid; grid-template-columns:auto 1fr; gap:72px; align-items:center; }
.wren-badge { background:var(--char); border:1px solid var(--line-dk); padding:44px 52px; text-align:left; min-width:240px; }
.wb-logo { font-family:'Cormorant Garamond',serif; font-size:2.6rem; font-weight:600; color:var(--paper); line-height:1; }
.wb-trade { display:block; font-size:.66rem; letter-spacing:.4em; text-transform:uppercase; font-weight:600; color:var(--brass-lt); margin-top:8px; font-family:'Inter',sans-serif; }
.wb-number { font-family:'Cormorant Garamond',serif; font-size:2.4rem; color:var(--brass-lt); margin:18px 0 6px; line-height:1; }
.wb-divider { height:1px; background:var(--line-dk); margin:10px 0 14px; }
.wb-name { font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--stone-lt); }
.wren-text h2 { margin-bottom:18px; }
.wren-text p { color:var(--stone); margin-bottom:16px; line-height:1.85; }
.wren-text strong { color:var(--ink); font-weight:600; }

/* ══════════════════════════════════
   CHECK LIST
══════════════════════════════════ */
.check-list { display:flex; flex-direction:column; gap:15px; margin:28px 0; }
.check-item { display:flex; align-items:flex-start; gap:14px; color:var(--char); font-size:.98rem; }
.check-item::before { content:''; flex-shrink:0; width:18px; height:18px; margin-top:4px; background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239c7b46' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E"); }

/* ══════════════════════════════════
   FOOTER
══════════════════════════════════ */
footer { background:var(--ink); color:var(--stone-lt); padding:96px 32px 36px; }
.footer-inner { max-width:var(--maxw); margin:0 auto 56px; display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:56px; }
.footer-brand .brand-name { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:600; color:var(--paper); margin-bottom:20px; }
.footer-brand .brand-name .amp { color:var(--brass-lt); }
.footer-brand p { font-size:.92rem; line-height:1.85; color:var(--stone-lt); max-width:380px; }
.footer-phone { display:inline-block; margin-top:22px; font-family:'Cormorant Garamond',serif; font-size:1.6rem; color:var(--brass-lt); }
.footer-phone:hover { color:#fff; }
.footer-addr { font-size:.84rem; margin-top:8px; color:var(--stone); }
footer h4 { font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--paper); margin-bottom:22px; }
footer ul li { margin-bottom:13px; }
footer ul li a { color:var(--stone-lt); font-size:.9rem; }
footer ul li a:hover { color:var(--brass-lt); }
.footer-bottom { max-width:var(--maxw); margin:0 auto; border-top:1px solid var(--line-dk); padding-top:30px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; font-size:.78rem; color:var(--stone); letter-spacing:.05em; }
.footer-creds { display:flex; gap:24px; flex-wrap:wrap; }
.footer-creds span { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--stone-lt); }

/* ══════════════════════════════════
   FLOATING CALL (mobile)
══════════════════════════════════ */
.float-call {
  display:none; position:fixed; bottom:22px; right:22px; z-index:999;
  background:var(--ink); color:var(--cream); padding:15px 26px;
  font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  align-items:center; gap:10px; box-shadow:0 10px 40px rgba(20,18,15,.4);
  border:1px solid var(--brass);
}
.float-call .ico { width:18px; height:18px; stroke:var(--brass-lt); }

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media(max-width:1024px) {
  .project, .split, .contact-grid, .wren-callout { grid-template-columns:1fr; gap:48px; }
  .project.reverse .project-media, .split.reverse .split-media { order:0; }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .diff-grid, .process { grid-template-columns:repeat(2,1fr); }
  .diff-item, .step { border-left:none; padding-left:0; padding-right:0; }
  .quotes { grid-template-columns:1fr; gap:40px; }
  .areas-grid { grid-template-columns:repeat(3,1fr); }
  .footer-inner { grid-template-columns:1fr 1fr; gap:40px; }
  .split-media { aspect-ratio:4/3; }
}
@media(max-width:768px) {
  body { font-size:16px; }
  .section { padding:80px 24px; }
  .cta, .page-hero { padding-left:24px; padding-right:24px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .pillars { grid-template-columns:1fr; gap:48px; }
  .pillar { padding:0 0 40px; border-left:none; border-bottom:1px solid var(--line); }
  .pillar:last-child { border-bottom:none; padding-bottom:0; }
  .why-grid { grid-template-columns:1fr; gap:36px; }
  .float-call { display:inline-flex; }
  .contact-form { padding:36px 26px; }
  .hero { padding:130px 24px 90px; min-height:90vh; }
}
@media(max-width:560px) {
  .services-grid, .diff-grid, .process, .areas-grid { grid-template-columns:1fr; }
  .photo-grid { grid-template-columns:1fr; }
  .photo-card.wide, .photo-card.tall { grid-column:span 1; aspect-ratio:4/3; }
  .footer-inner { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .wren-badge { width:100%; }
  .hero-btns .btn, .cta-btns .btn { width:100%; justify-content:center; }
}

/* ─── Brand logo (image) ─── */
.nav-logo { padding:14px 0; line-height:0; display:flex; align-items:center; }
.nav-logo img { height:50px; width:auto; display:block; }
.nav-logo .logo-dark { display:none; }
nav.scrolled .nav-logo .logo-light { display:none; }
nav.scrolled .nav-logo .logo-dark { display:block; }
.footer-brand .brand-name { line-height:0; margin-bottom:22px; }
.footer-logo { height:104px; width:auto; display:block; }
@media (max-width:768px){ .nav-logo img{ height:44px; } .footer-logo{ height:88px; } }
