:root {
  --ink: #14202a;
  --muted: #61707d;
  --paper: #fbf8f2;
  --card: #ffffff;
  --line: rgba(20, 32, 42, 0.14);
  --accent: #b85d22;
  --accent-dark: #743818;
  --shade: #edf1f3;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px clamp(18px, 4vw, 56px);
  background: rgba(251, 248, 242, 0.94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}
.brand { font-weight: 900; text-decoration: none; letter-spacing: -0.04em; }
nav { display: flex; gap: 18px; flex-wrap: wrap; font-size: 0.94rem; }
nav a, .nav-call { text-decoration: none; font-weight: 800; }
.nav-call { color: var(--accent-dark); }
section { scroll-margin-top: 88px; }
.hero, .door-hero, .excavation-hero, .studio-hero {
  padding: clamp(54px, 9vw, 118px) clamp(18px, 5vw, 72px);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 13px 19px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  text-decoration: none;
  font-weight: 900;
  box-shadow: 0 18px 38px rgba(20, 32, 42, 0.16);
}
.btn.ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); box-shadow: none; }
.eyebrow { margin: 0 0 12px; color: var(--accent-dark); font-weight: 900; text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.76rem; }
h1, h2, h3 { line-height: 0.98; letter-spacing: -0.055em; margin: 0; }
h1 { font-size: clamp(3rem, 7vw, 6.6rem); }
h2 { font-size: clamp(2rem, 4.5vw, 4.2rem); }
h3 { font-size: 1.35rem; }
.hero-copy p:not(.eyebrow), section > div > p, .contact-section p { color: var(--muted); font-size: 1.08rem; }
.review-strip {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 16px;
  padding: 22px clamp(18px, 5vw, 72px);
  background: var(--ink);
  color: #fff;
}
.rating-panel, .review-card {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 24px;
  padding: 18px;
}
.rating-panel span { font-size: 3rem; font-weight: 950; line-height: 1; }
.rating-panel p, .review-card p { margin: 8px 0 0; color: rgba(255,255,255,0.78); }
.stars { color: #f6bd38; letter-spacing: 0.1em; }
.review-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.review-card { margin: 0; }
.review-card cite { display: block; margin-top: 12px; font-style: normal; font-weight: 900; color: #fff; }
.contact-section {
  display: grid;
  grid-template-columns: 1.1fr 0.8fr;
  gap: 28px;
  padding: clamp(54px, 8vw, 96px) clamp(18px, 5vw, 72px);
  background: #fff;
}
.contact-card { border: 1px solid var(--line); border-radius: 28px; padding: 28px; background: var(--paper); }
.contact-card span { display: block; font-weight: 900; color: var(--muted); }
.contact-card a { display: block; font-size: clamp(2rem, 5vw, 4rem); line-height: 1; font-weight: 950; text-decoration: none; margin: 10px 0; color: var(--accent-dark); }
.site-footer { padding: 28px clamp(18px, 5vw, 72px); background: var(--ink); color: rgba(255,255,255,0.76); }
.site-footer a { color: #fff; }

.tdh-site { --paper: #f5f0e6; --accent: #d85f2e; --accent-dark: #8b2f15; }
.hero-tall { display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.8fr); gap: 48px; align-items: center; }
.hero-tall .hero-photo { margin: 0; transform: rotate(1.5deg); }
.framed img { border: 14px solid #fff; box-shadow: 0 28px 70px rgba(20,32,42,0.2); }
.framed figcaption { margin-top: 10px; font-weight: 900; color: var(--accent-dark); }
.paint-board { display: grid; grid-template-columns: 1.1fr 0.8fr; gap: 36px; padding: 76px clamp(18px, 5vw, 72px); }
.paint-board ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.paint-board li { padding: 20px; background: #fff; border-radius: 18px; font-weight: 950; border-left: 8px solid var(--accent); }
.split-proof, .showroom-section, .door-showcase, .sitework-feature, .detail-section { display: grid; grid-template-columns: 0.9fr 1fr; gap: 34px; align-items: center; padding: 76px clamp(18px, 5vw, 72px); background: #fff; }
.split-proof img, .showroom-section img, .door-showcase img, .sitework-feature img, .detail-section img { border-radius: 30px; width: 100%; height: 430px; object-fit: cover; }
.about-band, .promise-row, .service-after-sale, .work-values, .craft-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); padding: 1px; }
.about-band span, .promise-row span, .service-after-sale strong, .work-values span, .craft-band span { background: var(--paper); padding: 26px; text-align: center; font-weight: 950; }

.appliance-site { --paper: #f5f7fb; --ink: #182431; --accent: #2f6db3; --accent-dark: #16436f; }
.appliance-hero { display: grid; grid-template-columns: 0.8fr 1.1fr 0.8fr; gap: 28px; align-items: center; background: linear-gradient(135deg, #eaf2fb, #fff); }
.ticket-stack { background: var(--ink); color: #fff; border-radius: 30px; padding: 28px; transform: rotate(-2deg); }
.ticket-stack span { color: #9fd0ff; font-weight: 900; text-transform: uppercase; font-size: 0.78rem; letter-spacing: 0.12em; }
.ticket-stack strong { display: block; font-size: 2rem; line-height: 1; margin: 16px 0; }
.ticket-stack p { color: rgba(255,255,255,0.72); }
.hero-product { border-radius: 30px; height: 520px; object-fit: cover; box-shadow: 0 28px 70px rgba(20,32,42,0.18); }
.appliance-grid, .dirt-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 70px clamp(18px, 5vw, 72px); }
.appliance-grid article, .dirt-grid article { background: #fff; border-radius: 24px; padding: 24px; border: 1px solid var(--line); }

.door-site { --paper: #eef1ed; --ink: #17211f; --accent: #7b4b33; --accent-dark: #4a2d1f; }
.door-hero { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 0; align-items: stretch; min-height: 720px; }
.door-photo-panel img { width: 100%; height: 100%; object-fit: cover; border-radius: 40px 0 0 40px; }
.door-copy { background: #fff; padding: clamp(34px, 6vw, 76px); border-radius: 0 40px 40px 0; display: flex; flex-direction: column; justify-content: center; }
.door-services { padding: 76px clamp(18px, 5vw, 72px); background: #fff; }
.door-services ul { list-style: none; padding: 0; margin: 28px 0 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.door-services li span { display: block; padding: 22px; border-radius: 20px; background: var(--paper); font-weight: 950; }

.excavation-site { --paper: #efe8dc; --ink: #1f251b; --accent: #c36b25; --accent-dark: #6e3b17; }
.excavation-hero { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 42px; align-items: center; background: radial-gradient(circle at 15% 20%, #f7d7aa, transparent 35%), var(--paper); }
.machine-card { background: #fff; border-radius: 32px; padding: 14px; box-shadow: 0 30px 80px rgba(31,37,27,0.22); }
.machine-card img { border-radius: 24px; height: 440px; width: 100%; object-fit: cover; }
.machine-card span { display: block; padding: 15px; font-weight: 950; color: var(--accent-dark); }

.as-site { --paper: #fbf4ea; --ink: #231815; --accent: #a86d3c; --accent-dark: #633817; }
.studio-hero { display: grid; grid-template-columns: 1fr 0.8fr; gap: 46px; align-items: center; background: linear-gradient(90deg, #fbf4ea 0 70%, #ead4bf 70%); }
.stair-card { padding: 18px; background: #fff; border-radius: 36px; box-shadow: 0 28px 70px rgba(35,24,21,0.16); }
.stair-card img { border-radius: 24px; height: 560px; width: 100%; object-fit: cover; }
.numbered-services { padding: 76px clamp(18px, 5vw, 72px); background: #fff; }
.numbered-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 28px; }
.numbered-grid article { background: var(--paper); padding: 26px; border-radius: 24px; }
.numbered-grid span { color: var(--accent-dark); font-weight: 950; }

@media (max-width: 900px) {
  .site-header { align-items: flex-start; flex-direction: column; }
  .review-strip, .hero-tall, .appliance-hero, .door-hero, .excavation-hero, .studio-hero, .paint-board, .split-proof, .showroom-section, .door-showcase, .sitework-feature, .detail-section, .contact-section { grid-template-columns: 1fr; }
  .review-row, .appliance-grid, .dirt-grid, .door-services ul, .numbered-grid, .about-band, .promise-row, .service-after-sale, .work-values, .craft-band { grid-template-columns: 1fr; }
  .door-photo-panel img, .door-copy { border-radius: 30px; }
  .hero-product, .stair-card img, .machine-card img { height: auto; }
  h1 { font-size: clamp(2.7rem, 16vw, 4.4rem); }
}
