/* =============================================================
   MASSEYALB CONSTRUCTIONS — Design System
   Built on Trust. Designed for Life.
   Tokens → Base → Layout → Components → Pages → Responsive
   ============================================================= */

/* ---------- 1. TOKENS ---------- */
:root {
  /* Brand colors (§1.5) */
  --orange:      #E85C00;
  --orange-700:  #C44E00;   /* hover/active for orange */
  --orange-100:  #FCE8DA;   /* tint */
  --pink:        #ED2261;
  --pink-700:    #C8194F;
  --ink:         #1A1A1A;
  --ink-80:      #3a3a3a;
  --ink-60:      #5f5d5a;
  --neutral:     #F4F2EF;
  --neutral-200: #E7E3DD;   /* borders on neutral */
  --white:       #FFFFFF;

  /* Semantic */
  --bg:            var(--white);
  --bg-alt:        var(--neutral);
  --text:          var(--ink);
  --text-muted:    var(--ink-60);
  --border:        #E4E0DA;
  --focus:         var(--orange);

  /* Typography */
  --font-head: "Montserrat", "Segoe UI", Arial, sans-serif;
  --font-body: "Inter", "Segoe UI", system-ui, Arial, sans-serif;
  /* Modular scale, ratio 1.25, base 1rem = 18px */
  --fs-xs:   0.75rem;   /* 13.5 */
  --fs-sm:   0.875rem;  /* 15.75 */
  --fs-base: 1rem;      /* 18 */
  --fs-md:   1.25rem;   /* 22.5 */
  --fs-lg:   1.5625rem; /* 28 */
  --fs-xl:   1.953rem;  /* 35 */
  --fs-2xl:  2.441rem;  /* 44 */
  --fs-3xl:  3.052rem;  /* 55 */
  --fs-4xl:  3.815rem;  /* 68.7 */

  /* Spacing — 8px base */
  --s-1: 0.5rem;  --s-2: 1rem;   --s-3: 1.5rem;  --s-4: 2rem;
  --s-5: 2.5rem;  --s-6: 3rem;   --s-8: 4rem;    --s-10: 5rem;
  --s-12: 6rem;   --s-16: 8rem;

  /* Radius / shadow / motion */
  --radius:    14px;
  --radius-sm: 10px;
  --radius-lg: 22px;
  --shadow-sm: 0 2px 8px rgba(26,26,26,.06);
  --shadow:    0 12px 32px rgba(26,26,26,.10);
  --shadow-lg: 0 24px 60px rgba(26,26,26,.16);
  --ease: cubic-bezier(.2,.7,.3,1);
  --container: 1200px;
  --header-h: 84px;
}

/* ---------- 2. BASE / RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: var(--orange); text-decoration: none; }
a:hover { color: var(--orange-700); }
ul, ol { padding: 0; list-style: none; }

h1, h2, h3, h4 {
  font-family: var(--font-head);
  line-height: 1.1;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
}
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-lg); }
h4 { font-size: var(--fs-md); }
p { max-width: 68ch; }            /* readable measure (§4.2) */

:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
  border-radius: 4px;
}
::selection { background: var(--orange); color: #fff; }

/* ---------- 3. LAYOUT ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--s-3); }
.section { padding-block: var(--s-12); }
.section--tight { padding-block: var(--s-8); }
.section--neutral { background: var(--neutral); }
.section--ink { background: var(--ink); color: #fff; }
.section--ink h1, .section--ink h2, .section--ink h3 { color: #fff; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-head);
  font-size: var(--fs-sm); font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--orange); margin-bottom: var(--s-2);
}
.eyebrow::before { content:""; width: 28px; height: 2px; background: var(--orange); display:inline-block; }
.section--ink .eyebrow { color: #F4A86A; }
.section--ink .eyebrow::before { background:#F4A86A; }

.section-head { max-width: 760px; margin-bottom: var(--s-8); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head.center .eyebrow { justify-content: center; }
.lead { font-size: var(--fs-md); color: var(--text-muted); }
.section--ink .lead { color: #cfcbc6; }

.grid { display: grid; gap: var(--s-4); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }

/* ---------- 4. BUTTONS ---------- */
.btn {
  --btn-bg: var(--orange); --btn-fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: .6rem;
  font-family: var(--font-head); font-weight: 700; font-size: var(--fs-sm);
  letter-spacing: .04em; text-transform: uppercase;
  padding: .95rem 1.6rem; min-height: 48px;
  background: var(--btn-bg); color: var(--btn-fg);
  border: 2px solid transparent; border-radius: var(--radius-sm);
  cursor: pointer; transition: transform .15s var(--ease), background .2s, box-shadow .2s, color .2s;
  box-shadow: 0 6px 18px rgba(232,92,0,.28);
}
.btn:hover { background: var(--orange-700); color:#fff; transform: translateY(-2px); box-shadow: 0 10px 26px rgba(232,92,0,.34); }
.btn:active { transform: translateY(0); }
.btn .ico { width: 18px; height: 18px; }

.btn--outline {
  background: transparent; color: var(--ink);
  border-color: var(--ink); box-shadow: none;
}
.btn--outline:hover { background: var(--ink); color:#fff; box-shadow: var(--shadow-sm); }

.btn--ghost-light {
  background: rgba(255,255,255,.10); color:#fff;
  border-color: rgba(255,255,255,.55); box-shadow:none; backdrop-filter: blur(4px);
}
.btn--ghost-light:hover { background:#fff; color: var(--ink); border-color:#fff; }

.btn--lg { padding: 1.1rem 2rem; font-size: var(--fs-base); }
.btn--block { width: 100%; }

.btn-row { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.btn-row.center { justify-content: center; }

/* ---------- 5. HEADER / NAV ---------- */
.topbar {
  background: var(--ink); color: #cfcbc6;
  font-size: var(--fs-sm);
}
.topbar .container { display:flex; align-items:center; justify-content:space-between; min-height: 40px; gap: var(--s-3); }
.topbar a { color: #e9e6e2; }
.topbar a:hover { color:#fff; }
.topbar .socials { display:flex; gap: .35rem; }
.topbar .socials a {
  width: 28px; height: 28px; display:grid; place-items:center; border-radius: 6px;
  background: rgba(255,255,255,.08);
}
.topbar .socials a:hover { background: var(--orange); }
.topbar .topbar-meta { display:flex; gap: var(--s-3); align-items:center; }
.topbar .topbar-meta .ico { width:15px; height:15px; vertical-align:-2px; margin-right:.35rem; color: var(--orange); }

.site-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .25s, background .25s;
}
.site-header.scrolled { box-shadow: var(--shadow-sm); }
.nav { display:flex; align-items:center; justify-content: space-between; min-height: var(--header-h); gap: var(--s-3); }

.logo { display:flex; align-items:center; gap: .7rem; }
.logo svg { width: 46px; height: 46px; flex:none; }
.logo .logo-text { font-family: var(--font-head); line-height: 1; }
.logo .logo-name { display:block; font-weight: 800; font-size: 1.35rem; letter-spacing: .04em; color: var(--ink); }
.logo .logo-sub  { display:block; font-weight: 600; font-size: .66rem; letter-spacing: .34em; color: var(--orange); margin-top: 3px; }

.nav-links { display:flex; align-items:center; gap: var(--s-1); }
.nav-links a {
  font-family: var(--font-head); font-weight: 600; font-size: var(--fs-sm);
  letter-spacing: .06em; text-transform: uppercase; color: var(--ink);
  padding: .6rem .8rem; border-radius: 8px; position: relative;
}
.nav-links a::after {
  content:""; position:absolute; left:.8rem; right:.8rem; bottom:.35rem; height:2px;
  background: var(--orange); transform: scaleX(0); transform-origin:left; transition: transform .25s var(--ease);
}
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--orange); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { transform: scaleX(1); }

.nav-cta { display:flex; align-items:center; gap: var(--s-2); }
.nav-toggle {
  display:none; width: 46px; height: 46px; border:1px solid var(--border);
  background:#fff; border-radius: 10px; cursor:pointer; align-items:center; justify-content:center;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content:""; display:block; width: 22px; height: 2px; background: var(--ink); transition: .25s var(--ease);
}
.nav-toggle span::before { transform: translateY(-7px); }
.nav-toggle span::after  { transform: translateY(5px); }
.nav-toggle[aria-expanded="true"] span { background: transparent; }
.nav-toggle[aria-expanded="true"] span::before { transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after  { transform: rotate(-45deg); }

/* ---------- 6. HERO ---------- */
.hero {
  position: relative; color:#fff;
  min-height: clamp(520px, 78vh, 760px);
  display:flex; align-items:center;
  background: var(--ink);
}
.hero__bg { position:absolute; inset:0; object-fit: cover; width:100%; height:100%; }
.hero__overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(15,13,12,.86) 0%, rgba(15,13,12,.55) 48%, rgba(15,13,12,.30) 100%),
    linear-gradient(0deg, rgba(15,13,12,.65), rgba(15,13,12,0) 55%);
}
.hero .container { position: relative; z-index:2; padding-block: var(--s-10); }
.hero__inner { max-width: 720px; }
.hero h1 { font-size: clamp(2.4rem, 5.2vw, var(--fs-4xl)); text-transform: uppercase; color:#fff; }
.hero h1 .accent { color: #F4A86A; }
.hero .lead { color: #e6e2dd; margin-top: var(--s-3); font-size: var(--fs-md); }
.hero .btn-row { margin-top: var(--s-5); }

/* compact hero for inner pages */
.hero--inner { min-height: clamp(340px, 46vh, 460px); }
.hero--inner h1 { font-size: clamp(2rem, 4.4vw, var(--fs-3xl)); }
.breadcrumb { font-size: var(--fs-sm); color:#d9d4cf; margin-top: var(--s-2); }
.breadcrumb a { color:#F4A86A; }

/* ---------- 7. CTA BAND ---------- */
.cta-band { background: var(--orange); color:#fff; }
.cta-band .container {
  display:flex; align-items:center; justify-content:space-between; gap: var(--s-4);
  padding-block: var(--s-6); flex-wrap: wrap;
}
.cta-band h2 { color:#fff; font-size: var(--fs-xl); max-width: 22ch; }
.cta-band .btn { background:#fff; color: var(--orange); box-shadow:none; }
.cta-band .btn:hover { background: var(--ink); color:#fff; }
.cta-band--pink { background: var(--pink); }
.cta-band--pink .btn { color: var(--pink); }

/* ---------- 8. CARDS / SERVICES ---------- */
.card {
  background:#fff; border:1px solid var(--border); border-radius: var(--radius);
  overflow:hidden; box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease), box-shadow .25s;
  display:flex; flex-direction:column;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.card__media { aspect-ratio: 4/3; overflow:hidden; background: var(--neutral); }
.card__media img { width:100%; height:100%; object-fit: cover; transition: transform .5s var(--ease); }
.card:hover .card__media img { transform: scale(1.05); }
.card__body { padding: var(--s-4); display:flex; flex-direction:column; gap: var(--s-2); flex:1; }
.card__body h3 { font-size: var(--fs-lg); }
.card__body p { color: var(--text-muted); font-size: var(--fs-base); flex:1; }
.card__link {
  font-family: var(--font-head); font-weight:700; font-size: var(--fs-sm);
  text-transform: uppercase; letter-spacing:.05em; color: var(--orange);
  display:inline-flex; align-items:center; gap:.4rem; margin-top:auto;
}
.card__link .ico { width:16px; height:16px; transition: transform .2s; }
.card__link:hover .ico { transform: translateX(4px); }
.card__tag {
  position:absolute; top: var(--s-2); left: var(--s-2);
  background: rgba(26,26,26,.82); color:#fff; font-family: var(--font-head);
  font-size: var(--fs-xs); font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding: .35rem .7rem; border-radius: 6px;
}
.card.has-tag .card__media { position:relative; }

/* service card with number */
.service-card .card__body { padding-block: var(--s-5); }
.service-num {
  font-family: var(--font-head); font-weight:800; font-size: var(--fs-md);
  color: var(--orange); letter-spacing:.05em;
}

/* ---------- 9. PROCESS STEPS ---------- */
.steps { display:grid; gap: var(--s-4); grid-template-columns: repeat(5, 1fr); }
.step {
  background:#fff; border:1px solid var(--border); border-radius: var(--radius);
  padding: var(--s-4); position:relative; box-shadow: var(--shadow-sm);
}
.step__num {
  width: 52px; height: 52px; border-radius: 12px; display:grid; place-items:center;
  background: var(--orange-100); color: var(--orange);
  font-family: var(--font-head); font-weight:800; font-size: var(--fs-lg); margin-bottom: var(--s-2);
}
.step h3 { font-size: var(--fs-md); margin-bottom: .4rem; }
.step p { font-size: var(--fs-sm); color: var(--text-muted); }

/* long-form process row */
.process-row { display:grid; grid-template-columns: 1fr 1fr; gap: var(--s-6); align-items:center; margin-bottom: var(--s-8); }
.process-row:nth-child(even) .process-row__media { order: -1; }
.process-row__media img { border-radius: var(--radius); box-shadow: var(--shadow); width:100%; }
.process-row .step__num { margin-bottom: var(--s-3); }

/* ---------- 10. WHY CHOOSE / CREDIBILITY ---------- */
.why-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--s-4); }
.why-item { display:flex; gap: var(--s-2); align-items:flex-start; }
.why-item .ico-badge {
  flex:none; width: 48px; height:48px; border-radius: 12px; display:grid; place-items:center;
  background: var(--orange); color:#fff;
}
.why-item .ico-badge .ico { width: 24px; height:24px; }
.why-item h3 { font-size: var(--fs-md); margin-bottom:.25rem; }
.why-item p { font-size: var(--fs-sm); color: var(--text-muted); }
.section--ink .why-item p { color:#c9c5c0; }
.section--ink .why-item h3 { color:#fff; }

.cred-band { background: var(--neutral); }
.cred-grid { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--s-4); text-align:center; }
.cred-item .ico-badge { margin-inline:auto; margin-bottom: var(--s-2); width:56px; height:56px; border-radius:14px;
  background:#fff; border:1px solid var(--border); color: var(--orange); display:grid; place-items:center; }
.cred-item .ico-badge .ico { width:28px; height:28px; }
.cred-item h3 { font-size: var(--fs-md); }
.cred-item p { font-size: var(--fs-sm); color: var(--text-muted); margin-inline:auto; }

/* ---------- 11. TESTIMONIAL ---------- */
.testimonial { max-width: 820px; margin-inline:auto; text-align:center; }
.testimonial blockquote { font-family: var(--font-head); font-weight:600; font-size: var(--fs-xl); line-height:1.3; color: var(--ink); }
.section--ink .testimonial blockquote { color:#fff; }
.testimonial .quote-mark { font-size: 4rem; color: var(--orange); line-height: .6; font-family: var(--font-head); }
.testimonial cite { display:block; margin-top: var(--s-3); font-style: normal; color: var(--text-muted); font-weight:600; }

/* ---------- 12. WORK / PORTFOLIO ---------- */
.filters { display:flex; flex-wrap:wrap; gap: var(--s-1); justify-content:center; margin-bottom: var(--s-6); }
.filter-btn {
  font-family: var(--font-head); font-weight:600; font-size: var(--fs-sm); letter-spacing:.04em;
  text-transform: uppercase; padding:.6rem 1.1rem; border-radius: 999px;
  background:#fff; border:1px solid var(--border); color: var(--ink); cursor:pointer; transition:.2s;
}
.filter-btn:hover { border-color: var(--orange); color: var(--orange); }
.filter-btn[aria-pressed="true"] { background: var(--ink); color:#fff; border-color: var(--ink); }
.work-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--s-4); }
.work-card { position:relative; border-radius: var(--radius); overflow:hidden; display:block; box-shadow: var(--shadow-sm); }
.work-card img { aspect-ratio: 4/3; object-fit:cover; width:100%; transition: transform .5s var(--ease); }
.work-card:hover img { transform: scale(1.06); }
.work-card__overlay {
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding: var(--s-3); color:#fff;
  background: linear-gradient(0deg, rgba(15,13,12,.86) 0%, rgba(15,13,12,.12) 60%, transparent 100%);
  opacity:.96;
}
.work-card__overlay .tag { font-size: var(--fs-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#F4A86A; font-family:var(--font-head); }
.work-card__overlay h3 { color:#fff; font-size: var(--fs-md); margin-top:.2rem; }
.is-hidden { display:none !important; }

/* project detail gallery */
.gallery { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--s-3); }
.gallery img { border-radius: var(--radius-sm); aspect-ratio: 4/3; object-fit:cover; box-shadow: var(--shadow-sm); }
.project-meta { display:flex; flex-wrap:wrap; gap: var(--s-4); padding: var(--s-4); background: var(--neutral); border-radius: var(--radius); }
.project-meta dt { font-family:var(--font-head); font-size: var(--fs-xs); letter-spacing:.1em; text-transform:uppercase; color: var(--orange); }
.project-meta dd { font-weight:600; }

/* ---------- 13. FORM ---------- */
.form-card { background:#fff; border:1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: clamp(1.5rem, 4vw, var(--s-8)); }
.form-grid { display:grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
.field { display:flex; flex-direction:column; gap:.4rem; }
.field.full { grid-column: 1 / -1; }
.field label { font-family: var(--font-head); font-weight:600; font-size: var(--fs-sm); }
.field .req { color: var(--pink); }
.field input, .field select, .field textarea {
  font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink);
  padding: .85rem 1rem; border:1.5px solid var(--border); border-radius: var(--radius-sm);
  background:#fff; transition: border-color .2s, box-shadow .2s; width:100%;
}
.field textarea { resize: vertical; min-height: 120px; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline:none; border-color: var(--orange); box-shadow: 0 0 0 4px rgba(232,92,0,.12);
}
.form-note { font-size: var(--fs-sm); color: var(--text-muted); }
.form-status { display:none; padding: var(--s-3); border-radius: var(--radius-sm); margin-bottom: var(--s-3); font-weight:600; }
.form-status.show { display:block; }
.form-status.ok { background:#e9f7ec; color:#1c7a36; border:1px solid #bfe6c7; }
.form-status.err { background:#fdecef; color: var(--pink-700); border:1px solid #f6c4d2; }

/* contact info list */
.contact-list { display:flex; flex-direction:column; gap: var(--s-3); }
.contact-list li { display:flex; gap: var(--s-2); align-items:flex-start; }
.contact-list .ico-badge { flex:none; width:44px; height:44px; border-radius:11px; background: var(--orange-100); color: var(--orange); display:grid; place-items:center; }
.contact-list .ico-badge .ico { width:20px; height:20px; }
.contact-list b { font-family:var(--font-head); display:block; font-size: var(--fs-sm); text-transform:uppercase; letter-spacing:.06em; color: var(--text-muted); }
.contact-list a, .contact-list span { font-weight:600; color: var(--ink); }
.map-embed { border:0; width:100%; height:340px; border-radius: var(--radius); box-shadow: var(--shadow-sm); filter: grayscale(.2); }

/* ---------- 14. FOOTER ---------- */
.site-footer { background: var(--ink); color:#bdb8b2; padding-top: var(--s-10); font-size: var(--fs-sm); }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--s-6); }
.site-footer h4 { color:#fff; font-size: var(--fs-base); text-transform:uppercase; letter-spacing:.08em; margin-bottom: var(--s-3); }
.site-footer a { color:#bdb8b2; }
.site-footer a:hover { color:#fff; }
.footer-logo svg { width: 52px; height:52px; }
.footer-brand { display:flex; align-items:center; gap:.6rem; margin-bottom: var(--s-2); }
.footer-brand .logo-name { color:#fff; font-family:var(--font-head); font-weight:800; font-size:1.2rem; letter-spacing:.04em; }
.footer-tag { color:#F4A86A; font-family: var(--font-head); font-weight:600; }
.footer-about { max-width: 34ch; margin-block: var(--s-2); }
.footer-links li { margin-bottom: .6rem; }
.footer-contact li { display:flex; gap:.6rem; margin-bottom:.7rem; align-items:flex-start; }
.footer-contact .ico { width:17px; height:17px; color: var(--orange); flex:none; margin-top:3px; }
.footer-socials { display:flex; gap:.5rem; margin-top: var(--s-3); }
.footer-socials a { width:40px; height:40px; border-radius:10px; background: rgba(255,255,255,.08); display:grid; place-items:center; }
.footer-socials a:hover { background: var(--orange); color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top: var(--s-8); padding-block: var(--s-4); }
.footer-bottom .container { display:flex; justify-content:space-between; flex-wrap:wrap; gap: var(--s-2); }
.ico { width:20px; height:20px; stroke: currentColor; }

/* ---------- 15. MISC ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: var(--s-8); align-items:center; }
.media-frame img { border-radius: var(--radius); box-shadow: var(--shadow); width:100%; }
.badge-row { display:flex; flex-wrap:wrap; gap: var(--s-2); margin-top: var(--s-3); }
.pill { display:inline-flex; align-items:center; gap:.4rem; background: var(--orange-100); color: var(--orange-700);
  font-family:var(--font-head); font-weight:700; font-size: var(--fs-xs); letter-spacing:.05em; text-transform:uppercase;
  padding:.4rem .8rem; border-radius: 999px; }
.skip-link { position:absolute; left:-9999px; top:0; background: var(--ink); color:#fff; padding:.6rem 1rem; z-index:200; }
.skip-link:focus { left: var(--s-2); top: var(--s-2); border-radius:8px; color:#fff; }

/* reveal on scroll */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior:auto !important; }
  .reveal { opacity:1 !important; transform:none !important; transition:none; }
}

/* ---------- 16. RESPONSIVE ---------- */
@media (max-width: 1024px) {
  .grid-3, .why-grid, .work-grid, .gallery { grid-template-columns: repeat(2,1fr); }
  .steps { grid-template-columns: repeat(2,1fr); }
  .cred-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .process-row { grid-template-columns: 1fr; gap: var(--s-3); }
  .process-row:nth-child(even) .process-row__media { order: 0; }
}
@media (max-width: 760px) {
  :root { --header-h: 70px; }
  .topbar .topbar-meta { display:none; }
  .nav-toggle { display:flex; }
  .nav-links {
    position: fixed; inset: var(--header-h) 0 auto 0;
    flex-direction: column; align-items: stretch; gap:0;
    background:#fff; border-bottom:1px solid var(--border); box-shadow: var(--shadow);
    padding: var(--s-2); transform: translateY(-105%); transition: transform .3s var(--ease);
    max-height: calc(100vh - var(--header-h)); overflow:auto;
    visibility: hidden; pointer-events: none;
  }
  .nav[data-open="true"] .nav-links { transform: translateY(0); visibility: visible; pointer-events: auto; }
  .nav-links a { padding: .9rem; border-radius:8px; }
  .nav-links a::after { display:none; }
  .nav-links a:hover { background: var(--neutral); }
  .nav-cta .btn { display:none; }      /* primary CTA shown in mobile menu */
  .nav-links .btn { display:inline-flex; margin-top: var(--s-1); }

  .grid-3, .grid-2, .why-grid, .work-grid, .gallery, .steps, .cred-grid,
  .form-grid, .split, .footer-grid { grid-template-columns: 1fr; }
  .section { padding-block: var(--s-8); }
  .cta-band .container { flex-direction: column; align-items:flex-start; }
  h1 { font-size: var(--fs-2xl); }
  h2 { font-size: var(--fs-xl); }
  .footer-bottom .container { flex-direction:column; }
}
/* desktop: hide the in-menu CTA (shown only on mobile) */
@media (min-width: 761px){ .nav-links .btn { display:none; } }
