/* ============================================================
   NJ Home Project — main.css
   Depends on tokens.css being loaded first.
   ============================================================ */

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { display: block; max-width: 100%; }
ul { list-style: none; margin: 0; padding: 0; }
a { text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ── Layout ─────────────────────────────────────────────────── */
.container       { max-width: var(--container); margin: 0 auto; padding: 0 32px; }
.container-narrow{ max-width: var(--container-narrow); margin: 0 auto; padding: 0 32px; }
.section         { padding: var(--s-24) 0; }
.section-tight   { padding: var(--s-16) 0; }
.section-sm      { padding: var(--s-12) 0; }

/* ── Topbar ─────────────────────────────────────────────────── */
.topbar { background: var(--ink-900); color: var(--cream-50); font-size: 13px; padding: 8px 0; }
.topbar .container { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.topbar a { color: var(--cream-50); text-decoration: none; display: inline-flex; gap: 6px; align-items: center; transition: color var(--dur) var(--ease-out); }
.topbar a:hover { color: var(--clay-300); }
.topbar .left  { display: flex; gap: 18px; align-items: center; color: var(--slate-300); }
.topbar .right { display: flex; gap: 18px; align-items: center; }
.topbar i, .topbar svg { width: 14px; height: 14px; }

/* ── Navbar ─────────────────────────────────────────────────── */
.navbar { background: var(--cream-50); border-bottom: 1px solid var(--border); padding: 18px 0; position: sticky; top: 0; z-index: 100; }
.navbar .container { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.navbar .logo { height: 40px; }
.navbar nav { display: flex; gap: 28px; }
.navbar nav a { font-size: 14px; font-weight: 500; color: var(--ink-900); padding: 8px 0; position: relative; }
.navbar nav a:hover { color: var(--clay-600); }
.navbar nav a.active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: var(--clay-500); }
.navbar .cta-group { display: flex; gap: 12px; align-items: center; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans); font-weight: 600; font-size: 14px;
  border: 1px solid transparent; border-radius: var(--radius);
  padding: 10px 18px; cursor: pointer; letter-spacing: -0.005em;
  transition: all var(--dur) var(--ease-out); text-decoration: none;
  white-space: nowrap;
}
.btn i, .btn svg { width: 16px; height: 16px; }
.btn-sm  { padding: 7px 14px; font-size: 13px; }
.btn-lg  { padding: 14px 24px; font-size: 15px; }
.btn-primary  { background: var(--clay-500); color: var(--cream-50); box-shadow: 0 1px 2px rgba(16,25,42,.08), inset 0 1px 0 rgba(255,255,255,.18); }
.btn-primary:hover  { background: var(--clay-600); }
.btn-primary:active { background: var(--clay-700); transform: translateY(1px); box-shadow: none; }
.btn-dark    { background: var(--ink-900); color: var(--cream-50); }
.btn-dark:hover    { background: var(--ink-800); }
.btn-outline { background: transparent; color: var(--ink-900); border-color: var(--ink-900); }
.btn-outline:hover { background: var(--ink-900); color: var(--cream-50); }
.btn-ghost   { background: transparent; color: var(--ink-900); }
.btn-ghost:hover   { background: var(--cream-200); }
.btn-ghost-light   { background: transparent; color: var(--cream-50); border-color: rgba(255,255,255,.35); }
.btn-ghost-light:hover { background: rgba(255,255,255,.1); }
.btn-link { background: transparent; color: var(--clay-600); padding: 6px 0; font-weight: 600; text-decoration: underline; text-decoration-color: var(--clay-300); text-underline-offset: 4px; }
.btn-link:hover { text-decoration-color: var(--clay-600); }

/* ── Surface / card ─────────────────────────────────────────── */
.surface { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 24px; }
.surface-elevated { box-shadow: var(--shadow); }
.surface-2 { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 24px; }

/* ── Hero ───────────────────────────────────────────────────── */
.hero { background: var(--cream-50); padding: 80px 0 100px; position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.hero h1 { font-family: var(--font-display); font-weight: 500; font-size: clamp(2.5rem, 5vw, 4.5rem); line-height: 1.02; letter-spacing: -0.025em; color: var(--ink-900); margin-top: 20px; }
.hero h1 em { font-style: italic; color: var(--clay-600); font-weight: 400; }
.hero .lede { font-size: 19px; line-height: 1.55; color: var(--slate-500); margin: 24px 0 32px; max-width: 480px; }
.hero-actions { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.hero-trust { display: flex; gap: 24px; margin-top: 40px; align-items: center; }
.avatar-stack { display: flex; }
.avatar { width: 36px; height: 36px; border-radius: 50%; border: 2px solid var(--cream-50); font-family: var(--font-display); color: white; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 500; flex-shrink: 0; }
.avatar + .avatar { margin-left: -10px; }
.hero-stars { display: flex; gap: 4px; align-items: center; margin-bottom: 4px; }
.hero-stars i { width: 14px; height: 14px; color: var(--clay-500); fill: var(--clay-500); }
.hero-rating-num { margin-left: 6px; font-size: 13px; font-weight: 600; }
.hero-rating-src { font-size: 12px; color: var(--slate-500); }

/* Hero visual placeholder */
.hero-visual { aspect-ratio: 4/5; background: linear-gradient(135deg, var(--cream-200) 0%, var(--cream-300) 100%); border-radius: var(--radius-lg); position: relative; overflow: hidden; display: flex; align-items: flex-end; padding: 24px; }
.hero-visual::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent, transparent 24px, rgba(16,25,42,.025) 24px, rgba(16,25,42,.025) 25px); }
.hero-visual-tag { background: var(--cream-50); border-radius: 10px; padding: 14px 18px; display: flex; gap: 12px; align-items: center; box-shadow: var(--shadow); position: relative; }
.hero-visual-tag .num { font-family: var(--font-display); font-size: 28px; color: var(--clay-600); line-height: 1; }
.hero-visual-tag .lbl { font-size: 12px; color: var(--slate-500); line-height: 1.3; }
.hero-pin { position: absolute; padding: 8px 12px; background: var(--ink-900); color: var(--cream-50); font-family: var(--font-mono); font-size: 11px; border-radius: var(--radius-sm); }

/* ── Trust strip ────────────────────────────────────────────── */
.trust-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; padding: 32px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.trust-strip .stat .icon { color: var(--clay-600); margin-bottom: 10px; display: block; width: 22px; height: 22px; }
.trust-strip .stat .big { font-family: var(--font-display); font-size: 32px; line-height: 1; color: var(--ink-900); }
.trust-strip .stat .lbl { font-size: 13px; color: var(--slate-500); margin-top: 6px; }

/* ── Service grid ───────────────────────────────────────────── */
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 24px; transition: all 200ms var(--ease-out); display: flex; flex-direction: column; gap: 14px; }
.service-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--clay-300); }
.service-card .icon-frame { width: 48px; height: 48px; border-radius: 10px; background: var(--clay-100); color: var(--clay-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.service-card .icon-frame i { width: 24px; height: 24px; }
.service-card h3 { font-family: var(--font-display); font-size: 22px; font-weight: 500; }
.service-card .desc { font-size: 14px; color: var(--slate-500); line-height: 1.55; flex: 1; }
.service-card .meta { display: flex; justify-content: space-between; align-items: center; padding-top: 14px; border-top: 1px solid var(--rule); font-size: 12px; color: var(--slate-500); }
.service-card .meta .price { font-family: var(--font-display); font-size: 18px; color: var(--ink-900); }
.service-card .meta .eta { display: inline-flex; gap: 4px; align-items: center; }
.service-card .meta .eta i { width: 13px; height: 13px; }
.section-split { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; gap: 24px; flex-wrap: wrap; }
.section-split h2 { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 500; margin-top: 12px; line-height: 1.05; }
.section-split .lede { max-width: 420px; color: var(--slate-500); font-size: 15px; line-height: 1.6; }

/* ── Process steps ──────────────────────────────────────────── */
.process { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.process-step .num { font-family: var(--font-display); font-size: 56px; font-weight: 400; color: var(--clay-500); line-height: 1; font-style: italic; }
.process-step h4 { font-family: var(--font-display); font-size: 22px; margin: 8px 0; }
.process-step p { font-size: 14px; color: var(--slate-500); line-height: 1.55; }

/* ── Project grid / tiles ───────────────────────────────────── */
.project-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.project-tile { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; cursor: pointer; transition: all 200ms var(--ease-out); text-decoration: none; color: inherit; display: block; }
.project-tile:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.project-tile .photo { aspect-ratio: 4/3; position: relative; display: flex; align-items: flex-end; padding: 14px; background-size: cover; background-position: center; }
.project-tile .photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(16,25,42,.55) 100%); }
.project-tile .tag { position: relative; z-index: 1; background: rgba(251,248,242,.95); color: var(--ink-900); font-size: 11px; font-weight: 600; padding: 4px 8px; border-radius: 4px; }
.project-tile .info { padding: 16px 18px; }
.project-tile h4 { font-family: var(--font-display); font-size: 20px; font-weight: 500; }
.project-tile .meta { font-size: 12px; color: var(--slate-500); margin-top: 4px; display: flex; gap: 10px; align-items: center; }
.project-tile .meta .mono { font-family: var(--font-mono); }
.project-tile .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--slate-300); flex-shrink: 0; }

/* Project filter pills */
.filter-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-pill { font-family: var(--font-sans); font-size: 13px; font-weight: 600; padding: 7px 14px; border-radius: var(--radius-pill); border: 1px solid var(--border-strong); background: transparent; color: var(--ink-900); cursor: pointer; transition: all 150ms; text-decoration: none; display: inline-block; }
.filter-pill:hover { border-color: var(--ink-700); }
.filter-pill.active { background: var(--ink-900); color: var(--cream-50); border-color: var(--ink-900); }

/* ── CTA band ───────────────────────────────────────────────── */
.cta-band { background: var(--ink-900); color: var(--cream-50); border-radius: var(--radius-lg); padding: 64px 56px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; }
.cta-band h2 { font-family: var(--font-display); font-size: clamp(2rem, 3.5vw, 3rem); font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; margin-top: 12px; }
.cta-band h2 em { color: var(--clay-400); font-style: italic; font-weight: 400; }
.cta-band p { color: var(--slate-300); font-size: 16px; line-height: 1.6; margin-top: 16px; }
.cta-band-actions { display: flex; gap: 14px; margin-top: 28px; flex-wrap: wrap; }
.cta-checklist { display: flex; flex-direction: column; gap: 18px; }
.cta-check { display: flex; gap: 12px; align-items: center; }
.cta-check-icon { width: 28px; height: 28px; border-radius: 50%; background: var(--clay-500); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cta-check-icon i { width: 14px; height: 14px; color: white; stroke-width: 3; }
.cta-check span { font-size: 15px; }

/* ── Testimonials ───────────────────────────────────────────── */
.testimonial-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.quote-large { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 500; line-height: 1.25; letter-spacing: -0.01em; color: var(--ink-900); text-wrap: balance; margin-top: 20px; }
.reviewer { display: flex; align-items: center; gap: 14px; margin-top: 28px; }
.reviewer-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--clay-500); color: white; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 18px; flex-shrink: 0; }
.reviewer-name { font-weight: 600; font-size: 15px; }
.reviewer-sub  { font-size: 13px; color: var(--slate-500); margin-top: 2px; }
.mini-reviews  { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mini-stars { display: flex; gap: 2px; margin-bottom: 10px; }
.mini-stars i { width: 12px; height: 12px; color: var(--clay-500); fill: var(--clay-500); }
.mini-text { font-size: 14px; line-height: 1.5; }
.mini-who { font-size: 12px; color: var(--slate-500); margin-top: 12px; }

/* ── Gallery page ───────────────────────────────────────────── */
.page-hero { background: var(--ink-900); color: var(--cream-50); padding: 52px 0 48px; }
.page-hero .breadcrumb { font-size: 13px; color: var(--slate-400); margin-bottom: 12px; }
.page-hero .breadcrumb a { color: var(--slate-400); }
.page-hero .breadcrumb a:hover { color: var(--cream-50); }
.page-hero h1 { font-size: clamp(2rem, 4vw, 3rem); font-weight: 500; }
.page-hero .sub { font-size: 17px; color: var(--slate-300); margin-top: 8px; }
.category-pill { display: inline-block; background: rgba(255,255,255,.12); color: var(--cream-50); font-family: var(--font-sans); font-size: 12px; font-weight: 600; letter-spacing: var(--tracking-caps); text-transform: uppercase; padding: 4px 10px; border-radius: var(--radius-pill); margin-bottom: 12px; }
.gallery-count { font-size: 14px; color: var(--slate-500); margin-bottom: 24px; }
.gallery-empty { text-align: center; padding: 64px 0; }
.gallery-empty h3 { font-family: var(--font-display); font-size: 28px; color: var(--ink-900); margin-bottom: 8px; }
.gallery-empty p { color: var(--slate-500); }

/* ── Project detail ─────────────────────────────────────────── */
.project-body { display: grid; grid-template-columns: 1fr 360px; gap: 48px; align-items: start; }
.photo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 40px; }
.photo-placeholder { aspect-ratio: 4/3; background: linear-gradient(135deg, var(--cream-200), var(--cream-300)); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 12px; color: var(--slate-400); }
.photo-placeholder:first-child { grid-column: span 2; aspect-ratio: 16/9; }
.project-panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; position: sticky; top: 90px; }
.project-panel-head { background: var(--ink-900); color: var(--cream-50); padding: 20px 24px; }
.project-panel-head h3 { font-size: 16px; font-weight: 600; font-family: var(--font-sans); }
.project-panel-body { padding: 20px 24px; }
.detail-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--rule); font-size: 14px; }
.detail-row:last-child { border-bottom: none; }
.detail-row dt { color: var(--fg-muted); }
.detail-row dd { font-weight: 600; color: var(--ink-900); font-family: var(--font-sans); }
.project-desc h2 { font-size: var(--text-2xl); margin-bottom: 16px; }
.project-desc p { color: var(--slate-500); line-height: 1.75; margin-bottom: 16px; }
.related-section { background: var(--cream-200); padding: var(--s-16) 0; }

/* ── About page ─────────────────────────────────────────────── */
.about-story { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.stat-card { background: var(--ink-900); color: var(--cream-50); border-radius: var(--radius-lg); padding: 32px 24px; }
.stat-card .big { font-family: var(--font-display); font-size: 3rem; color: var(--clay-400); line-height: 1; margin-bottom: 8px; }
.stat-card .lbl { font-size: 14px; color: var(--slate-300); }
.about-creds { margin-top: 24px; display: flex; flex-direction: column; gap: 10px; }
.about-cred { display: flex; gap: 10px; align-items: flex-start; font-size: 15px; color: var(--slate-500); }
.about-cred i { width: 16px; height: 16px; color: var(--clay-500); flex-shrink: 0; margin-top: 2px; }

/* ── Contact / Forms ────────────────────────────────────────── */
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.contact-info h2 { font-size: var(--text-3xl); margin-bottom: 12px; }
.contact-info .lede { color: var(--slate-500); line-height: 1.7; margin-bottom: 32px; }
.contact-detail { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 16px; }
.contact-detail-icon { width: 36px; height: 36px; border-radius: var(--radius); background: var(--clay-100); color: var(--clay-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-detail-icon i { width: 16px; height: 16px; }
.contact-detail strong { display: block; font-size: 13px; font-weight: 600; color: var(--ink-900); }
.contact-detail span, .contact-detail a { font-size: 14px; color: var(--slate-500); }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field label { font-size: 12px; font-weight: 600; color: var(--ink-900); letter-spacing: 0.02em; }
.field input, .field select, .field textarea {
  font-family: var(--font-sans); font-size: 14px; padding: 10px 12px;
  border: 1px solid var(--border); background: var(--surface);
  border-radius: var(--radius); color: var(--ink-900);
  transition: border-color 150ms; width: 100%;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--ink-900); box-shadow: 0 0 0 3px rgba(16,25,42,.08); }
.field input::placeholder, .field textarea::placeholder { color: var(--slate-400); }
.field textarea { min-height: 120px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.alert { padding: 14px 16px; border-radius: var(--radius); font-size: 14px; margin-bottom: 20px; display: flex; gap: 10px; align-items: flex-start; }
.alert i { width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px; }
.alert-success { background: var(--sage-100); color: var(--success); border: 1px solid var(--sage-300); }
.alert-error   { background: var(--clay-100); color: var(--danger);  border: 1px solid var(--clay-300); }

/* ── Footer ─────────────────────────────────────────────────── */
.footer { background: var(--ink-900); color: var(--cream-50); padding: 64px 0 32px; }
.footer a { color: var(--cream-50); text-decoration: none; }
.footer a:hover { color: var(--clay-300); }
.footer .cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
.footer h6 { font-family: var(--font-sans); font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--clay-300); margin-bottom: 14px; }
.footer ul { display: flex; flex-direction: column; gap: 10px; }
.footer ul li a { font-size: 14px; color: var(--slate-300); }
.footer ul li a:hover { color: var(--cream-50); }
.footer-desc { color: var(--slate-300); font-size: 14px; line-height: 1.6; margin-top: 18px; max-width: 320px; }
.footer-bottom { border-top: 1px solid var(--ink-700); margin-top: 48px; padding-top: 24px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--slate-400); flex-wrap: wrap; gap: 12px; }
.footer-bottom a { color: var(--slate-400); }
.footer-bottom a:hover { color: var(--cream-50); }
.footer-links { display: flex; gap: 18px; }

/* ── Admin ──────────────────────────────────────────────────── */
.admin-wrap  { max-width: 1100px; margin: 40px auto; padding: 0 32px; }
.admin-title { font-size: var(--text-2xl); font-family: var(--font-display); color: var(--ink-900); margin-bottom: 24px; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.admin-table th, .admin-table td { text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--rule); }
.admin-table th { background: var(--cream-200); font-weight: 600; color: var(--ink-900); font-size: 12px; letter-spacing: 0.04em; }
.badge { display: inline-block; padding: 3px 8px; border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; }
.badge-new  { background: var(--sage-100);  color: var(--success); }
.badge-read { background: var(--cream-200); color: var(--slate-500); }

/* ── Estimate page ──────────────────────────────────────────── */
.estimate-layout {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: var(--s-16);
  align-items: start;
}
.estimate-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}
.input-icon { position: relative; }
.input-icon i, .input-icon svg {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--fg-subtle);
  width: 15px;
  height: 15px;
}
#upload-zone { position: relative; }
#upload-zone:hover { border-color: var(--clay-400); }
@media (max-width: 900px) {
  .estimate-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .estimate-grid { grid-template-columns: 1fr; }
}

/* ── Lucide icon baseline ───────────────────────────────────── */
[data-lucide] { stroke-width: 1.75; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .hero-grid        { grid-template-columns: 1fr; }
  .hero-visual      { display: none; }
  .service-grid     { grid-template-columns: 1fr 1fr; }
  .project-grid     { grid-template-columns: 1fr 1fr; }
  .process          { grid-template-columns: 1fr 1fr; gap: 32px; }
  .cta-band         { grid-template-columns: 1fr; gap: 32px; }
  .testimonial-grid { grid-template-columns: 1fr; gap: 40px; }
  .footer .cols     { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 768px) {
  .container        { padding: 0 20px; }
  .navbar nav       { display: none; }
  .topbar .left     { flex-wrap: wrap; gap: 10px; font-size: 12px; }
  .about-story      { grid-template-columns: 1fr; }
  .contact-layout   { grid-template-columns: 1fr; }
  .project-body     { grid-template-columns: 1fr; }
  .photo-grid       { grid-template-columns: 1fr; }
  .photo-placeholder:first-child { grid-column: span 1; }
  .project-panel    { position: static; }
  .form-row         { grid-template-columns: 1fr; }
  .service-grid     { grid-template-columns: 1fr; }
  .project-grid     { grid-template-columns: 1fr; }
  .trust-strip      { grid-template-columns: 1fr 1fr; gap: 24px; }
  .footer .cols     { grid-template-columns: 1fr; gap: 28px; }
  .cta-band         { padding: 40px 28px; }
  .hero             { padding: 48px 0 64px; }
  .mini-reviews     { grid-template-columns: 1fr; }
}
