
:root {
  --ink:#171615;
  --muted:#615f5b;
  --line:#ded9ce;
  --paper:#fbfaf6;
  --stone:#efede7;
  --graphite:#2f2d2b;
  --sage:#60766d;
  --clay:#b15f46;
  --white:#ffffff;
  --shadow:0 16px 48px rgba(23,22,21,.12);
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; color:var(--ink); background:var(--paper); font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; letter-spacing:0; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
.container { width:min(1160px, calc(100% - 40px)); margin:0 auto; }
.narrow { width:min(860px, calc(100% - 40px)); }
.site-header { position:fixed; inset:18px 0 auto; z-index:50; pointer-events:none; }
.nav-wrap { width:min(1120px, calc(100% - 28px)); margin:0 auto; pointer-events:auto; }
.nav-pill { height:72px; display:flex; align-items:center; gap:22px; justify-content:space-between; padding:8px 10px 8px 18px; border:1px solid rgba(222,217,206,.86); background:rgba(251,250,246,.82); backdrop-filter:blur(18px); box-shadow:0 10px 34px rgba(23,22,21,.12); border-radius:8px; }
.nav-logo { display:flex; align-items:center; width:174px; height:56px; overflow:hidden; }
.nav-logo img { width:150px; height:auto; object-fit:contain; }
.nav-links { display:flex; gap:8px; align-items:center; }
.nav-links a { padding:10px 14px; color:#3c3935; font-size:14px; font-weight:650; border-radius:8px; }
.nav-links a.active,.nav-links a:hover { background:var(--stone); }
.nav-cta { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 18px; background:var(--ink); color:#fff; border-radius:8px; font-weight:750; font-size:14px; white-space:nowrap; }
.menu-toggle { display:none; border:0; background:var(--ink); width:44px; height:44px; border-radius:8px; padding:11px; }
.menu-toggle span { display:block; height:2px; background:#fff; margin:5px 0; }
.mobile-menu { display:none; }
.hero { min-height:88vh; display:grid; grid-template-columns:minmax(280px, 44%) 1fr; align-items:center; gap:54px; padding:128px max(30px, calc((100vw - 1160px)/2)) 64px; background:linear-gradient(90deg, rgba(251,250,246,.94), rgba(251,250,246,.76)), url("/clients/tile-by-design/img/source-03.jpg"); background-size:cover; }
.hero-media { position:relative; align-self:stretch; min-height:520px; border-radius:8px; overflow:hidden; box-shadow:var(--shadow); border:1px solid rgba(222,217,206,.85); background:#fff; }
.hero-media img { width:100%; height:100%; object-fit:cover; filter:saturate(.88) contrast(1.05); }
.hero-content { max-width:720px; }
.hero-kicker,.eyebrow { display:block; color:var(--sage); font-weight:800; text-transform:uppercase; font-size:13px; letter-spacing:0; margin-bottom:14px; }
h1,h2,h3,p { margin-top:0; }
.hero h1 { font-size:78px; line-height:.94; max-width:760px; margin-bottom:24px; font-weight:850; letter-spacing:0; }
.hero p { font-size:21px; line-height:1.55; color:#34312d; max-width:690px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:30px; }
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:50px; padding:0 18px; border-radius:8px; font-weight:800; border:1px solid var(--ink); }
.btn-primary { background:var(--ink); color:#fff; }
.btn-secondary { background:rgba(255,255,255,.72); color:var(--ink); }
.hero-proof { grid-column:1 / -1; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.hero-proof span { background:rgba(255,255,255,.8); padding:18px; font-weight:850; text-align:center; }
.service-strip { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; }
.service-strip div { padding:28px 36px; border-right:1px solid var(--line); }
.service-strip div:last-child { border-right:0; }
.service-strip strong { display:block; font-size:20px; margin-bottom:6px; }
.service-strip span { color:var(--muted); line-height:1.5; }
.section { padding:96px 0; }
.section-head { margin-bottom:38px; }
.section-head.split { display:grid; grid-template-columns:1.1fr .8fr; gap:56px; align-items:end; }
.section-head h2,.image-copy h2,.about-preview h2,.contact-band h2,.page-hero h1 { font-size:48px; line-height:1.02; margin-bottom:18px; font-weight:850; letter-spacing:0; }
.section-head p,.image-copy p,.about-preview p,.page-hero p { color:var(--muted); font-size:18px; line-height:1.65; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.service-card { min-height:268px; padding:26px; background:#fff; border:1px solid var(--line); border-radius:8px; display:flex; flex-direction:column; box-shadow:0 8px 24px rgba(23,22,21,.06); }
.service-card.feature { background:linear-gradient(135deg, #fff, #f0eee6); }
.card-index { color:var(--clay); font-weight:850; margin-bottom:28px; }
.service-card h3 { font-size:24px; line-height:1.12; margin-bottom:12px; }
.service-card p { color:var(--muted); line-height:1.55; }
.service-card a { margin-top:auto; font-weight:800; color:var(--sage); }
.image-band { display:grid; grid-template-columns:.8fr 1.2fr; gap:44px; align-items:center; padding:96px max(30px, calc((100vw - 1160px)/2)); background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.image-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.image-grid img { width:100%; height:310px; object-fit:cover; border-radius:8px; border:1px solid var(--line); }
.image-grid img:first-child { grid-row:span 2; height:632px; }
.text-link { font-weight:850; color:var(--clay); }
.about-preview { padding:104px 0; background:linear-gradient(180deg, rgba(96,118,109,.08), rgba(96,118,109,.02)); text-align:center; }
.reviews-section { padding:92px 0; background:var(--paper); overflow:hidden; }
.reviews-section .section-head { text-align:center; max-width:780px; margin:0 auto 34px; }
.gr-summary { display:flex; align-items:center; justify-content:space-between; gap:24px; max-width:920px; margin:0 auto 24px; padding:20px; background:#fff; border:1px solid var(--line); border-radius:8px; }
.gr-sum-left { display:flex; align-items:center; gap:18px; }
.gr-logo { width:56px; height:56px; display:grid; place-items:center; background:var(--ink); color:#fff; border-radius:50%; font-weight:850; font-size:26px; }
.gr-meta-top { color:var(--muted); font-size:13px; font-weight:800; text-transform:uppercase; }
.gr-score { font-size:44px; font-weight:900; line-height:1; }
.gr-stars { font-weight:850; }
.gr-sub { color:var(--muted); }
.gr-cta { min-height:44px; display:inline-flex; align-items:center; padding:0 15px; background:var(--stone); border-radius:8px; font-weight:800; }
.gr-marquee { overflow:hidden; margin:12px 0; }
.gr-track { display:flex; gap:12px; width:max-content; animation:marquee 30s linear infinite; }
.gr-marquee.reverse .gr-track { animation-direction:reverse; }
.gr-card { width:330px; min-height:158px; background:#fff; border:1px solid var(--line); border-radius:8px; padding:20px; box-shadow:0 6px 18px rgba(23,22,21,.06); }
.gr-card strong { display:block; margin-bottom:8px; }
.gr-card p { color:var(--muted); line-height:1.55; margin-bottom:0; }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.contact-band { display:flex; justify-content:space-between; align-items:center; gap:28px; padding:70px max(30px, calc((100vw - 1160px)/2)); background:var(--graphite); color:#fff; }
.contact-band h2 { color:#fff; margin:0; }
.subpage { padding-top:110px; }
.page-hero { padding:84px max(30px, calc((100vw - 980px)/2)); background:linear-gradient(135deg,#fff,var(--stone)); }
.page-hero.compact { text-align:center; }
.page-hero p { max-width:760px; }
.page-hero.compact p { margin-left:auto; margin-right:auto; }
.service-detail { background:linear-gradient(rgba(251,250,246,.88), rgba(251,250,246,.92)), url("/clients/tile-by-design/img/source-01.jpg"); background-size:cover; }
.process-band { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.process-band div { background:#fff; padding:44px; }
.process-band span { color:var(--clay); font-weight:900; }
.process-band h2 { font-size:26px; margin:12px 0; }
.process-band p { color:var(--muted); line-height:1.6; }
.detail-layout { width:min(1080px, calc(100% - 40px)); margin:72px auto; display:grid; grid-template-columns:1fr 320px; gap:28px; }
.detail-layout article,.detail-layout aside,.contact-panel,.quote-form { background:#fff; border:1px solid var(--line); border-radius:8px; padding:30px; }
.detail-layout h2,.contact-panel h2 { font-size:28px; margin-bottom:14px; }
.detail-layout p,.detail-layout li { color:var(--muted); line-height:1.65; }
.tick-list { padding-left:20px; }
.detail-layout aside ul { padding-left:18px; line-height:1.9; }
.gallery-grid { width:min(1160px, calc(100% - 40px)); margin:72px auto; display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery-grid figure { margin:0; background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.gallery-grid img { width:100%; height:300px; object-fit:cover; }
.gallery-grid figcaption { padding:14px; color:var(--muted); font-size:14px; }
.story-grid { width:min(1060px, calc(100% - 40px)); margin:78px auto; display:grid; grid-template-columns:.9fr 1fr; gap:44px; align-items:center; }
.story-grid img { border-radius:8px; border:1px solid var(--line); }
.story-grid h2 { font-size:42px; line-height:1.06; }
.story-grid p { color:var(--muted); line-height:1.7; font-size:18px; }
.contact-grid { width:min(1040px, calc(100% - 40px)); margin:72px auto; display:grid; grid-template-columns:.85fr 1.15fr; gap:20px; }
.big-phone { display:block; font-size:40px; font-weight:900; margin:12px 0 20px; color:var(--clay); }
.quote-form { display:grid; gap:16px; }
.quote-form label { display:grid; gap:8px; color:var(--muted); font-weight:800; }
.quote-form input,.quote-form textarea { width:100%; border:1px solid var(--line); border-radius:8px; padding:14px; font:inherit; color:var(--ink); background:var(--paper); }
.quote-form textarea { min-height:140px; resize:vertical; }
.quote-form button { border:0; background:var(--ink); color:#fff; border-radius:8px; padding:15px 18px; font-weight:850; font:inherit; cursor:pointer; }
.faq-list { width:min(860px, calc(100% - 40px)); margin:72px auto; display:grid; gap:12px; }
.faq-list details { background:#fff; border:1px solid var(--line); border-radius:8px; padding:22px; }
.faq-list summary { cursor:pointer; font-size:19px; font-weight:850; }
.faq-list p { color:var(--muted); line-height:1.65; margin:14px 0 0; }
.site-footer { background:#242220; color:#fff; }
.footer-inner { width:min(1160px, calc(100% - 40px)); margin:0 auto; display:grid; grid-template-columns:1.3fr .7fr 1fr 1fr .9fr; gap:28px; padding:62px 0; }
.footer-brand img { width:88px; height:auto; margin-bottom:18px; filter:drop-shadow(0 8px 20px rgba(0,0,0,.18)); }
.footer-brand p,.footer-col li { color:#d7d2c8; line-height:1.65; }
.footer-phone { display:inline-flex; margin-top:10px; font-weight:900; color:#fff; }
.footer-col h2 { font-size:15px; text-transform:uppercase; margin-bottom:14px; color:#fff; }
.footer-col ul { list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer-col a { color:#fff; }
.footer-base { border-top:1px solid rgba(255,255,255,.14); padding:18px max(30px, calc((100vw - 1160px)/2)); color:#d7d2c8; font-size:14px; }
.sticky-call { position:fixed; display:none; z-index:40; left:12px; right:12px; bottom:12px; min-height:52px; align-items:center; justify-content:center; border-radius:8px; color:#fff; background:var(--ink); box-shadow:var(--shadow); font-weight:900; opacity:0; visibility:hidden; transform:translateY(86px); transition:transform .22s ease, opacity .22s ease, visibility .22s ease; pointer-events:none; }
.sticky-call.visible { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }
@media (max-width: 980px) {
  .nav-links,.nav-cta { display:none; }
  .menu-toggle { display:block; }
  .nav-pill { height:66px; }
  .mobile-menu { position:fixed; inset:92px 14px auto; background:#fff; border:1px solid var(--line); border-radius:8px; box-shadow:var(--shadow); }
  .mobile-menu.open { display:block; }
  .mobile-menu-inner { display:grid; gap:4px; padding:14px; }
  .mobile-menu a { padding:14px; border-radius:8px; font-weight:850; }
  .mobile-call { background:var(--ink); color:#fff; text-align:center; }
  .hero { grid-template-columns:1fr; min-height:0; padding-top:112px; gap:28px; }
  .hero-media { min-height:300px; }
  .hero h1 { font-size:44px; }
  .hero p { font-size:18px; }
  .hero-proof,.service-strip,.section-head.split,.image-band,.process-band,.detail-layout,.story-grid,.contact-grid { grid-template-columns:1fr; }
  .service-strip div { border-right:0; border-bottom:1px solid var(--line); }
  .services-grid,.gallery-grid { grid-template-columns:1fr 1fr; }
  .image-grid img,.image-grid img:first-child { height:260px; grid-row:auto; }
  .contact-band { align-items:flex-start; flex-direction:column; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width: 640px) {
  .site-header { inset:10px 0 auto; }
  .nav-wrap,.container,.narrow,.gallery-grid,.story-grid,.contact-grid,.detail-layout,.faq-list { width:calc(100% - 24px); }
  .nav-logo { width:150px; }
  .hero { padding:96px 16px 36px; }
  .hero h1 { font-size:38px; line-height:1.02; }
  .hero-actions,.gr-summary { flex-direction:column; align-items:stretch; }
  .services-grid,.gallery-grid,.footer-inner { grid-template-columns:1fr; }
  .section,.reviews-section,.about-preview { padding:64px 0; }
  .section-head h2,.image-copy h2,.about-preview h2,.contact-band h2,.page-hero h1 { font-size:34px; }
  .image-band,.page-hero,.contact-band { padding-left:16px; padding-right:16px; }
  .gr-card { width:292px; }
  .big-phone { font-size:30px; }
  .sticky-call { display:flex; }
  .site-footer { padding-bottom:70px; }
}
