/* ===== from index.html ===== */
.section-title { color:#1C1A19; }
  :root { --ink:#1C1A19; --red:#F4A100; --red-deep:#C77F00; --soft:#F6F6F7; --line:#ececec; }

  /* ---------- HERO: full-width van banner ---------- */
  .mh { position:relative; background:#fff; overflow:hidden; }
  .mh-photo {
    width:100%;
    aspect-ratio:1536/560;
    background:#fff url('megapolis-van-star.jpg') center 8%/cover no-repeat;
  }
  .mh-chip { position:absolute; left:40px; bottom:34px; z-index:3; background:#fff; color:var(--ink); border-radius:18px; padding:18px 22px; box-shadow:0 24px 60px rgba(0,0,0,.28); display:flex; align-items:center; gap:14px; }
  .mh-chip .g { width:42px; height:42px; flex-shrink:0; }
  .mh-chip .rt { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; line-height:1; }
  .mh-chip .st { color:#FFB400; font-size:14px; letter-spacing:1px; }
  .mh-chip .lb { font-family:'Hanken Grotesk',sans-serif; font-size:12px; color:#666; margin-top:2px; }
  .mbtn { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; padding:18px 30px; border-radius:999px; cursor:pointer; transition:transform .2s, box-shadow .2s, background .2s; }
  .mbtn-red { background:var(--red); color:#1C1A19; box-shadow:0 12px 30px rgba(244,161,0,.35); }
  .mbtn-red:hover { transform:translateY(-2px); background:var(--red-deep); }

  /* ---------- LIVE PROJECT + STEPS + CONTACT ---------- */
  .lp { background:#fff; padding:30px 64px 90px; }
  .lp-head { text-align:center; max-width:720px; margin:0 auto 28px; }
  .lp-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .lp-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:14px; }
  .lp-count { max-width:520px; margin:0 auto 30px; background:var(--soft); border-radius:16px; padding:18px 24px; display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap; }
  .lp-count-label { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
  .lp-count-row { display:flex; align-items:center; gap:14px; }
  .lp-unit { text-align:center; min-width:42px; }
  .lp-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:28px; line-height:1; color:var(--ink); }
  .lp-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#999; margin-top:5px; }
  .lp-sep { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--red); }

  .lp-photos { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:1180px; margin:0 auto; }
  .lp-photo { position:relative; aspect-ratio:4/3; border-radius:16px; overflow:hidden; background:#111; }
  .lp-photo img { width:100%; height:100%; object-fit:cover; display:block; }
  .lp-photo::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.04) 50%, rgba(0,0,0,.55)); }
  .lp-live { position:absolute; top:12px; left:12px; z-index:2; display:inline-flex; align-items:center; gap:7px; background:#fff; color:var(--ink); font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:11px; letter-spacing:.1em; padding:5px 11px; border-radius:999px; }
  .lp-dot { width:7px; height:7px; border-radius:50%; background:var(--red); animation:lpPulse 1.4s ease-in-out infinite; }
  @keyframes lpPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(1.25)} }
  .lp-play { position:absolute; inset:0; margin:auto; width:60px; height:60px; z-index:2; background:none; border:none; cursor:pointer; }
  .lp-play svg { width:60px; height:60px; filter:drop-shadow(0 4px 14px rgba(0,0,0,.4)); transition:transform .2s; }
  .lp-play:hover svg { transform:scale(1.08); }
  .lp-cap { position:absolute; left:14px; bottom:12px; z-index:2; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:500; font-size:13px; }

  /* steps */
  .lp-steps-head { text-align:center; margin:60px auto 30px; }
  .lp-steps-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:1080px; margin:0 auto; }
  .lp-step { background:var(--soft); border-radius:18px; padding:36px 30px 30px; position:relative; }
  .lp-step-num { position:absolute; top:-16px; left:30px; width:44px; height:44px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:19px; box-shadow:0 8px 20px rgba(244,161,0,.35); }
  .lp-step h4 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; color:var(--ink); margin:10px 0 10px; }
  .lp-step p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }
  .lp-step:not(:last-child)::after { content:"›"; position:absolute; top:50%; right:-24px; transform:translateY(-50%); width:28px; height:0; border-top:2px dashed var(--red); z-index:2; color:var(--red); font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:26px; line-height:0; text-align:right; }

  /* estimate CTA: text + form (stands out on orange) */
  .lp-cta { display:grid; grid-template-columns:1fr 460px; gap:48px; align-items:center; max-width:1080px; margin:60px auto 0; background:var(--red); border-radius:24px; padding:48px 52px; }
  .lp-cta-text .ms-eye { color:#1C1A19; }
  .lp-cta-text h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3vw,40px); line-height:1.1; letter-spacing:-0.01em; color:#1C1A19; margin:10px 0 0; }
  .lp-cta-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; max-width:440px; }
  .lp-cta-call { display:inline-flex; align-items:center; gap:8px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--ink); }
  .lp-cta-call:hover { color:var(--red-deep); }

  /* compact contact form (NorthCan-style, narrow) */
  .lp-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 28px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:11px; }
  .lp-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 6px; text-align:center; }
  .lp-form .form-input, .lp-form .form-textarea { width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:9px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .lp-form .form-textarea { min-height:78px; resize:vertical; }
  .lp-form .form-input:focus, .lp-form .form-textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .lp-cta .lp-submit { background:var(--ink); color:#fff; }
  .lp-cta .lp-submit:hover { background:#000; }
  .lp-submit { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .lp-submit:hover { background:var(--red-deep); transform:translateY(-2px); }

  /* our services: bordered grid (Option C) */
  .lp-svc-head { text-align:center; margin:0 auto 28px; }
  .lp-svc-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; max-width:900px; margin:0 auto; border:1px solid var(--line); border-radius:18px; overflow:hidden; }
  .lp-svc { display:flex; flex-direction:column; align-items:center; text-align:center; gap:13px; padding:34px 16px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; color:var(--ink); transition:background .2s; }
  .lp-svc:nth-child(3n) { border-right:0; }
  .lp-svc:nth-last-child(-n+3) { border-bottom:0; }
  .lp-svc:hover { background:var(--soft); }
  .lp-svc .c-ic { width:52px; height:52px; border-radius:13px; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .lp-svc .c-ic svg { width:28px; height:28px; }
  .lp-svc h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; line-height:1.25; }
  .lp-svc span { display:none; }

  /* cost calculator (bottom) */
  .mcalc-card { max-width:560px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 18px 50px rgba(0,0,0,.07); overflow:hidden; }
  .mcalc-top { background:var(--ink); color:#fff; padding:24px 30px; }
  .mcalc-top h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; }
  .mcalc-top p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:rgba(255,255,255,.7); margin-top:4px; }
  .mcalc-body { padding:26px 30px 30px; display:flex; flex-direction:column; gap:13px; }
  .mcalc-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .mcalc-body label { font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; font-weight:600; color:#888; display:flex; flex-direction:column; gap:5px; }
  .mcalc-body input, .mcalc-body select { padding:13px 14px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcalc-body input:focus, .mcalc-body select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcalc-btn { margin-top:6px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:16px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcalc-btn:hover { background:var(--red-deep); transform:translateY(-2px); }
  .mcalc-result { display:none; margin-top:4px; border:1px dashed var(--red); background:rgba(244,161,0,.07); border-radius:14px; padding:22px; text-align:center; }
  .mcalc-result.show { display:block; animation:calcfade .4s ease; }
  @keyframes calcfade { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }
  .mcalc-result .est-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#888; }
  .mcalc-result .est-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:34px; color:var(--ink); margin:6px 0; }
  .mcalc-result .est-note { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#555; }
  .mcalc-result .est-note b { color:var(--ink); }

  @media (max-width:1024px){
    .lp-svc-grid { grid-template-columns:repeat(3,1fr); }
    .lp-svc:nth-child(3n) { border-right:0; }
    .lp-svc:nth-child(-n+3) { border-bottom:1px solid var(--line); }
    .lp-svc:last-child { border-right:0; }
  }
  @media (max-width:760px){
    .lp { padding:24px 20px 48px; }
    .lp-photos { grid-template-columns:1fr; max-width:420px; }
    .lp-photos .lp-photo:nth-child(n+2) { display:none; }
    .lp-steps { grid-template-columns:1fr; max-width:420px; gap:28px; }
    .lp-step:not(:last-child)::after { display:none; }
    .lp-count { flex-direction:column; gap:12px; }
    .lp-cta { grid-template-columns:1fr; gap:22px; max-width:none; border-radius:18px; padding:26px 10px; }
    .lp-cta-text { text-align:center; }
    .lp-cta-text p { margin-left:auto; margin-right:auto; }
    .lp-form { padding:26px 18px; }
    .lp-svc-grid { grid-template-columns:repeat(2,1fr); max-width:420px; }
    .lp-svc:nth-child(2n) { border-right:0; }
    .lp-svc:nth-child(3n) { border-right:1px solid var(--line); }
    .lp-svc:nth-child(-n+4) { border-bottom:1px solid var(--line); }
    .mc2 { display:none; }
  }

  /* ---------- MARQUEE (kept) ---------- */
  .mq { background:var(--red); color:#1C1A19; overflow:hidden; padding:16px 0; white-space:nowrap; }
  .mq-track { display:inline-flex; gap:48px; animation:mqscroll 26s linear infinite; }
  .mq-track span { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; display:inline-flex; align-items:center; gap:48px; }
  .mq-track span::after { content:"◆"; font-size:10px; opacity:.7; }
  @keyframes mqscroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* shared eyebrow + section heads */
  .ms-eye { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); }

  /* ---------- STATS (kept, light) ---------- */
  .mstat { background:#fff; padding:0 64px; }
  .mstat-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); border-radius:24px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.10); transform:translateY(-50%); }
  .mstat-cell { background:#fff; padding:40px 28px; text-align:center; border-right:1px solid var(--line); }
  .mstat-cell:last-child { border-right:0; }
  .mstat-cell .n { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(32px,3.4vw,46px); color:var(--ink); line-height:1; }
  .mstat-cell .n em { font-style:normal; color:var(--red); }
  .mstat-cell .l { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#777; margin-top:9px; }

  /* ---------- SERVICES (light, red hover) ---------- */
  .ms { padding:30px 64px 100px; background:#fff; }
  .ms-head { max-width:720px; margin:0 auto 56px; text-align:center; }
  .ms-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .ms-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:16px; }
  .ms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1280px; margin:0 auto; }
  .ms-card { border:1px solid var(--line); border-radius:22px; padding:40px 34px; background:#fff; transition:transform .26s, box-shadow .26s, border-color .26s; }
  .ms-card .ic { width:60px; height:60px; border-radius:16px; background:rgba(244,161,0,.16); color:#1C1A19; display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:background .26s, color .26s; }
  .ms-card .ic svg { width:32px; height:32px; }
  .ms-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:23px; color:var(--ink); margin:0 0 10px; }
  .ms-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0 0 18px; }
  .ms-card .lk { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:14px; color:var(--red); display:inline-flex; align-items:center; gap:7px; }
  .ms-card:hover { transform:translateY(-8px); box-shadow:0 26px 54px rgba(244,161,0,.14); border-color:var(--red); }
  .ms-card:hover .ic { background:var(--red); color:#1C1A19; }

  /* ---------- VAN SPLIT (light) ---------- */
  .mv { display:grid; grid-template-columns:1fr 1fr; background:var(--soft); color:var(--ink); }
  .mv-photo { background:#fff url('megapolis-van.jpg') center/cover no-repeat; min-height:520px; }
  .mv-copy { padding:84px 64px; display:flex; flex-direction:column; justify-content:center; }
  .mv-copy h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; margin:16px 0 20px; color:var(--ink); }
  .mv-copy > p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0 0 30px; max-width:560px; }
  .mv-list { display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; margin-bottom:34px; }
  .mv-list span { display:flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:var(--ink); }
  .mv-list svg { width:20px; height:20px; color:var(--red); flex-shrink:0; }

  /* ---------- PROCESS (restored, light) ---------- */
  .mp { background:#fff; padding:100px 64px; text-align:center; }
  .mp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); letter-spacing:-0.02em; color:var(--ink); }
  .mp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; max-width:680px; margin:14px auto 56px; line-height:1.7; }
  .mp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1180px; margin:0 auto; position:relative; }
  .mp-card { background:var(--soft); border-radius:22px; padding:44px 34px; text-align:left; position:relative; }
  .mp-num { position:absolute; top:-16px; left:34px; width:46px; height:46px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:20px; box-shadow:0 8px 20px rgba(244,161,0,.3); }
  .mp-card .ic { width:58px; height:58px; margin:14px 0 18px; color:#1C1A19; }
  .mp-card .ic svg { width:58px; height:58px; }
  .mp-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:21px; color:var(--ink); margin:0 0 10px; }
  .mp-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }

  /* ---------- COMMITMENT (restored, white) ---------- */
  .mc2 { background:#fff; padding:24px 20px 64px; text-align:center; }
  .mc2-inner { max-width:1080px; margin:0 auto; }
  .mc2 h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3.4vw,42px); letter-spacing:-0.01em; color:var(--ink); line-height:1.14; margin:14px 0 30px; }
  .mc2 p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; line-height:1.8; color:#444; margin:0 auto 20px; max-width:920px; }
  .mc2 .sig { font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:var(--red); margin-top:26px; }

  /* ---------- COMPLETED (restored, light) ---------- */
  .mcp { background:var(--soft); padding:64px 64px 70px; text-align:center; }
  .mcp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; }
  .mcp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin:14px auto 56px; }
  .mcp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:980px; margin:0 auto; }
  .mcp-card { text-align:left; display:block; }
  .mcp-img { position:relative; aspect-ratio:4/3; border-radius:14px; overflow:hidden; background:#ddd center/cover no-repeat; box-shadow:0 10px 26px rgba(0,0,0,.10); transition:transform .25s, box-shadow .25s; }
  .mcp-card:hover .mcp-img { transform:translateY(-4px); box-shadow:0 18px 40px rgba(244,161,0,.22); }
  .mcp-img::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.45)); }
  .mcp-badge { position:absolute; top:10px; left:10px; z-index:2; background:var(--red); color:#1C1A19; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:5px 10px; border-radius:999px; }

  /* ---------- WHY (restored, light) ---------- */
  .mw { background:#fff; padding:100px 64px; }
  .mw-inner { max-width:1280px; margin:0 auto; }
  .mw-top { text-align:center; max-width:760px; margin:0 auto 56px; }
  .mw-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; margin:14px 0 0; }
  .mw-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin-top:16px; line-height:1.7; }
  .mw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .mw-item { border:1px solid var(--line); border-radius:18px; padding:32px 26px; transition:border-color .25s, box-shadow .25s, transform .25s; }
  .mw-item:hover { border-color:var(--red); box-shadow:0 18px 40px rgba(244,161,0,.10); transform:translateY(-4px); }
  .mw-item .ic { width:52px; height:52px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
  .mw-item .ic svg { width:52px; height:52px; }
  .mw-item h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); margin:0 0 8px; }
  .mw-item p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#666; margin:0; }

  /* ---------- CTA BANNER (red) ---------- */
  .mcta { background:var(--red); color:#1C1A19; padding:62px 64px; text-align:center; }
  .mcta h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,52px); line-height:1.05; letter-spacing:-0.01em; margin:0 0 14px; }
  .mcta p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; color:rgba(26,26,26,.78); margin:0 0 30px; }
  .mcta .row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .mcta .mbtn-white { background:#fff; color:var(--ink); }
  .mcta .mbtn-white:hover { transform:translateY(-2px); }
  .mcta .mbtn-dark { background:var(--ink); color:#fff; }

  /* Toronto-based + areas */
  .mabout { background:#fff; padding:64px 40px; }
  .mabout-top { max-width:900px; margin:0 auto 44px; text-align:center; }
  .mabout-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,46px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:12px 0 16px; }
  .mabout-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0; }
  .mabout-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:0.9fr 1.1fr; gap:50px; align-items:center; }
  .mabout-media { display:flex; justify-content:center; }
  .mabout-van { width:100%; max-width:480px; height:auto; }
  .mabout-copy p { font-family:'Hanken Grotesk',sans-serif; font-size:16px; line-height:1.75; color:#555; margin:0 0 18px; }
  .mabout-cities { display:flex; flex-wrap:wrap; gap:9px; }
  .mabout-cities span { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:13.5px; color:var(--ink); background:var(--soft); border:1px solid var(--line); padding:7px 14px; border-radius:999px; transition:background .2s, color .2s; }
  .mabout-cities span:hover { background:var(--red); color:#1C1A19; border-color:var(--red); }
  @media (max-width:860px){
    .mabout { padding:34px 20px 56px; }
    .mabout-top { margin-bottom:28px; }
    .mabout-grid { grid-template-columns:1fr; gap:24px; }
    .mabout-cities { justify-content:center; }
  }
  @media (max-width:600px){
    .lp { padding-top:14px; }
    .mcalc-card { max-width:none; }
    .mcontact-only { max-width:none; }
    .mcontact { padding:0; background:#fff; }
    .mcalc-card { border-left:0; border-right:0; border-radius:0; }
    .mcontact-form { border-left:0; border-right:0; border-radius:0; box-shadow:none; }
    .lp-steps-head { margin-top:28px; }
    .mw-strip { padding:30px 20px; }
    .mw-strip-inner { display:grid; grid-template-columns:1fr; gap:0; }
    .mw-strip-inner span { font-size:15px; padding:14px 4px; border-bottom:1px solid var(--line); width:100%; }
    .mw-strip-inner span:last-child { border-bottom:0; }
    .mw-strip-inner svg { width:22px; height:22px; }
    /* mobile-only contact form below services */
    .mobile-contact { display:flex; max-width:none; }
  }

  /* why bullet strip */
  .mobile-contact { display:none; max-width:460px; margin:34px auto 0; background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px 22px; box-shadow:0 14px 40px rgba(0,0,0,.07); flex-direction:column; gap:11px; }
  .mobile-contact h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:21px; color:var(--ink); margin:0 0 4px; text-align:center; }
  .mobile-contact input, .mobile-contact select { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mobile-contact input:focus, .mobile-contact select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mobile-contact button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:15px; cursor:pointer; }
  .mw-strip { background:var(--soft); padding:26px 40px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .mw-strip-inner { max-width:1240px; margin:0 auto; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:18px 40px; }
  .mw-strip-inner span { display:inline-flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; color:var(--ink); }
  .mw-strip-inner svg { width:24px; height:24px; color:var(--red); flex-shrink:0; }
  .reviews { padding:60px 40px 64px; }
  .reviews .review-grid { grid-template-columns:repeat(4,1fr); gap:18px; margin-top:14px; max-width:1280px; margin-left:auto; margin-right:auto; }
  .rev-summary { display:flex; flex-direction:column; align-items:center; gap:6px; margin:10px auto 28px; }
  .rev-summary .big { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:40px; color:var(--ink); line-height:1; }
  .rev-summary .st { color:#FFB400; font-size:20px; letter-spacing:2px; }
  .rev-summary .sub { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#888; }
  .reviews .review-card { padding:22px 22px 24px; border:1px solid var(--line); box-shadow:0 8px 24px rgba(0,0,0,.05); }
  .reviews .review-body { font-size:14px; line-height:1.6; }
  .reviews .review-name { font-size:15px; }
  .reviews .review-stars { font-size:15px; }

  /* bottom contact form */
  .mcontact { background:var(--soft); padding:64px 40px; }
  .mcontact-only { max-width:520px; margin:0 auto; }
  .mcontact-grid { max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 480px; gap:48px; align-items:center; }
  .mcontact-text .ms-eye { display:block; }
  .mcontact-text h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; color:var(--ink); margin:12px 0 16px; }
  .mcontact-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; }
  .mcontact-text .row { display:flex; flex-direction:column; gap:12px; }
  .mcontact-text .row a { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); }
  .mcontact-text .row a:hover { color:var(--red-deep); }
  .mcontact-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:32px 30px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:12px; }
  .mcontact-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 4px; }
  .mcontact-form input, .mcontact-form select, .mcontact-form textarea { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcontact-form textarea { min-height:84px; resize:vertical; }
  .mcontact-form input:focus, .mcontact-form select:focus, .mcontact-form textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcontact-form button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcontact-form button:hover { background:var(--red-deep); transform:translateY(-2px); }

  @media (max-width:1024px){
    .reviews .review-grid { grid-template-columns:repeat(2,1fr); }
    .mcontact-grid { grid-template-columns:1fr; gap:28px; max-width:480px; }
    .mcontact-text { text-align:center; }
    .mcontact-text .row { align-items:center; }
    .mh-chip { left:24px; bottom:24px; }
    .ms, .mp, .mw, .mcta, .mcp { padding-left:32px; padding-right:32px; }
    .ms-grid, .mw-grid { grid-template-columns:repeat(2,1fr); }
    .mp-grid { grid-template-columns:1fr; gap:32px; }
    .mcp-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
    .mv { grid-template-columns:1fr; }
    .mv-photo { min-height:300px; }
    .mv-copy { padding:52px 32px; }
    .mstat { padding:0 32px; }
  }
  @media (max-width:640px){
    .mh-photo { aspect-ratio:1536/900; background-position:center 18%; }
    .mh-chip { left:16px; bottom:16px; padding:14px 16px; }
    .mh-chip .rt { font-size:20px; }
    .ms, .mp, .mw, .mcta, .mcp, .mc2 { padding-left:20px; padding-right:20px; }
    .ms, .mp, .mw, .mcp { padding-top:60px; padding-bottom:64px; }
    .ms-grid, .mw-grid { grid-template-columns:1fr; }
    .mv-copy { padding:44px 20px; }
    .mv-list { grid-template-columns:1fr; }
    .mstat { padding:0 20px; }
    .mstat-inner { grid-template-columns:1fr 1fr; transform:translateY(-12%); }
    .mstat-cell { border-bottom:1px solid var(--line); }
    .mstat-cell:nth-child(2) { border-right:0; }
    .reviews .review-grid { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; gap:14px; padding:4px 20px 16px; margin-left:-20px; margin-right:-20px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .reviews .review-grid::-webkit-scrollbar { display:none; }
    .reviews .review-card { flex:0 0 82%; scroll-snap-align:center; }
    .mcalc-row { grid-template-columns:1fr; }
    .mcalc-top, .mcalc-body { padding-left:22px; padding-right:22px; }
    .mcp-grid { grid-template-columns:repeat(2,1fr); }
    .mcp-badge { font-size:9px; padding:4px 8px; }
    .mcta .row { flex-direction:column; }
    .mcta .mbtn { justify-content:center; }
  }

/* ===== from index.html ===== */
.whyc{ background:#fff; padding:80px 40px; }
  .whyc-wrap{ max-width:1180px; margin:0 auto; }
  .whyc-title{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,44px); letter-spacing:-0.02em; color:var(--ink); margin:0 0 12px; }
  .whyc-row{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding:30px 4px; border-top:1px solid var(--line); }
  .whyc-row:last-child{ border-bottom:1px solid var(--line); }
  .whyc-row .txt{ max-width:760px; }
  .whyc-row .txt h3{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:clamp(22px,2.4vw,30px); color:var(--ink); margin:0 0 6px; }
  .whyc-row .txt h3 em{ font-style:normal; color:var(--red); }
  .whyc-row .txt p{ font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.6; color:#777; margin:0; }
  .whyc-row .num{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(40px,5vw,68px); color:var(--red); line-height:1; flex-shrink:0; }
  @media(max-width:640px){ .whyc{ padding:54px 20px; } .whyc-row{ gap:18px; padding:24px 2px; } }

/* ===== from index.html ===== */
.mh{ position:relative; }
  .mh-anniv{ position:absolute; top:50%; left:36px; transform:translateY(-50%); z-index:4; width:280px; height:280px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; background:rgba(0,0,0,.82); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 2l11 28 30 2-23 19 8 29-26-16-26 16 8-29-23-19 30-2z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 2l11 28 30 2-23 19 8 29-26-16-26 16 8-29-23-19 30-2z'/></svg>") center/contain no-repeat; }
  .mh-anniv-num{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:58px; line-height:.85; color:#fff; }
  .mh-anniv-txt{ display:flex; flex-direction:column; max-width:58%; }
  .mh-anniv-txt .t1{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:17px; line-height:1; color:#fff; }
  .mh-anniv-txt .t2{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:8.5px; letter-spacing:.06em; color:#fff; margin-top:3px; }
  @media(max-width:640px){ .mh-anniv{ top:14px; left:10px; transform:none; width:118px; height:118px; } .mh-anniv-num{ font-size:34px; } .mh-anniv-txt .t1{ font-size:12px; } .mh-anniv-txt .t2{ font-size:7px; letter-spacing:.14em; } } .mh-anniv-txt .t1{ font-size:11px; } .mh-anniv-txt .t2{ font-size:7px; letter-spacing:.14em; } }

/* ===== from index.html ===== */
.trust{ background:#fff; padding:44px 40px; }
  .trust-grid{ max-width:980px; margin:0 auto; display:grid; grid-template-columns:1fr 280px; gap:36px; max-width:880px; align-items:center; }
  .trust-left h2{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,3.8vw,48px); line-height:1.05; letter-spacing:-0.02em; color:var(--ink); margin:0 0 16px; }
  .trust-left p{ font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; max-width:400px; }
  .trust-widget{ border:1px solid #d8d8d8; border-radius:8px; overflow:hidden; box-shadow:0 14px 40px rgba(0,0,0,.10); background:#fff; }
  .trust-whead{ background:#1CA4DC; color:#fff; padding:10px 16px; display:flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:14px; }
  .trust-whead .hs{ background:#fff; color:#1CA4DC; font-weight:800; font-size:12px; padding:4px 9px; border-radius:5px; letter-spacing:-.02em; }
  .trust-best{ background:#f4f4f4; border-bottom:1px solid #e6e6e6; padding:11px 18px; text-align:center; font-family:'Hanken Grotesk',sans-serif; font-size:13.5px; color:#444; }
  .trust-best b{ color:#1C1A19; }
  .trust-best .crown{ color:#F4A100; margin-right:6px; }
  .trust-rev{ padding:11px 16px; border-bottom:1px solid #ececec; }
  .trust-rev .top{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
  .trust-rev .ti{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:#1C1A19; font-size:13.5px; }
  .trust-rev .sc{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:#1C1A19; font-size:14px; flex-shrink:0; }
  .trust-rev p{ font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; line-height:1.45; color:#777; margin:4px 0 5px; }
  .trust-rev .by{ font-size:12.5px; }
  .trust-rev .by .nm{ color:#1CA4DC; font-style:italic; font-weight:600; }
  .trust-rev .by .dt{ color:#999; margin-left:8px; }
  .trust-wfoot{ padding:16px 18px; background:#f7f7f7; display:flex; gap:12px; justify-content:center; }
  .trust-wfoot a{ background:#1CA4DC; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:14px; padding:11px 22px; border-radius:5px; }
  .trust-wfoot a:hover{ background:#1791c2; }
  .trust-powered{ text-align:center; font-size:11px; color:#aaa; margin-top:10px; font-family:'Hanken Grotesk',sans-serif; }
  @media(max-width:860px){ .trust{ padding:44px 20px; } .trust-grid{ grid-template-columns:1fr; gap:26px; max-width:420px; } }

/* ===== from index.html ===== */
.whyc{ padding:52px 40px; } .trust{ padding:38px 40px; } .mcp{ padding:52px 64px; }
  .mabout{ padding:46px 40px; } .reviews{ padding:46px 40px 50px; } .mcta{ padding:52px 64px; }
  .mc2{ padding:24px 20px 52px; } .lp{ padding-top:22px; padding-bottom:46px; }
  .lp-steps-head{ border-top:0; }
  @media(max-width:860px){ .mabout-media{ display:none; } .mabout-grid{ grid-template-columns:1fr; } }
  @media(max-width:640px){ .whyc,.trust,.mcp,.mabout,.reviews,.mcta{ padding-left:20px; padding-right:20px; } }

/* ===== from index.html ===== */
/* tighter tops + no stray borders */
  .whyc{ padding-top:8px !important; }
  .mcp{ padding-top:26px !important; }
  .mabout{ padding-top:26px !important; }
  .trust{ padding-top:20px !important; padding-bottom:24px !important; }
  .lp{ padding-top:6px !important; }
  .lp-steps-head{ border-top:0 !important; margin-top:10px !important; }
  section, .lp, .trust, .whyc, .mcp, .mabout { border-top:0 !important; }
  @media(max-width:860px){ .trust{ padding-top:8px !important; } .trust-grid{ gap:18px !important; } }

/* ===== from index.html ===== */
.lp{ padding-top:22px !important; padding-bottom:42px !important; }
  .reviews{ padding-top:40px !important; padding-bottom:44px !important; }
  .xtrust{ padding-top:32px !important; padding-bottom:32px !important; }
  .mcp,.mabout,.xwhyc,.mcta,.mc2{ padding-top:42px !important; padding-bottom:42px !important; }
  .whyc{ padding-top:0 !important; padding-bottom:42px !important; }
  .ip-sec{ padding-top:46px !important; padding-bottom:46px !important; }
  .ip-band{ padding-top:46px !important; padding-bottom:46px !important; }

/* ===== from index.html ===== */
/* Upcoming-project cards: brand logo + title instead of stock photo */
  .lp-photo.lp-upcoming { background:var(--soft); display:flex; align-items:center; justify-content:center; border:1px solid var(--line); }
  .lp-photo.lp-upcoming::after { display:none; }
  .lp-up-inner { display:flex; flex-direction:column; align-items:center; gap:16px; padding:24px; text-align:center; }
  .lp-up-logo { width:min(60%,196px); height:auto; display:block; }
  .lp-up-title { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(18px,2vw,22px); letter-spacing:-0.01em; color:var(--ink); }
  /* Emergency gallery card shows the van on white — contain, not crop */
  .mcp-img.mcp-van { background-color:#fff; background-size:contain; background-position:center; }

/* ===== from services.html ===== */
.section-title { color:#1C1A19; }
  :root { --ink:#1C1A19; --red:#F4A100; --red-deep:#C77F00; --soft:#F6F6F7; --line:#ececec; }

  /* ---------- HERO: full-width van banner ---------- */
  .mh { position:relative; background:#fff; overflow:hidden; }
  .mh-photo {
    width:100%;
    aspect-ratio:1536/560;
    background:#fff url('megapolis-van-star.jpg') center 20%/cover no-repeat;
  }
  .mh-chip { position:absolute; left:40px; bottom:34px; z-index:3; background:#fff; color:var(--ink); border-radius:18px; padding:18px 22px; box-shadow:0 24px 60px rgba(0,0,0,.28); display:flex; align-items:center; gap:14px; }
  .mh-chip .g { width:42px; height:42px; flex-shrink:0; }
  .mh-chip .rt { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; line-height:1; }
  .mh-chip .st { color:#FFB400; font-size:14px; letter-spacing:1px; }
  .mh-chip .lb { font-family:'Hanken Grotesk',sans-serif; font-size:12px; color:#666; margin-top:2px; }
  .mbtn { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; padding:18px 30px; border-radius:999px; cursor:pointer; transition:transform .2s, box-shadow .2s, background .2s; }
  .mbtn-red { background:var(--red); color:#1C1A19; box-shadow:0 12px 30px rgba(244,161,0,.35); }
  .mbtn-red:hover { transform:translateY(-2px); background:var(--red-deep); }

  /* ---------- LIVE PROJECT + STEPS + CONTACT ---------- */
  .lp { background:#fff; padding:30px 64px 90px; }
  .lp-head { text-align:center; max-width:720px; margin:0 auto 28px; }
  .lp-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .lp-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:14px; }
  .lp-count { max-width:520px; margin:0 auto 30px; background:var(--soft); border-radius:16px; padding:18px 24px; display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap; }
  .lp-count-label { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
  .lp-count-row { display:flex; align-items:center; gap:14px; }
  .lp-unit { text-align:center; min-width:42px; }
  .lp-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:28px; line-height:1; color:var(--ink); }
  .lp-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#999; margin-top:5px; }
  .lp-sep { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--red); }

  .lp-photos { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:1180px; margin:0 auto; }
  .lp-photo { position:relative; aspect-ratio:4/3; border-radius:16px; overflow:hidden; background:#111; }
  .lp-photo img { width:100%; height:100%; object-fit:cover; display:block; }
  .lp-photo::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.04) 50%, rgba(0,0,0,.55)); }
  .lp-live { position:absolute; top:12px; left:12px; z-index:2; display:inline-flex; align-items:center; gap:7px; background:#fff; color:var(--ink); font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:11px; letter-spacing:.1em; padding:5px 11px; border-radius:999px; }
  .lp-dot { width:7px; height:7px; border-radius:50%; background:var(--red); animation:lpPulse 1.4s ease-in-out infinite; }
  @keyframes lpPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(1.25)} }
  .lp-play { position:absolute; inset:0; margin:auto; width:60px; height:60px; z-index:2; background:none; border:none; cursor:pointer; }
  .lp-play svg { width:60px; height:60px; filter:drop-shadow(0 4px 14px rgba(0,0,0,.4)); transition:transform .2s; }
  .lp-play:hover svg { transform:scale(1.08); }
  .lp-cap { position:absolute; left:14px; bottom:12px; z-index:2; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:500; font-size:13px; }

  /* steps */
  .lp-steps-head { text-align:center; margin:60px auto 30px; }
  .lp-steps-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:1080px; margin:0 auto; }
  .lp-step { background:var(--soft); border-radius:18px; padding:36px 30px 30px; position:relative; }
  .lp-step-num { position:absolute; top:-16px; left:30px; width:44px; height:44px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:19px; box-shadow:0 8px 20px rgba(244,161,0,.35); }
  .lp-step h4 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; color:var(--ink); margin:10px 0 10px; }
  .lp-step p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }
  .lp-step:not(:last-child)::after { content:"›"; position:absolute; top:50%; right:-24px; transform:translateY(-50%); width:28px; height:0; border-top:2px dashed var(--red); z-index:2; color:var(--red); font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:26px; line-height:0; text-align:right; }

  /* estimate CTA: text + form (stands out on orange) */
  .lp-cta { display:grid; grid-template-columns:1fr 460px; gap:48px; align-items:center; max-width:1080px; margin:60px auto 0; background:var(--red); border-radius:24px; padding:48px 52px; }
  .lp-cta-text .ms-eye { color:#1C1A19; }
  .lp-cta-text h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3vw,40px); line-height:1.1; letter-spacing:-0.01em; color:#1C1A19; margin:10px 0 0; }
  .lp-cta-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; max-width:440px; }
  .lp-cta-call { display:inline-flex; align-items:center; gap:8px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--ink); }
  .lp-cta-call:hover { color:var(--red-deep); }

  /* compact contact form (NorthCan-style, narrow) */
  .lp-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 28px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:11px; }
  .lp-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 6px; text-align:center; }
  .lp-form .form-input, .lp-form .form-textarea { width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:9px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .lp-form .form-textarea { min-height:78px; resize:vertical; }
  .lp-form .form-input:focus, .lp-form .form-textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .lp-cta .lp-submit { background:var(--ink); color:#fff; }
  .lp-cta .lp-submit:hover { background:#000; }
  .lp-submit { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .lp-submit:hover { background:var(--red-deep); transform:translateY(-2px); }

  /* our services: bordered grid (Option C) */
  .lp-svc-head { text-align:center; margin:0 auto 28px; }
  .lp-svc-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; max-width:1000px; margin:0 auto; border:1px solid var(--line); border-radius:18px; overflow:hidden; }
  .lp-svc { display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; padding:44px 24px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; color:var(--ink); transition:background .2s; }
  .lp-svc:nth-child(3n) { border-right:0; }
  .lp-svc:nth-last-child(-n+3) { border-bottom:0; }
  .lp-svc:hover { background:var(--soft); }
  .lp-svc .c-ic { width:62px; height:62px; border-radius:15px; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .lp-svc .c-ic svg { width:34px; height:34px; }
  .lp-svc h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; line-height:1.25; }
  .lp-svc span { display:block; font-size:14px; line-height:1.5; color:#777; }

  /* cost calculator (bottom) */
  .mcalc-card { max-width:560px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 18px 50px rgba(0,0,0,.07); overflow:hidden; }
  .mcalc-top { background:var(--ink); color:#fff; padding:24px 30px; }
  .mcalc-top h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; }
  .mcalc-top p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:rgba(255,255,255,.7); margin-top:4px; }
  .mcalc-body { padding:26px 30px 30px; display:flex; flex-direction:column; gap:13px; }
  .mcalc-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .mcalc-body label { font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; font-weight:600; color:#888; display:flex; flex-direction:column; gap:5px; }
  .mcalc-body input, .mcalc-body select { padding:13px 14px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcalc-body input:focus, .mcalc-body select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcalc-btn { margin-top:6px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:16px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcalc-btn:hover { background:var(--red-deep); transform:translateY(-2px); }
  .mcalc-result { display:none; margin-top:4px; border:1px dashed var(--red); background:rgba(244,161,0,.07); border-radius:14px; padding:22px; text-align:center; }
  .mcalc-result.show { display:block; animation:calcfade .4s ease; }
  @keyframes calcfade { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }
  .mcalc-result .est-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#888; }
  .mcalc-result .est-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:34px; color:var(--ink); margin:6px 0; }
  .mcalc-result .est-note { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#555; }
  .mcalc-result .est-note b { color:var(--ink); }

  @media (max-width:1024px){
    .lp-svc-grid { grid-template-columns:repeat(3,1fr); }
    .lp-svc:nth-child(3n) { border-right:0; }
    .lp-svc:nth-child(-n+3) { border-bottom:1px solid var(--line); }
    .lp-svc:last-child { border-right:0; }
  }
  @media (max-width:760px){
    .lp { padding:24px 20px 48px; }
    .lp-photos { grid-template-columns:1fr; max-width:420px; }
    .lp-photos .lp-photo:nth-child(n+2) { display:none; }
    .lp-steps { grid-template-columns:1fr; max-width:420px; gap:28px; }
    .lp-step:not(:last-child)::after { display:none; }
    .lp-count { flex-direction:column; gap:12px; }
    .lp-cta { grid-template-columns:1fr; gap:22px; max-width:none; border-radius:18px; padding:26px 10px; }
    .lp-cta-text { text-align:center; }
    .lp-cta-text p { margin-left:auto; margin-right:auto; }
    .lp-form { padding:24px 20px; }
    .lp-svc-grid { grid-template-columns:repeat(2,1fr); max-width:420px; }
    .lp-svc:nth-child(2n) { border-right:0; }
    .lp-svc:nth-child(3n) { border-right:1px solid var(--line); }
    .lp-svc:nth-child(-n+4) { border-bottom:1px solid var(--line); }
    .mc2 { display:none; }
  }

  /* ---------- MARQUEE (kept) ---------- */
  .mq { background:var(--red); color:#1C1A19; overflow:hidden; padding:16px 0; white-space:nowrap; }
  .mq-track { display:inline-flex; gap:48px; animation:mqscroll 26s linear infinite; }
  .mq-track span { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; display:inline-flex; align-items:center; gap:48px; }
  .mq-track span::after { content:"◆"; font-size:10px; opacity:.7; }
  @keyframes mqscroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* shared eyebrow + section heads */
  .ms-eye { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); }

  /* ---------- STATS (kept, light) ---------- */
  .mstat { background:#fff; padding:0 64px; }
  .mstat-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); border-radius:24px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.10); transform:translateY(-50%); }
  .mstat-cell { background:#fff; padding:40px 28px; text-align:center; border-right:1px solid var(--line); }
  .mstat-cell:last-child { border-right:0; }
  .mstat-cell .n { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(32px,3.4vw,46px); color:var(--ink); line-height:1; }
  .mstat-cell .n em { font-style:normal; color:var(--red); }
  .mstat-cell .l { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#777; margin-top:9px; }

  /* ---------- SERVICES (light, red hover) ---------- */
  .ms { padding:30px 64px 100px; background:#fff; }
  .ms-head { max-width:720px; margin:0 auto 56px; text-align:center; }
  .ms-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .ms-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:16px; }
  .ms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1280px; margin:0 auto; }
  .ms-card { border:1px solid var(--line); border-radius:22px; padding:40px 34px; background:#fff; transition:transform .26s, box-shadow .26s, border-color .26s; }
  .ms-card .ic { width:60px; height:60px; border-radius:16px; background:rgba(244,161,0,.16); color:#1C1A19; display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:background .26s, color .26s; }
  .ms-card .ic svg { width:32px; height:32px; }
  .ms-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:23px; color:var(--ink); margin:0 0 10px; }
  .ms-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0 0 18px; }
  .ms-card .lk { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:14px; color:var(--red); display:inline-flex; align-items:center; gap:7px; }
  .ms-card:hover { transform:translateY(-8px); box-shadow:0 26px 54px rgba(244,161,0,.14); border-color:var(--red); }
  .ms-card:hover .ic { background:var(--red); color:#1C1A19; }

  /* ---------- VAN SPLIT (light) ---------- */
  .mv { display:grid; grid-template-columns:1fr 1fr; background:var(--soft); color:var(--ink); }
  .mv-photo { background:#fff url('megapolis-van.jpg') center/cover no-repeat; min-height:520px; }
  .mv-copy { padding:84px 64px; display:flex; flex-direction:column; justify-content:center; }
  .mv-copy h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; margin:16px 0 20px; color:var(--ink); }
  .mv-copy > p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0 0 30px; max-width:560px; }
  .mv-list { display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; margin-bottom:34px; }
  .mv-list span { display:flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:var(--ink); }
  .mv-list svg { width:20px; height:20px; color:var(--red); flex-shrink:0; }

  /* ---------- PROCESS (restored, light) ---------- */
  .mp { background:#fff; padding:100px 64px; text-align:center; }
  .mp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); letter-spacing:-0.02em; color:var(--ink); }
  .mp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; max-width:680px; margin:14px auto 56px; line-height:1.7; }
  .mp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1180px; margin:0 auto; position:relative; }
  .mp-card { background:var(--soft); border-radius:22px; padding:44px 34px; text-align:left; position:relative; }
  .mp-num { position:absolute; top:-16px; left:34px; width:46px; height:46px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:20px; box-shadow:0 8px 20px rgba(244,161,0,.3); }
  .mp-card .ic { width:58px; height:58px; margin:14px 0 18px; color:#1C1A19; }
  .mp-card .ic svg { width:58px; height:58px; }
  .mp-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:21px; color:var(--ink); margin:0 0 10px; }
  .mp-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }

  /* ---------- COMMITMENT (restored, white) ---------- */
  .mc2 { background:#fff; padding:24px 20px 64px; text-align:center; }
  .mc2-inner { max-width:1080px; margin:0 auto; }
  .mc2 h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3.4vw,42px); letter-spacing:-0.01em; color:var(--ink); line-height:1.14; margin:14px 0 30px; }
  .mc2 p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; line-height:1.8; color:#444; margin:0 auto 20px; max-width:920px; }
  .mc2 .sig { font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:var(--red); margin-top:26px; }

  /* ---------- COMPLETED (restored, light) ---------- */
  .mcp { background:var(--soft); padding:64px 64px 70px; text-align:center; }
  .mcp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; }
  .mcp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin:14px auto 56px; }
  .mcp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:980px; margin:0 auto; }
  .mcp-card { text-align:left; display:block; }
  .mcp-img { position:relative; aspect-ratio:4/3; border-radius:14px; overflow:hidden; background:#ddd center/cover no-repeat; box-shadow:0 10px 26px rgba(0,0,0,.10); transition:transform .25s, box-shadow .25s; }
  .mcp-card:hover .mcp-img { transform:translateY(-4px); box-shadow:0 18px 40px rgba(244,161,0,.22); }
  .mcp-img::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.45)); }
  .mcp-badge { position:absolute; top:10px; left:10px; z-index:2; background:var(--red); color:#1C1A19; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:5px 10px; border-radius:999px; }

  /* ---------- WHY (restored, light) ---------- */
  .mw { background:#fff; padding:100px 64px; }
  .mw-inner { max-width:1280px; margin:0 auto; }
  .mw-top { text-align:center; max-width:760px; margin:0 auto 56px; }
  .mw-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; margin:14px 0 0; }
  .mw-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin-top:16px; line-height:1.7; }
  .mw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .mw-item { border:1px solid var(--line); border-radius:18px; padding:32px 26px; transition:border-color .25s, box-shadow .25s, transform .25s; }
  .mw-item:hover { border-color:var(--red); box-shadow:0 18px 40px rgba(244,161,0,.10); transform:translateY(-4px); }
  .mw-item .ic { width:52px; height:52px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
  .mw-item .ic svg { width:52px; height:52px; }
  .mw-item h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); margin:0 0 8px; }
  .mw-item p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#666; margin:0; }

  /* ---------- CTA BANNER (red) ---------- */
  .mcta { background:var(--red); color:#1C1A19; padding:62px 64px; text-align:center; }
  .mcta h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,52px); line-height:1.05; letter-spacing:-0.01em; margin:0 0 14px; }
  .mcta p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; color:rgba(26,26,26,.78); margin:0 0 30px; }
  .mcta .row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .mcta .mbtn-white { background:#fff; color:var(--ink); }
  .mcta .mbtn-white:hover { transform:translateY(-2px); }
  .mcta .mbtn-dark { background:var(--ink); color:#fff; }

  /* Toronto-based + areas */
  .mabout { background:#fff; padding:64px 40px; }
  .mabout-top { max-width:900px; margin:0 auto 44px; text-align:center; }
  .mabout-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,46px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:12px 0 16px; }
  .mabout-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0; }
  .mabout-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:0.9fr 1.1fr; gap:50px; align-items:center; }
  .mabout-media { display:flex; justify-content:center; }
  .mabout-van { width:100%; max-width:480px; height:auto; }
  .mabout-copy p { font-family:'Hanken Grotesk',sans-serif; font-size:16px; line-height:1.75; color:#555; margin:0 0 18px; }
  .mabout-cities { display:flex; flex-wrap:wrap; gap:9px; }
  .mabout-cities span { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:13.5px; color:var(--ink); background:var(--soft); border:1px solid var(--line); padding:7px 14px; border-radius:999px; transition:background .2s, color .2s; }
  .mabout-cities span:hover { background:var(--red); color:#1C1A19; border-color:var(--red); }
  @media (max-width:860px){
    .mabout { padding:34px 20px 56px; }
    .mabout-top { margin-bottom:28px; }
    .mabout-grid { grid-template-columns:1fr; gap:24px; }
    .mabout-cities { justify-content:center; }
  }
  @media (max-width:600px){
    .lp { padding-top:14px; }
    .mcalc-card { max-width:none; }
    .mcontact-only { max-width:none; }
    .mcontact { padding:0; background:#fff; }
    .mcalc-card { border-left:0; border-right:0; border-radius:0; }
    .mcontact-form { border-left:0; border-right:0; border-radius:0; box-shadow:none; }
    .lp-steps-head { margin-top:28px; }
    .mw-strip { padding:30px 20px; }
    .mw-strip-inner { display:grid; grid-template-columns:1fr; gap:0; }
    .mw-strip-inner span { font-size:15px; padding:14px 4px; border-bottom:1px solid rgba(255,255,255,.12); width:100%; }
    .mw-strip-inner span:last-child { border-bottom:0; }
    .mw-strip-inner svg { width:22px; height:22px; }
    /* mobile-only contact form below services */
    .mobile-contact { display:flex; max-width:none; }
  }

  /* why bullet strip */
  .mobile-contact { display:none; max-width:460px; margin:34px auto 0; background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px 22px; box-shadow:0 14px 40px rgba(0,0,0,.07); flex-direction:column; gap:11px; }
  .mobile-contact h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:21px; color:var(--ink); margin:0 0 4px; text-align:center; }
  .mobile-contact input, .mobile-contact select { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mobile-contact input:focus, .mobile-contact select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mobile-contact button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:15px; cursor:pointer; }
  .mw-strip { background:var(--ink); padding:26px 40px; }
  .mw-strip-inner { max-width:1240px; margin:0 auto; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:18px 40px; }
  .mw-strip-inner span { display:inline-flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; color:#fff; }
  .mw-strip-inner svg { width:24px; height:24px; color:var(--red); flex-shrink:0; }
  .reviews { padding:60px 40px 64px; }
  .reviews .review-grid { grid-template-columns:repeat(4,1fr); gap:18px; margin-top:14px; max-width:1280px; margin-left:auto; margin-right:auto; }
  .rev-summary { display:flex; flex-direction:column; align-items:center; gap:6px; margin:10px auto 28px; }
  .rev-summary .big { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:40px; color:var(--ink); line-height:1; }
  .rev-summary .st { color:#FFB400; font-size:20px; letter-spacing:2px; }
  .rev-summary .sub { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#888; }
  .reviews .review-card { padding:22px 22px 24px; border:1px solid var(--line); box-shadow:0 8px 24px rgba(0,0,0,.05); }
  .reviews .review-body { font-size:14px; line-height:1.6; }
  .reviews .review-name { font-size:15px; }
  .reviews .review-stars { font-size:15px; }

  /* bottom contact form */
  .mcontact { background:var(--soft); padding:64px 40px; }
  .mcontact-only { max-width:520px; margin:0 auto; }
  .mcontact-grid { max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 480px; gap:48px; align-items:center; }
  .mcontact-text .ms-eye { display:block; }
  .mcontact-text h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; color:var(--ink); margin:12px 0 16px; }
  .mcontact-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; }
  .mcontact-text .row { display:flex; flex-direction:column; gap:12px; }
  .mcontact-text .row a { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); }
  .mcontact-text .row a:hover { color:var(--red-deep); }
  .mcontact-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:32px 30px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:12px; }
  .mcontact-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 4px; }
  .mcontact-form input, .mcontact-form select, .mcontact-form textarea { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcontact-form textarea { min-height:84px; resize:vertical; }
  .mcontact-form input:focus, .mcontact-form select:focus, .mcontact-form textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcontact-form button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcontact-form button:hover { background:var(--red-deep); transform:translateY(-2px); }

  @media (max-width:1024px){
    .reviews .review-grid { grid-template-columns:repeat(2,1fr); }
    .mcontact-grid { grid-template-columns:1fr; gap:28px; max-width:480px; }
    .mcontact-text { text-align:center; }
    .mcontact-text .row { align-items:center; }
    .mh-chip { left:24px; bottom:24px; }
    .ms, .mp, .mw, .mcta, .mcp { padding-left:32px; padding-right:32px; }
    .ms-grid, .mw-grid { grid-template-columns:repeat(2,1fr); }
    .mp-grid { grid-template-columns:1fr; gap:32px; }
    .mcp-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
    .mv { grid-template-columns:1fr; }
    .mv-photo { min-height:300px; }
    .mv-copy { padding:52px 32px; }
    .mstat { padding:0 32px; }
  }
  @media (max-width:640px){
    .mh-photo { aspect-ratio:1536/900; background-position:center 18%; }
    .mh-chip { left:16px; bottom:16px; padding:14px 16px; }
    .mh-chip .rt { font-size:20px; }
    .ms, .mp, .mw, .mcta, .mcp, .mc2 { padding-left:20px; padding-right:20px; }
    .ms, .mp, .mw, .mcp { padding-top:60px; padding-bottom:64px; }
    .ms-grid, .mw-grid { grid-template-columns:1fr; }
    .mv-copy { padding:44px 20px; }
    .mv-list { grid-template-columns:1fr; }
    .mstat { padding:0 20px; }
    .mstat-inner { grid-template-columns:1fr 1fr; transform:translateY(-12%); }
    .mstat-cell { border-bottom:1px solid var(--line); }
    .mstat-cell:nth-child(2) { border-right:0; }
    .reviews .review-grid { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; gap:14px; padding:4px 20px 16px; margin-left:-20px; margin-right:-20px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .reviews .review-grid::-webkit-scrollbar { display:none; }
    .reviews .review-card { flex:0 0 82%; scroll-snap-align:center; }
    .mcalc-row { grid-template-columns:1fr; }
    .mcalc-top, .mcalc-body { padding-left:22px; padding-right:22px; }
    .mcp-grid { grid-template-columns:repeat(2,1fr); }
    .mcp-badge { font-size:9px; padding:4px 8px; }
    .mcta .row { flex-direction:column; }
    .mcta .mbtn { justify-content:center; }
  }

/* ===== from services.html ===== */
.xtrust{ background:#fff; padding:44px 40px; }
  .xtrust-grid{ max-width:880px; margin:0 auto; display:grid; grid-template-columns:1fr 280px; gap:36px; align-items:center; }
  .xtrust-photo{ background:#fff url('megapolis-van.jpg') center/contain no-repeat; aspect-ratio:4/3; }
  .xtw{ border:1px solid #d8d8d8; border-radius:8px; overflow:hidden; box-shadow:0 14px 40px rgba(0,0,0,.10); background:#fff; }
  .xtw-h{ background:#1CA4DC; color:#fff; padding:10px 16px; display:flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:14px; }
  .xtw-h .hs{ background:#fff; color:#1CA4DC; font-weight:800; font-size:12px; padding:4px 9px; border-radius:5px; }
  .xtr{ padding:11px 16px; border-bottom:1px solid #ececec; }
  .xtr .top{ display:flex; justify-content:space-between; gap:10px; }
  .xtr .ti{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:#1C1A19; font-size:13.5px; }
  .xtr .sc{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:#1C1A19; font-size:14px; }
  .xtr p{ font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; line-height:1.45; color:#777; margin:4px 0 5px; }
  .xtr .by .nm{ color:#1CA4DC; font-style:italic; font-weight:600; font-size:12.5px; }
  .xtr .by .dt{ color:#999; margin-left:8px; font-size:12.5px; }
  .xtw-f{ padding:14px 16px; background:#f7f7f7; display:flex; gap:10px; justify-content:center; }
  .xtw-f a{ background:#1CA4DC; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:13px; padding:10px 18px; border-radius:5px; }
  .xtp{ text-align:center; font-size:11px; color:#aaa; margin-top:10px; font-family:'Hanken Grotesk',sans-serif; }
  @media(max-width:860px){ .xtrust{ padding:34px 20px; } .xtrust-grid{ grid-template-columns:1fr; gap:18px; max-width:420px; } .xtrust-photo{ display:none; } }

/* ===== from services.html ===== */
.vstar{ position:absolute; top:50%; left:36px; transform:translateY(-50%); z-index:4; width:210px; height:210px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; background:rgba(0,0,0,.82); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 2l11 28 30 2-23 19 8 29-26-16-26 16 8-29-23-19 30-2z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 2l11 28 30 2-23 19 8 29-26-16-26 16 8-29-23-19 30-2z'/></svg>") center/contain no-repeat; }
  .vstar .n{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:48px; color:#fff; line-height:.85; }
  .vstar .t{ display:flex; flex-direction:column; max-width:58%; }
  .vstar .a{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:15px; color:#fff; }
  .vstar .b{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:8px; letter-spacing:.06em; color:#fff; margin-top:2px; }
  @media(max-width:640px){ .vstar{ top:10px; left:10px; transform:none; width:112px; height:112px; } .vstar .n{ font-size:32px; } .vstar .a{ font-size:11px; } .vstar .b{ font-size:6.5px; } }

/* ===== from services.html ===== */
.lp{ padding-top:22px !important; padding-bottom:42px !important; }
  .reviews{ padding-top:40px !important; padding-bottom:44px !important; }
  .xtrust{ padding-top:32px !important; padding-bottom:32px !important; }
  .mcp,.mabout,.whyc,.xwhyc,.mcta,.mc2{ padding-top:42px !important; padding-bottom:42px !important; }
  .ip-sec{ padding-top:46px !important; padding-bottom:46px !important; }
  .ip-band{ padding-top:46px !important; padding-bottom:46px !important; }
  /* fix oversized white-on-white gaps between stacked sections */
  .ip-sec + .xtrust{ padding-top:4px !important; }
  .ip-sec:has(+ .xtrust){ padding-bottom:30px !important; }
  .xtrust + .lp{ padding-top:0 !important; }
  .xtrust:has(+ .lp){ padding-bottom:30px !important; }
  .lp-cta{ margin-top:0 !important; }

/* ===== from about.html ===== */
.section-title { color:#1C1A19; }
  :root { --ink:#1C1A19; --red:#F4A100; --red-deep:#C77F00; --soft:#F6F6F7; --line:#ececec; }

  /* ---------- HERO: full-width van banner ---------- */
  .mh { position:relative; background:#fff; overflow:hidden; }
  .mh-photo {
    width:100%;
    aspect-ratio:1536/560;
    background:#fff url('megapolis-van.jpg') center 20%/cover no-repeat;
  }
  .mh-chip { position:absolute; left:40px; bottom:34px; z-index:3; background:#fff; color:var(--ink); border-radius:18px; padding:18px 22px; box-shadow:0 24px 60px rgba(0,0,0,.28); display:flex; align-items:center; gap:14px; }
  .mh-chip .g { width:42px; height:42px; flex-shrink:0; }
  .mh-chip .rt { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; line-height:1; }
  .mh-chip .st { color:#FFB400; font-size:14px; letter-spacing:1px; }
  .mh-chip .lb { font-family:'Hanken Grotesk',sans-serif; font-size:12px; color:#666; margin-top:2px; }
  .mbtn { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; padding:18px 30px; border-radius:999px; cursor:pointer; transition:transform .2s, box-shadow .2s, background .2s; }
  .mbtn-red { background:var(--red); color:#1C1A19; box-shadow:0 12px 30px rgba(244,161,0,.35); }
  .mbtn-red:hover { transform:translateY(-2px); background:var(--red-deep); }

  /* ---------- LIVE PROJECT + STEPS + CONTACT ---------- */
  .lp { background:#fff; padding:30px 64px 90px; }
  .lp-head { text-align:center; max-width:720px; margin:0 auto 28px; }
  .lp-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .lp-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:14px; }
  .lp-count { max-width:520px; margin:0 auto 30px; background:var(--soft); border-radius:16px; padding:18px 24px; display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap; }
  .lp-count-label { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
  .lp-count-row { display:flex; align-items:center; gap:14px; }
  .lp-unit { text-align:center; min-width:42px; }
  .lp-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:28px; line-height:1; color:var(--ink); }
  .lp-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#999; margin-top:5px; }
  .lp-sep { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--red); }

  .lp-photos { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:1180px; margin:0 auto; }
  .lp-photo { position:relative; aspect-ratio:4/3; border-radius:16px; overflow:hidden; background:#111; }
  .lp-photo img { width:100%; height:100%; object-fit:cover; display:block; }
  .lp-photo::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.04) 50%, rgba(0,0,0,.55)); }
  .lp-live { position:absolute; top:12px; left:12px; z-index:2; display:inline-flex; align-items:center; gap:7px; background:#fff; color:var(--ink); font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:11px; letter-spacing:.1em; padding:5px 11px; border-radius:999px; }
  .lp-dot { width:7px; height:7px; border-radius:50%; background:var(--red); animation:lpPulse 1.4s ease-in-out infinite; }
  @keyframes lpPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(1.25)} }
  .lp-play { position:absolute; inset:0; margin:auto; width:60px; height:60px; z-index:2; background:none; border:none; cursor:pointer; }
  .lp-play svg { width:60px; height:60px; filter:drop-shadow(0 4px 14px rgba(0,0,0,.4)); transition:transform .2s; }
  .lp-play:hover svg { transform:scale(1.08); }
  .lp-cap { position:absolute; left:14px; bottom:12px; z-index:2; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:500; font-size:13px; }

  /* steps */
  .lp-steps-head { text-align:center; margin:60px auto 30px; }
  .lp-steps-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:1080px; margin:0 auto; }
  .lp-step { background:var(--soft); border-radius:18px; padding:36px 30px 30px; position:relative; }
  .lp-step-num { position:absolute; top:-16px; left:30px; width:44px; height:44px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:19px; box-shadow:0 8px 20px rgba(244,161,0,.35); }
  .lp-step h4 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; color:var(--ink); margin:10px 0 10px; }
  .lp-step p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }
  .lp-step:not(:last-child)::after { content:"›"; position:absolute; top:50%; right:-24px; transform:translateY(-50%); width:28px; height:0; border-top:2px dashed var(--red); z-index:2; color:var(--red); font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:26px; line-height:0; text-align:right; }

  /* estimate CTA: text + form (stands out on orange) */
  .lp-cta { display:grid; grid-template-columns:1fr 460px; gap:48px; align-items:center; max-width:1080px; margin:60px auto 0; background:var(--red); border-radius:24px; padding:48px 52px; }
  .lp-cta-text .ms-eye { color:#1C1A19; }
  .lp-cta-text h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3vw,40px); line-height:1.1; letter-spacing:-0.01em; color:#1C1A19; margin:10px 0 0; }
  .lp-cta-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; max-width:440px; }
  .lp-cta-call { display:inline-flex; align-items:center; gap:8px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--ink); }
  .lp-cta-call:hover { color:var(--red-deep); }

  /* compact contact form (NorthCan-style, narrow) */
  .lp-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 28px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:11px; }
  .lp-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 6px; text-align:center; }
  .lp-form .form-input, .lp-form .form-textarea { width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:9px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .lp-form .form-textarea { min-height:78px; resize:vertical; }
  .lp-form .form-input:focus, .lp-form .form-textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .lp-cta .lp-submit { background:var(--ink); color:#fff; }
  .lp-cta .lp-submit:hover { background:#000; }
  .lp-submit { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .lp-submit:hover { background:var(--red-deep); transform:translateY(-2px); }

  /* our services: bordered grid (Option C) */
  .lp-svc-head { text-align:center; margin:0 auto 28px; }
  .lp-svc-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; max-width:900px; margin:0 auto; border:1px solid var(--line); border-radius:18px; overflow:hidden; }
  .lp-svc { display:flex; flex-direction:column; align-items:center; text-align:center; gap:13px; padding:34px 16px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; color:var(--ink); transition:background .2s; }
  .lp-svc:nth-child(3n) { border-right:0; }
  .lp-svc:nth-last-child(-n+3) { border-bottom:0; }
  .lp-svc:hover { background:var(--soft); }
  .lp-svc .c-ic { width:52px; height:52px; border-radius:13px; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .lp-svc .c-ic svg { width:28px; height:28px; }
  .lp-svc h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; line-height:1.25; }
  .lp-svc span { display:none; }

  /* cost calculator (bottom) */
  .mcalc-card { max-width:560px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 18px 50px rgba(0,0,0,.07); overflow:hidden; }
  .mcalc-top { background:var(--ink); color:#fff; padding:24px 30px; }
  .mcalc-top h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; }
  .mcalc-top p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:rgba(255,255,255,.7); margin-top:4px; }
  .mcalc-body { padding:26px 30px 30px; display:flex; flex-direction:column; gap:13px; }
  .mcalc-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .mcalc-body label { font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; font-weight:600; color:#888; display:flex; flex-direction:column; gap:5px; }
  .mcalc-body input, .mcalc-body select { padding:13px 14px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcalc-body input:focus, .mcalc-body select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcalc-btn { margin-top:6px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:16px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcalc-btn:hover { background:var(--red-deep); transform:translateY(-2px); }
  .mcalc-result { display:none; margin-top:4px; border:1px dashed var(--red); background:rgba(244,161,0,.07); border-radius:14px; padding:22px; text-align:center; }
  .mcalc-result.show { display:block; animation:calcfade .4s ease; }
  @keyframes calcfade { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }
  .mcalc-result .est-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#888; }
  .mcalc-result .est-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:34px; color:var(--ink); margin:6px 0; }
  .mcalc-result .est-note { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#555; }
  .mcalc-result .est-note b { color:var(--ink); }

  @media (max-width:1024px){
    .lp-svc-grid { grid-template-columns:repeat(3,1fr); }
    .lp-svc:nth-child(3n) { border-right:0; }
    .lp-svc:nth-child(-n+3) { border-bottom:1px solid var(--line); }
    .lp-svc:last-child { border-right:0; }
  }
  @media (max-width:760px){
    .lp { padding:24px 20px 48px; }
    .lp-photos { grid-template-columns:1fr; max-width:420px; }
    .lp-photos .lp-photo:nth-child(n+2) { display:none; }
    .lp-steps { grid-template-columns:1fr; max-width:420px; gap:28px; }
    .lp-step:not(:last-child)::after { display:none; }
    .lp-count { flex-direction:column; gap:12px; }
    .lp-cta { grid-template-columns:1fr; gap:22px; max-width:none; border-radius:18px; padding:26px 10px; }
    .lp-cta-text { text-align:center; }
    .lp-cta-text p { margin-left:auto; margin-right:auto; }
    .lp-form { padding:24px 20px; }
    .lp-svc-grid { grid-template-columns:repeat(2,1fr); max-width:420px; }
    .lp-svc:nth-child(2n) { border-right:0; }
    .lp-svc:nth-child(3n) { border-right:1px solid var(--line); }
    .lp-svc:nth-child(-n+4) { border-bottom:1px solid var(--line); }
    .mc2 { display:none; }
  }

  /* ---------- MARQUEE (kept) ---------- */
  .mq { background:var(--red); color:#1C1A19; overflow:hidden; padding:16px 0; white-space:nowrap; }
  .mq-track { display:inline-flex; gap:48px; animation:mqscroll 26s linear infinite; }
  .mq-track span { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; display:inline-flex; align-items:center; gap:48px; }
  .mq-track span::after { content:"◆"; font-size:10px; opacity:.7; }
  @keyframes mqscroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* shared eyebrow + section heads */
  .ms-eye { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); }

  /* ---------- STATS (kept, light) ---------- */
  .mstat { background:#fff; padding:0 64px; }
  .mstat-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); border-radius:24px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.10); transform:translateY(-50%); }
  .mstat-cell { background:#fff; padding:40px 28px; text-align:center; border-right:1px solid var(--line); }
  .mstat-cell:last-child { border-right:0; }
  .mstat-cell .n { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(32px,3.4vw,46px); color:var(--ink); line-height:1; }
  .mstat-cell .n em { font-style:normal; color:var(--red); }
  .mstat-cell .l { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#777; margin-top:9px; }

  /* ---------- SERVICES (light, red hover) ---------- */
  .ms { padding:30px 64px 100px; background:#fff; }
  .ms-head { max-width:720px; margin:0 auto 56px; text-align:center; }
  .ms-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .ms-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:16px; }
  .ms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1280px; margin:0 auto; }
  .ms-card { border:1px solid var(--line); border-radius:22px; padding:40px 34px; background:#fff; transition:transform .26s, box-shadow .26s, border-color .26s; }
  .ms-card .ic { width:60px; height:60px; border-radius:16px; background:rgba(244,161,0,.16); color:#1C1A19; display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:background .26s, color .26s; }
  .ms-card .ic svg { width:32px; height:32px; }
  .ms-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:23px; color:var(--ink); margin:0 0 10px; }
  .ms-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0 0 18px; }
  .ms-card .lk { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:14px; color:var(--red); display:inline-flex; align-items:center; gap:7px; }
  .ms-card:hover { transform:translateY(-8px); box-shadow:0 26px 54px rgba(244,161,0,.14); border-color:var(--red); }
  .ms-card:hover .ic { background:var(--red); color:#1C1A19; }

  /* ---------- VAN SPLIT (light) ---------- */
  .mv { display:grid; grid-template-columns:1fr 1fr; background:var(--soft); color:var(--ink); }
  .mv-photo { background:#fff url('megapolis-van.jpg') center/cover no-repeat; min-height:520px; }
  .mv-copy { padding:84px 64px; display:flex; flex-direction:column; justify-content:center; }
  .mv-copy h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; margin:16px 0 20px; color:var(--ink); }
  .mv-copy > p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0 0 30px; max-width:560px; }
  .mv-list { display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; margin-bottom:34px; }
  .mv-list span { display:flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:var(--ink); }
  .mv-list svg { width:20px; height:20px; color:var(--red); flex-shrink:0; }

  /* ---------- PROCESS (restored, light) ---------- */
  .mp { background:#fff; padding:100px 64px; text-align:center; }
  .mp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); letter-spacing:-0.02em; color:var(--ink); }
  .mp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; max-width:680px; margin:14px auto 56px; line-height:1.7; }
  .mp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1180px; margin:0 auto; position:relative; }
  .mp-card { background:var(--soft); border-radius:22px; padding:44px 34px; text-align:left; position:relative; }
  .mp-num { position:absolute; top:-16px; left:34px; width:46px; height:46px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:20px; box-shadow:0 8px 20px rgba(244,161,0,.3); }
  .mp-card .ic { width:58px; height:58px; margin:14px 0 18px; color:#1C1A19; }
  .mp-card .ic svg { width:58px; height:58px; }
  .mp-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:21px; color:var(--ink); margin:0 0 10px; }
  .mp-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }

  /* ---------- COMMITMENT (restored, white) ---------- */
  .mc2 { background:#fff; padding:24px 20px 64px; text-align:center; }
  .mc2-inner { max-width:1080px; margin:0 auto; }
  .mc2 h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3.4vw,42px); letter-spacing:-0.01em; color:var(--ink); line-height:1.14; margin:14px 0 30px; }
  .mc2 p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; line-height:1.8; color:#444; margin:0 auto 20px; max-width:920px; }
  .mc2 .sig { font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:var(--red); margin-top:26px; }

  /* ---------- COMPLETED (restored, light) ---------- */
  .mcp { background:var(--soft); padding:64px 64px 70px; text-align:center; }
  .mcp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; }
  .mcp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin:14px auto 56px; }
  .mcp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:980px; margin:0 auto; }
  .mcp-card { text-align:left; display:block; }
  .mcp-img { position:relative; aspect-ratio:4/3; border-radius:14px; overflow:hidden; background:#ddd center/cover no-repeat; box-shadow:0 10px 26px rgba(0,0,0,.10); transition:transform .25s, box-shadow .25s; }
  .mcp-card:hover .mcp-img { transform:translateY(-4px); box-shadow:0 18px 40px rgba(244,161,0,.22); }
  .mcp-img::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.45)); }
  .mcp-badge { position:absolute; top:10px; left:10px; z-index:2; background:var(--red); color:#1C1A19; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:5px 10px; border-radius:999px; }

  /* ---------- WHY (restored, light) ---------- */
  .mw { background:#fff; padding:100px 64px; }
  .mw-inner { max-width:1280px; margin:0 auto; }
  .mw-top { text-align:center; max-width:760px; margin:0 auto 56px; }
  .mw-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; margin:14px 0 0; }
  .mw-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin-top:16px; line-height:1.7; }
  .mw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .mw-item { border:1px solid var(--line); border-radius:18px; padding:32px 26px; transition:border-color .25s, box-shadow .25s, transform .25s; }
  .mw-item:hover { border-color:var(--red); box-shadow:0 18px 40px rgba(244,161,0,.10); transform:translateY(-4px); }
  .mw-item .ic { width:52px; height:52px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
  .mw-item .ic svg { width:52px; height:52px; }
  .mw-item h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); margin:0 0 8px; }
  .mw-item p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#666; margin:0; }

  /* ---------- CTA BANNER (red) ---------- */
  .mcta { background:var(--red); color:#1C1A19; padding:62px 64px; text-align:center; }
  .mcta h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,52px); line-height:1.05; letter-spacing:-0.01em; margin:0 0 14px; }
  .mcta p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; color:rgba(26,26,26,.78); margin:0 0 30px; }
  .mcta .row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .mcta .mbtn-white { background:#fff; color:var(--ink); }
  .mcta .mbtn-white:hover { transform:translateY(-2px); }
  .mcta .mbtn-dark { background:var(--ink); color:#fff; }

  /* Toronto-based + areas */
  .mabout { background:#fff; padding:64px 40px; }
  .mabout-top { max-width:900px; margin:0 auto 44px; text-align:center; }
  .mabout-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,46px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:12px 0 16px; }
  .mabout-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0; }
  .mabout-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:0.9fr 1.1fr; gap:50px; align-items:center; }
  .mabout-media { display:flex; justify-content:center; }
  .mabout-van { width:100%; max-width:480px; height:auto; }
  .mabout-copy p { font-family:'Hanken Grotesk',sans-serif; font-size:16px; line-height:1.75; color:#555; margin:0 0 18px; }
  .mabout-cities { display:flex; flex-wrap:wrap; gap:9px; }
  .mabout-cities span { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:13.5px; color:var(--ink); background:var(--soft); border:1px solid var(--line); padding:7px 14px; border-radius:999px; transition:background .2s, color .2s; }
  .mabout-cities span:hover { background:var(--red); color:#1C1A19; border-color:var(--red); }
  @media (max-width:860px){
    .mabout { padding:34px 20px 56px; }
    .mabout-top { margin-bottom:28px; }
    .mabout-grid { grid-template-columns:1fr; gap:24px; }
    .mabout-cities { justify-content:center; }
  }
  @media (max-width:600px){
    .lp { padding-top:14px; }
    .mcalc-card { max-width:none; }
    .mcontact-only { max-width:none; }
    .mcontact { padding:0; background:#fff; }
    .mcalc-card { border-left:0; border-right:0; border-radius:0; }
    .mcontact-form { border-left:0; border-right:0; border-radius:0; box-shadow:none; }
    .lp-steps-head { margin-top:28px; }
    .mw-strip { padding:30px 20px; }
    .mw-strip-inner { display:grid; grid-template-columns:1fr; gap:0; }
    .mw-strip-inner span { font-size:15px; padding:14px 4px; border-bottom:1px solid var(--line); width:100%; }
    .mw-strip-inner span:last-child { border-bottom:0; }
    .mw-strip-inner svg { width:22px; height:22px; }
    /* mobile-only contact form below services */
    .mobile-contact { display:flex; max-width:none; }
  }

  /* why bullet strip */
  .mobile-contact { display:none; max-width:460px; margin:34px auto 0; background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px 22px; box-shadow:0 14px 40px rgba(0,0,0,.07); flex-direction:column; gap:11px; }
  .mobile-contact h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:21px; color:var(--ink); margin:0 0 4px; text-align:center; }
  .mobile-contact input, .mobile-contact select { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mobile-contact input:focus, .mobile-contact select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mobile-contact button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:15px; cursor:pointer; }
  .mw-strip { background:var(--soft); padding:26px 40px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .mw-strip-inner { max-width:1240px; margin:0 auto; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:18px 40px; }
  .mw-strip-inner span { display:inline-flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; color:var(--ink); }
  .mw-strip-inner svg { width:24px; height:24px; color:var(--red); flex-shrink:0; }
  .reviews { padding:60px 40px 64px; }
  .reviews .review-grid { grid-template-columns:repeat(4,1fr); gap:18px; margin-top:14px; max-width:1280px; margin-left:auto; margin-right:auto; }
  .rev-summary { display:flex; flex-direction:column; align-items:center; gap:6px; margin:10px auto 28px; }
  .rev-summary .big { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:40px; color:var(--ink); line-height:1; }
  .rev-summary .st { color:#FFB400; font-size:20px; letter-spacing:2px; }
  .rev-summary .sub { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#888; }
  .reviews .review-card { padding:22px 22px 24px; border:1px solid var(--line); box-shadow:0 8px 24px rgba(0,0,0,.05); }
  .reviews .review-body { font-size:14px; line-height:1.6; }
  .reviews .review-name { font-size:15px; }
  .reviews .review-stars { font-size:15px; }

  /* bottom contact form */
  .mcontact { background:var(--soft); padding:64px 40px; }
  .mcontact-only { max-width:520px; margin:0 auto; }
  .mcontact-grid { max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 480px; gap:48px; align-items:center; }
  .mcontact-text .ms-eye { display:block; }
  .mcontact-text h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; color:var(--ink); margin:12px 0 16px; }
  .mcontact-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; }
  .mcontact-text .row { display:flex; flex-direction:column; gap:12px; }
  .mcontact-text .row a { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); }
  .mcontact-text .row a:hover { color:var(--red-deep); }
  .mcontact-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:32px 30px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:12px; }
  .mcontact-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 4px; }
  .mcontact-form input, .mcontact-form select, .mcontact-form textarea { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcontact-form textarea { min-height:84px; resize:vertical; }
  .mcontact-form input:focus, .mcontact-form select:focus, .mcontact-form textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcontact-form button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcontact-form button:hover { background:var(--red-deep); transform:translateY(-2px); }

  @media (max-width:1024px){
    .reviews .review-grid { grid-template-columns:repeat(2,1fr); }
    .mcontact-grid { grid-template-columns:1fr; gap:28px; max-width:480px; }
    .mcontact-text { text-align:center; }
    .mcontact-text .row { align-items:center; }
    .mh-chip { left:24px; bottom:24px; }
    .ms, .mp, .mw, .mcta, .mcp { padding-left:32px; padding-right:32px; }
    .ms-grid, .mw-grid { grid-template-columns:repeat(2,1fr); }
    .mp-grid { grid-template-columns:1fr; gap:32px; }
    .mcp-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
    .mv { grid-template-columns:1fr; }
    .mv-photo { min-height:300px; }
    .mv-copy { padding:52px 32px; }
    .mstat { padding:0 32px; }
  }
  @media (max-width:640px){
    .mh-photo { aspect-ratio:1536/900; background-position:center 18%; }
    .mh-chip { left:16px; bottom:16px; padding:14px 16px; }
    .mh-chip .rt { font-size:20px; }
    .ms, .mp, .mw, .mcta, .mcp, .mc2 { padding-left:20px; padding-right:20px; }
    .ms, .mp, .mw, .mcp { padding-top:60px; padding-bottom:64px; }
    .ms-grid, .mw-grid { grid-template-columns:1fr; }
    .mv-copy { padding:44px 20px; }
    .mv-list { grid-template-columns:1fr; }
    .mstat { padding:0 20px; }
    .mstat-inner { grid-template-columns:1fr 1fr; transform:translateY(-12%); }
    .mstat-cell { border-bottom:1px solid var(--line); }
    .mstat-cell:nth-child(2) { border-right:0; }
    .reviews .review-grid { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; gap:14px; padding:4px 20px 16px; margin-left:-20px; margin-right:-20px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .reviews .review-grid::-webkit-scrollbar { display:none; }
    .reviews .review-card { flex:0 0 82%; scroll-snap-align:center; }
    .mcalc-row { grid-template-columns:1fr; }
    .mcalc-top, .mcalc-body { padding-left:22px; padding-right:22px; }
    .mcp-grid { grid-template-columns:repeat(2,1fr); }
    .mcp-badge { font-size:9px; padding:4px 8px; }
    .mcta .row { flex-direction:column; }
    .mcta .mbtn { justify-content:center; }
  }

/* ===== from about.html ===== */
@media(max-width:760px){.mc2{display:block !important;}}

/* ===== from about.html ===== */
.xwhyc{ background:#fff; padding:54px 40px; }
  .xwhyc-wrap{ max-width:1180px; margin:0 auto; }
  .xwhyc-title{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,44px); letter-spacing:-0.02em; color:#1C1A19; margin:0 0 12px; }
  .xwhyc-row{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding:28px 4px; border-top:1px solid #ececec; }
  .xwhyc-row:last-child{ border-bottom:1px solid #ececec; }
  .xwhyc-row .txt{ max-width:760px; }
  .xwhyc-row .txt h3{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:clamp(20px,2.2vw,28px); color:#1C1A19; margin:0 0 6px; }
  .xwhyc-row .txt h3 em{ font-style:normal; color:#F4A100; }
  .xwhyc-row .txt p{ font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.6; color:#777; margin:0; }
  .xwhyc-row .num{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(38px,5vw,62px); color:#F4A100; line-height:1; flex-shrink:0; }
  @media(max-width:640px){ .xwhyc{ padding:44px 20px; } .xwhyc-row{ gap:18px; padding:22px 2px; } }

/* ===== from service-areas.html ===== */
.section-title { color:#1C1A19; }
  :root { --ink:#1C1A19; --red:#F4A100; --red-deep:#C77F00; --soft:#F6F6F7; --line:#ececec; }

  /* ---------- HERO: full-width van banner ---------- */
  .mh { position:relative; background:#fff; overflow:hidden; }
  .mh-photo {
    width:100%;
    aspect-ratio:1536/560;
    background:#fff url('megapolis-van.jpg') center 20%/cover no-repeat;
  }
  .mh-chip { position:absolute; left:40px; bottom:34px; z-index:3; background:#fff; color:var(--ink); border-radius:18px; padding:18px 22px; box-shadow:0 24px 60px rgba(0,0,0,.28); display:flex; align-items:center; gap:14px; }
  .mh-chip .g { width:42px; height:42px; flex-shrink:0; }
  .mh-chip .rt { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; line-height:1; }
  .mh-chip .st { color:#FFB400; font-size:14px; letter-spacing:1px; }
  .mh-chip .lb { font-family:'Hanken Grotesk',sans-serif; font-size:12px; color:#666; margin-top:2px; }
  .mbtn { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; padding:18px 30px; border-radius:999px; cursor:pointer; transition:transform .2s, box-shadow .2s, background .2s; }
  .mbtn-red { background:var(--red); color:#1C1A19; box-shadow:0 12px 30px rgba(244,161,0,.35); }
  .mbtn-red:hover { transform:translateY(-2px); background:var(--red-deep); }

  /* ---------- LIVE PROJECT + STEPS + CONTACT ---------- */
  .lp { background:#fff; padding:30px 64px 90px; }
  .lp-head { text-align:center; max-width:720px; margin:0 auto 28px; }
  .lp-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .lp-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:14px; }
  .lp-count { max-width:520px; margin:0 auto 30px; background:var(--soft); border-radius:16px; padding:18px 24px; display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap; }
  .lp-count-label { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
  .lp-count-row { display:flex; align-items:center; gap:14px; }
  .lp-unit { text-align:center; min-width:42px; }
  .lp-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:28px; line-height:1; color:var(--ink); }
  .lp-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#999; margin-top:5px; }
  .lp-sep { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--red); }

  .lp-photos { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:1180px; margin:0 auto; }
  .lp-photo { position:relative; aspect-ratio:4/3; border-radius:16px; overflow:hidden; background:#111; }
  .lp-photo img { width:100%; height:100%; object-fit:cover; display:block; }
  .lp-photo::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.04) 50%, rgba(0,0,0,.55)); }
  .lp-live { position:absolute; top:12px; left:12px; z-index:2; display:inline-flex; align-items:center; gap:7px; background:#fff; color:var(--ink); font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:11px; letter-spacing:.1em; padding:5px 11px; border-radius:999px; }
  .lp-dot { width:7px; height:7px; border-radius:50%; background:var(--red); animation:lpPulse 1.4s ease-in-out infinite; }
  @keyframes lpPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(1.25)} }
  .lp-play { position:absolute; inset:0; margin:auto; width:60px; height:60px; z-index:2; background:none; border:none; cursor:pointer; }
  .lp-play svg { width:60px; height:60px; filter:drop-shadow(0 4px 14px rgba(0,0,0,.4)); transition:transform .2s; }
  .lp-play:hover svg { transform:scale(1.08); }
  .lp-cap { position:absolute; left:14px; bottom:12px; z-index:2; color:#fff; font-family:'Hanken Grotesk',sans-serif; font-weight:500; font-size:13px; }

  /* steps */
  .lp-steps-head { text-align:center; margin:60px auto 30px; }
  .lp-steps-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:1080px; margin:0 auto; }
  .lp-step { background:var(--soft); border-radius:18px; padding:36px 30px 30px; position:relative; }
  .lp-step-num { position:absolute; top:-16px; left:30px; width:44px; height:44px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:19px; box-shadow:0 8px 20px rgba(244,161,0,.35); }
  .lp-step h4 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; color:var(--ink); margin:10px 0 10px; }
  .lp-step p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }
  .lp-step:not(:last-child)::after { content:"›"; position:absolute; top:50%; right:-24px; transform:translateY(-50%); width:28px; height:0; border-top:2px dashed var(--red); z-index:2; color:var(--red); font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:26px; line-height:0; text-align:right; }

  /* estimate CTA: text + form (stands out on orange) */
  .lp-cta { display:grid; grid-template-columns:1fr 460px; gap:48px; align-items:center; max-width:1080px; margin:60px auto 0; background:var(--red); border-radius:24px; padding:48px 52px; }
  .lp-cta-text .ms-eye { color:#1C1A19; }
  .lp-cta-text h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3vw,40px); line-height:1.1; letter-spacing:-0.01em; color:#1C1A19; margin:10px 0 0; }
  .lp-cta-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; max-width:440px; }
  .lp-cta-call { display:inline-flex; align-items:center; gap:8px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:var(--ink); }
  .lp-cta-call:hover { color:var(--red-deep); }

  /* compact contact form (NorthCan-style, narrow) */
  .lp-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 28px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:11px; }
  .lp-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 6px; text-align:center; }
  .lp-form .form-input, .lp-form .form-textarea { width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:9px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .lp-form .form-textarea { min-height:78px; resize:vertical; }
  .lp-form .form-input:focus, .lp-form .form-textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .lp-cta .lp-submit { background:var(--ink); color:#fff; }
  .lp-cta .lp-submit:hover { background:#000; }
  .lp-submit { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .lp-submit:hover { background:var(--red-deep); transform:translateY(-2px); }

  /* our services: bordered grid (Option C) */
  .lp-svc-head { text-align:center; margin:0 auto 28px; }
  .lp-svc-head h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(24px,3vw,38px); color:var(--ink); letter-spacing:-0.01em; margin:12px 0 0; }
  .lp-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; max-width:1000px; margin:0 auto; border:1px solid var(--line); border-radius:18px; overflow:hidden; }
  .lp-svc { display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; padding:44px 24px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; color:var(--ink); transition:background .2s; }
  .lp-svc:nth-child(3n) { border-right:0; }
  .lp-svc:nth-last-child(-n+3) { border-bottom:0; }
  .lp-svc:hover { background:var(--soft); }
  .lp-svc .c-ic { width:62px; height:62px; border-radius:15px; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .lp-svc .c-ic svg { width:34px; height:34px; }
  .lp-svc h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:20px; line-height:1.25; }
  .lp-svc span { display:block; font-size:14px; line-height:1.5; color:#777; }
  .city-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; max-width:1080px; margin:0 auto; }
  .city-grid a { display:flex; align-items:center; gap:9px; padding:16px 18px; border:1px solid var(--line); border-radius:14px; background:#fff; color:var(--ink); font-weight:600; font-size:15px; transition:transform .2s, box-shadow .2s, border-color .2s; }
  .city-grid a:hover { transform:translateY(-3px); border-color:var(--red); box-shadow:0 14px 30px rgba(244,161,0,.16); }
  .city-grid .pin { width:18px; height:18px; flex-shrink:0; background:var(--red); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 21s-7-5.5-7-11a7 7 0 0114 0c0 5.5-7 11-7 11z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 21s-7-5.5-7-11a7 7 0 0114 0c0 5.5-7 11-7 11z'/></svg>") center/contain no-repeat; }
  @media (max-width:1024px){ .city-grid { grid-template-columns:repeat(3,1fr); } }
  @media (max-width:640px){ .city-grid { grid-template-columns:repeat(2,1fr); } }

  /* cost calculator (bottom) */
  .mcalc-card { max-width:560px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 18px 50px rgba(0,0,0,.07); overflow:hidden; }
  .mcalc-top { background:var(--ink); color:#fff; padding:24px 30px; }
  .mcalc-top h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; }
  .mcalc-top p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:rgba(255,255,255,.7); margin-top:4px; }
  .mcalc-body { padding:26px 30px 30px; display:flex; flex-direction:column; gap:13px; }
  .mcalc-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .mcalc-body label { font-family:'Hanken Grotesk',sans-serif; font-size:12.5px; font-weight:600; color:#888; display:flex; flex-direction:column; gap:5px; }
  .mcalc-body input, .mcalc-body select { padding:13px 14px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcalc-body input:focus, .mcalc-body select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcalc-btn { margin-top:6px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:16px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcalc-btn:hover { background:var(--red-deep); transform:translateY(-2px); }
  .mcalc-result { display:none; margin-top:4px; border:1px dashed var(--red); background:rgba(244,161,0,.07); border-radius:14px; padding:22px; text-align:center; }
  .mcalc-result.show { display:block; animation:calcfade .4s ease; }
  @keyframes calcfade { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }
  .mcalc-result .est-lbl { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#888; }
  .mcalc-result .est-num { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:34px; color:var(--ink); margin:6px 0; }
  .mcalc-result .est-note { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#555; }
  .mcalc-result .est-note b { color:var(--ink); }

  @media (max-width:1024px){
    .lp-svc-grid { grid-template-columns:repeat(3,1fr); }
    .lp-svc:nth-child(3n) { border-right:0; }
    .lp-svc:nth-child(-n+3) { border-bottom:1px solid var(--line); }
    .lp-svc:last-child { border-right:0; }
  }
  @media (max-width:760px){
    .lp { padding:24px 20px 48px; }
    .lp-photos { grid-template-columns:1fr; max-width:420px; }
    .lp-photos .lp-photo:nth-child(n+2) { display:none; }
    .lp-steps { grid-template-columns:1fr; max-width:420px; gap:28px; }
    .lp-step:not(:last-child)::after { display:none; }
    .lp-count { flex-direction:column; gap:12px; }
    .lp-cta { grid-template-columns:1fr; gap:22px; max-width:none; border-radius:18px; padding:26px 10px; }
    .lp-cta-text { text-align:center; }
    .lp-cta-text p { margin-left:auto; margin-right:auto; }
    .lp-form { padding:24px 20px; }
    .lp-svc-grid { grid-template-columns:repeat(2,1fr); max-width:420px; }
    .lp-svc:nth-child(2n) { border-right:0; }
    .lp-svc:nth-child(3n) { border-right:1px solid var(--line); }
    .lp-svc:nth-child(-n+4) { border-bottom:1px solid var(--line); }
    .mc2 { display:none; }
  }

  /* ---------- MARQUEE (kept) ---------- */
  .mq { background:var(--red); color:#1C1A19; overflow:hidden; padding:16px 0; white-space:nowrap; }
  .mq-track { display:inline-flex; gap:48px; animation:mqscroll 26s linear infinite; }
  .mq-track span { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:17px; display:inline-flex; align-items:center; gap:48px; }
  .mq-track span::after { content:"◆"; font-size:10px; opacity:.7; }
  @keyframes mqscroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* shared eyebrow + section heads */
  .ms-eye { font-family:'Hanken Grotesk',sans-serif; font-size:13px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); }

  /* ---------- STATS (kept, light) ---------- */
  .mstat { background:#fff; padding:0 64px; }
  .mstat-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); border-radius:24px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.10); transform:translateY(-50%); }
  .mstat-cell { background:#fff; padding:40px 28px; text-align:center; border-right:1px solid var(--line); }
  .mstat-cell:last-child { border-right:0; }
  .mstat-cell .n { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(32px,3.4vw,46px); color:var(--ink); line-height:1; }
  .mstat-cell .n em { font-style:normal; color:var(--red); }
  .mstat-cell .l { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#777; margin-top:9px; }

  /* ---------- SERVICES (light, red hover) ---------- */
  .ms { padding:30px 64px 100px; background:#fff; }
  .ms-head { max-width:720px; margin:0 auto 56px; text-align:center; }
  .ms-head h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,50px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:14px 0 0; }
  .ms-head p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin-top:16px; }
  .ms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1280px; margin:0 auto; }
  .ms-card { border:1px solid var(--line); border-radius:22px; padding:40px 34px; background:#fff; transition:transform .26s, box-shadow .26s, border-color .26s; }
  .ms-card .ic { width:60px; height:60px; border-radius:16px; background:rgba(244,161,0,.16); color:#1C1A19; display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:background .26s, color .26s; }
  .ms-card .ic svg { width:32px; height:32px; }
  .ms-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:23px; color:var(--ink); margin:0 0 10px; }
  .ms-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0 0 18px; }
  .ms-card .lk { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:14px; color:var(--red); display:inline-flex; align-items:center; gap:7px; }
  .ms-card:hover { transform:translateY(-8px); box-shadow:0 26px 54px rgba(244,161,0,.14); border-color:var(--red); }
  .ms-card:hover .ic { background:var(--red); color:#1C1A19; }

  /* ---------- VAN SPLIT (light) ---------- */
  .mv { display:grid; grid-template-columns:1fr 1fr; background:var(--soft); color:var(--ink); }
  .mv-photo { background:#fff url('megapolis-van.jpg') center/cover no-repeat; min-height:520px; }
  .mv-copy { padding:84px 64px; display:flex; flex-direction:column; justify-content:center; }
  .mv-copy h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; margin:16px 0 20px; color:var(--ink); }
  .mv-copy > p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0 0 30px; max-width:560px; }
  .mv-list { display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; margin-bottom:34px; }
  .mv-list span { display:flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:var(--ink); }
  .mv-list svg { width:20px; height:20px; color:var(--red); flex-shrink:0; }

  /* ---------- PROCESS (restored, light) ---------- */
  .mp { background:#fff; padding:100px 64px; text-align:center; }
  .mp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,50px); letter-spacing:-0.02em; color:var(--ink); }
  .mp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; max-width:680px; margin:14px auto 56px; line-height:1.7; }
  .mp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1180px; margin:0 auto; position:relative; }
  .mp-card { background:var(--soft); border-radius:22px; padding:44px 34px; text-align:left; position:relative; }
  .mp-num { position:absolute; top:-16px; left:34px; width:46px; height:46px; border-radius:50%; background:var(--red); color:#1C1A19; display:flex; align-items:center; justify-content:center; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:20px; box-shadow:0 8px 20px rgba(244,161,0,.3); }
  .mp-card .ic { width:58px; height:58px; margin:14px 0 18px; color:#1C1A19; }
  .mp-card .ic svg { width:58px; height:58px; }
  .mp-card h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:21px; color:var(--ink); margin:0 0 10px; }
  .mp-card p { font-family:'Hanken Grotesk',sans-serif; font-size:15px; line-height:1.65; color:#666; margin:0; }

  /* ---------- COMMITMENT (restored, white) ---------- */
  .mc2 { background:#fff; padding:24px 20px 64px; text-align:center; }
  .mc2-inner { max-width:1080px; margin:0 auto; }
  .mc2 h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3.4vw,42px); letter-spacing:-0.01em; color:var(--ink); line-height:1.14; margin:14px 0 30px; }
  .mc2 p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; line-height:1.8; color:#444; margin:0 auto 20px; max-width:920px; }
  .mc2 .sig { font-family:'Hanken Grotesk',sans-serif; font-weight:700; color:var(--red); margin-top:26px; }

  /* ---------- COMPLETED (restored, light) ---------- */
  .mcp { background:var(--soft); padding:64px 64px 70px; text-align:center; }
  .mcp h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; }
  .mcp .lead { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin:14px auto 56px; }
  .mcp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:980px; margin:0 auto; }
  .mcp-card { text-align:left; display:block; }
  .mcp-img { position:relative; aspect-ratio:4/3; border-radius:14px; overflow:hidden; background:#ddd center/cover no-repeat; box-shadow:0 10px 26px rgba(0,0,0,.10); transition:transform .25s, box-shadow .25s; }
  .mcp-card:hover .mcp-img { transform:translateY(-4px); box-shadow:0 18px 40px rgba(244,161,0,.22); }
  .mcp-img::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.45)); }
  .mcp-badge { position:absolute; top:10px; left:10px; z-index:2; background:var(--red); color:#1C1A19; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:5px 10px; border-radius:999px; }

  /* ---------- WHY (restored, light) ---------- */
  .mw { background:#fff; padding:100px 64px; }
  .mw-inner { max-width:1280px; margin:0 auto; }
  .mw-top { text-align:center; max-width:760px; margin:0 auto 56px; }
  .mw-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,4vw,48px); color:var(--ink); letter-spacing:-0.02em; margin:14px 0 0; }
  .mw-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; color:#666; margin-top:16px; line-height:1.7; }
  .mw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .mw-item { border:1px solid var(--line); border-radius:18px; padding:32px 26px; transition:border-color .25s, box-shadow .25s, transform .25s; }
  .mw-item:hover { border-color:var(--red); box-shadow:0 18px 40px rgba(244,161,0,.10); transform:translateY(-4px); }
  .mw-item .ic { width:52px; height:52px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
  .mw-item .ic svg { width:52px; height:52px; }
  .mw-item h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); margin:0 0 8px; }
  .mw-item p { font-family:'Hanken Grotesk',sans-serif; font-size:14px; line-height:1.6; color:#666; margin:0; }

  /* ---------- CTA BANNER (red) ---------- */
  .mcta { background:var(--red); color:#1C1A19; padding:62px 64px; text-align:center; }
  .mcta h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(30px,4vw,52px); line-height:1.05; letter-spacing:-0.01em; margin:0 0 14px; }
  .mcta p { font-family:'Hanken Grotesk',sans-serif; font-size:18px; color:rgba(26,26,26,.78); margin:0 0 30px; }
  .mcta .row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .mcta .mbtn-white { background:#fff; color:var(--ink); }
  .mcta .mbtn-white:hover { transform:translateY(-2px); }
  .mcta .mbtn-dark { background:var(--ink); color:#fff; }

  /* Toronto-based + areas */
  .mabout { background:#fff; padding:64px 40px; }
  .mabout-top { max-width:900px; margin:0 auto 44px; text-align:center; }
  .mabout-top h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.6vw,46px); line-height:1.08; letter-spacing:-0.02em; color:var(--ink); margin:12px 0 16px; }
  .mabout-top p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.75; color:#555; margin:0; }
  .mabout-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:0.9fr 1.1fr; gap:50px; align-items:center; }
  .mabout-media { display:flex; justify-content:center; }
  .mabout-van { width:100%; max-width:480px; height:auto; }
  .mabout-copy p { font-family:'Hanken Grotesk',sans-serif; font-size:16px; line-height:1.75; color:#555; margin:0 0 18px; }
  .mabout-cities { display:flex; flex-wrap:wrap; gap:9px; }
  .mabout-cities span { font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:13.5px; color:var(--ink); background:var(--soft); border:1px solid var(--line); padding:7px 14px; border-radius:999px; transition:background .2s, color .2s; }
  .mabout-cities span:hover { background:var(--red); color:#1C1A19; border-color:var(--red); }
  @media (max-width:860px){
    .mabout { padding:34px 20px 56px; }
    .mabout-top { margin-bottom:28px; }
    .mabout-grid { grid-template-columns:1fr; gap:24px; }
    .mabout-cities { justify-content:center; }
  }
  @media (max-width:600px){
    .lp { padding-top:14px; }
    .mcalc-card { max-width:none; }
    .mcontact-only { max-width:none; }
    .mcontact { padding:0; background:#fff; }
    .mcalc-card { border-left:0; border-right:0; border-radius:0; }
    .mcontact-form { border-left:0; border-right:0; border-radius:0; box-shadow:none; }
    .lp-steps-head { margin-top:28px; }
    .mw-strip { padding:30px 20px; }
    .mw-strip-inner { display:grid; grid-template-columns:1fr; gap:0; }
    .mw-strip-inner span { font-size:15px; padding:14px 4px; border-bottom:1px solid rgba(255,255,255,.12); width:100%; }
    .mw-strip-inner span:last-child { border-bottom:0; }
    .mw-strip-inner svg { width:22px; height:22px; }
    /* mobile-only contact form below services */
    .mobile-contact { display:flex; max-width:none; }
  }

  /* why bullet strip */
  .mobile-contact { display:none; max-width:460px; margin:34px auto 0; background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px 22px; box-shadow:0 14px 40px rgba(0,0,0,.07); flex-direction:column; gap:11px; }
  .mobile-contact h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:21px; color:var(--ink); margin:0 0 4px; text-align:center; }
  .mobile-contact input, .mobile-contact select { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mobile-contact input:focus, .mobile-contact select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mobile-contact button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:15px; cursor:pointer; }
  .mw-strip { background:var(--ink); padding:26px 40px; }
  .mw-strip-inner { max-width:1240px; margin:0 auto; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:18px 40px; }
  .mw-strip-inner span { display:inline-flex; align-items:center; gap:11px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:16px; color:#fff; }
  .mw-strip-inner svg { width:24px; height:24px; color:var(--red); flex-shrink:0; }
  .reviews { padding:60px 40px 64px; }
  .reviews .review-grid { grid-template-columns:repeat(4,1fr); gap:18px; margin-top:14px; max-width:1280px; margin-left:auto; margin-right:auto; }
  .rev-summary { display:flex; flex-direction:column; align-items:center; gap:6px; margin:10px auto 28px; }
  .rev-summary .big { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:40px; color:var(--ink); line-height:1; }
  .rev-summary .st { color:#FFB400; font-size:20px; letter-spacing:2px; }
  .rev-summary .sub { font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:#888; }
  .reviews .review-card { padding:22px 22px 24px; border:1px solid var(--line); box-shadow:0 8px 24px rgba(0,0,0,.05); }
  .reviews .review-body { font-size:14px; line-height:1.6; }
  .reviews .review-name { font-size:15px; }
  .reviews .review-stars { font-size:15px; }

  /* bottom contact form */
  .mcontact { background:var(--soft); padding:64px 40px; }
  .mcontact-only { max-width:520px; margin:0 auto; }
  .mcontact-grid { max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 480px; gap:48px; align-items:center; }
  .mcontact-text .ms-eye { display:block; }
  .mcontact-text h2 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-0.01em; color:var(--ink); margin:12px 0 16px; }
  .mcontact-text p { font-family:'Hanken Grotesk',sans-serif; font-size:17px; line-height:1.7; color:#666; margin:0 0 22px; }
  .mcontact-text .row { display:flex; flex-direction:column; gap:12px; }
  .mcontact-text .row a { display:inline-flex; align-items:center; gap:10px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--ink); }
  .mcontact-text .row a:hover { color:var(--red-deep); }
  .mcontact-form { background:#fff; border:1px solid var(--line); border-radius:18px; padding:32px 30px; box-shadow:0 18px 50px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:12px; }
  .mcontact-form h3 { font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:22px; color:var(--ink); margin:0 0 4px; }
  .mcontact-form input, .mcontact-form select, .mcontact-form textarea { width:100%; padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); background:#fff; }
  .mcontact-form textarea { min-height:84px; resize:vertical; }
  .mcontact-form input:focus, .mcontact-form select:focus, .mcontact-form textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .mcontact-form button { margin-top:4px; background:var(--red); color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; cursor:pointer; transition:background .2s, transform .2s; }
  .mcontact-form button:hover { background:var(--red-deep); transform:translateY(-2px); }

  @media (max-width:1024px){
    .reviews .review-grid { grid-template-columns:repeat(2,1fr); }
    .mcontact-grid { grid-template-columns:1fr; gap:28px; max-width:480px; }
    .mcontact-text { text-align:center; }
    .mcontact-text .row { align-items:center; }
    .mh-chip { left:24px; bottom:24px; }
    .ms, .mp, .mw, .mcta, .mcp { padding-left:32px; padding-right:32px; }
    .ms-grid, .mw-grid { grid-template-columns:repeat(2,1fr); }
    .mp-grid { grid-template-columns:1fr; gap:32px; }
    .mcp-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
    .mv { grid-template-columns:1fr; }
    .mv-photo { min-height:300px; }
    .mv-copy { padding:52px 32px; }
    .mstat { padding:0 32px; }
  }
  @media (max-width:640px){
    .mh-photo { aspect-ratio:1536/900; background-position:center 18%; }
    .mh-chip { left:16px; bottom:16px; padding:14px 16px; }
    .mh-chip .rt { font-size:20px; }
    .ms, .mp, .mw, .mcta, .mcp, .mc2 { padding-left:20px; padding-right:20px; }
    .ms, .mp, .mw, .mcp { padding-top:60px; padding-bottom:64px; }
    .ms-grid, .mw-grid { grid-template-columns:1fr; }
    .mv-copy { padding:44px 20px; }
    .mv-list { grid-template-columns:1fr; }
    .mstat { padding:0 20px; }
    .mstat-inner { grid-template-columns:1fr 1fr; transform:translateY(-12%); }
    .mstat-cell { border-bottom:1px solid var(--line); }
    .mstat-cell:nth-child(2) { border-right:0; }
    .reviews .review-grid { display:flex; overflow-x:auto; scroll-snap-type:x mandatory; gap:14px; padding:4px 20px 16px; margin-left:-20px; margin-right:-20px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .reviews .review-grid::-webkit-scrollbar { display:none; }
    .reviews .review-card { flex:0 0 82%; scroll-snap-align:center; }
    .mcalc-row { grid-template-columns:1fr; }
    .mcalc-top, .mcalc-body { padding-left:22px; padding-right:22px; }
    .mcp-grid { grid-template-columns:repeat(2,1fr); }
    .mcp-badge { font-size:9px; padding:4px 8px; }
    .mcta .row { flex-direction:column; }
    .mcta .mbtn { justify-content:center; }
  }

/* ===== from contact.html ===== */
.ct-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:48px; align-items:start; max-width:1080px; margin:0 auto; }
  .ct-info h2{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:clamp(26px,3vw,40px); color:var(--ink); margin:12px 0 14px; letter-spacing:-0.01em; }
  .ct-info p.lead{ font-size:16px; line-height:1.7; color:#666; margin:0 0 26px; }
  .ct-bits{ display:flex; flex-direction:column; gap:18px; }
  .ct-bit{ display:flex; gap:14px; align-items:flex-start; }
  .ct-bit .ic{ width:46px; height:46px; border-radius:50%; background:var(--yellow); color:var(--ink); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .ct-bit .ic svg{ width:20px; height:20px; }
  .ct-bit h3{ font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:var(--ink); margin:0 0 3px; }
  .ct-bit p{ font-size:14px; color:#666; margin:0; line-height:1.55; }
  .ct-bit a{ color:var(--yellow-deep); font-weight:600; }
  @media (max-width:880px){ .ct-grid{ grid-template-columns:1fr; gap:30px; } }

/* ===== from estimate.html ===== */
.calc-card{ max-width:600px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 18px 50px rgba(0,0,0,.08); overflow:hidden; }
  .calc-top{ background:var(--soft); color:var(--ink); padding:26px 32px; border-bottom:1px solid var(--line); }
  .calc-top h3{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:23px; margin:0; }
  .calc-top p{ font-size:14px; color:#777; margin:4px 0 0; }
  .calc-body{ padding:28px 32px 32px; display:flex; flex-direction:column; gap:14px; }
  .calc-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .calc-body label{ font-size:12.5px; font-weight:600; color:#888; display:flex; flex-direction:column; gap:6px; }
  .calc-body input,.calc-body select{ padding:14px 15px; border:1px solid var(--line); border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:14px; color:var(--ink); }
  .calc-body input:focus,.calc-body select:focus{ outline:none; border-color:var(--yellow); box-shadow:0 0 0 3px rgba(244,161,0,.18); }
  .calc-btn{ margin-top:6px; background:var(--yellow); color:var(--ink); border:none; border-radius:999px; padding:16px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; }
  .calc-btn:hover{ background:var(--yellow-deep); }
  .calc-res{ display:none; margin-top:6px; border:1px dashed var(--yellow); background:rgba(244,161,0,.08); border-radius:14px; padding:22px; text-align:center; }
  .calc-res.show{ display:block; }
  .calc-res .l{ font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#888; }
  .calc-res .n{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:34px; color:var(--ink); margin:6px 0; }
  .calc-res .note{ font-size:14px; line-height:1.6; color:#555; }
  @media (max-width:560px){ .calc-row{ grid-template-columns:1fr; } .calc-card{ border-radius:0; border-left:0; border-right:0; } }
/* ---- Spacing fix: separate the 3 steps from the estimate/contact form ---- */
.lp-steps { margin-bottom: 30px; }
.lp-cta { margin-top: 80px !important; }
@media (max-width: 600px){
  .lp-steps { margin-bottom: 22px; }
  .lp-cta { margin-top: 44px !important; }
}

/* ---- Floating call + contact CTA ---- */
.mega-fab{ position:fixed; right:22px; bottom:22px; z-index:9999; display:flex; flex-direction:column; gap:12px; align-items:flex-end; }
.mega-fab-btn{ display:inline-flex; align-items:center; gap:10px; padding:14px 22px; border-radius:999px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:15px; line-height:1; text-decoration:none; box-shadow:0 14px 34px rgba(0,0,0,.28); transition:transform .18s ease, box-shadow .18s ease; }
.mega-fab-btn svg{ width:20px; height:20px; flex-shrink:0; }
.mega-fab-btn:hover{ transform:translateY(-2px); box-shadow:0 18px 40px rgba(0,0,0,.34); }
.mega-fab-call{ background:#1C1A19; color:#fff; }
.mega-fab-contact{ background:#F4A100; color:#1C1A19; }
@media (max-width:600px){
  .mega-fab{ left:0; right:0; bottom:0; flex-direction:row; gap:0; align-items:stretch; box-shadow:0 -6px 18px rgba(0,0,0,.16); }
  .mega-fab-btn{ flex:1 1 50%; justify-content:center; border-radius:0; padding:15px 8px; font-size:16px; box-shadow:none; }
  .mega-fab-btn:hover{ transform:none; box-shadow:none; }
  body{ padding-bottom:60px; }
}

/* ---- Free-estimate popup modal ---- */
.mega-modal{ position:fixed; inset:0; z-index:10000; display:none; }
.mega-modal.open{ display:block; }
.mega-modal-overlay{ position:absolute; inset:0; background:rgba(15,12,10,.62); backdrop-filter:saturate(120%) blur(2px); }
.mega-modal-card{ position:relative; z-index:1; width:min(460px,92vw); max-height:92vh; overflow:auto; margin:6vh auto 0; background:#fff; border-radius:18px; padding:30px 28px 28px; box-shadow:0 30px 80px rgba(0,0,0,.4); animation:megaPop .22s ease; }
@keyframes megaPop{ from{opacity:0; transform:translateY(14px);} to{opacity:1; transform:translateY(0);} }
.mega-modal-x{ position:absolute; top:12px; right:14px; width:34px; height:34px; border:none; background:#f3f3f4; border-radius:50%; font-size:22px; line-height:1; color:#1C1A19; cursor:pointer; }
.mega-modal-x:hover{ background:#e7e7e9; }
.mega-modal-card h3{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:24px; color:#1C1A19; margin:0 6px 6px 0; }
.mega-modal-sub{ font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:#666; margin:0 0 18px; }
.mega-modal-form{ display:flex; flex-direction:column; gap:11px; }
.mega-modal-form input, .mega-modal-form select, .mega-modal-form textarea{ width:100%; padding:14px 15px; border:1px solid #ececec; border-radius:10px; font-family:'Hanken Grotesk',sans-serif; font-size:15px; color:#1C1A19; background:#fff; }
.mega-modal-form textarea{ min-height:84px; resize:vertical; }
.mega-modal-form input:focus, .mega-modal-form select:focus, .mega-modal-form textarea:focus{ outline:none; border-color:#F4A100; box-shadow:0 0 0 3px rgba(244,161,0,.18); }
.mega-modal-submit{ margin-top:4px; background:#F4A100; color:#1C1A19; border:none; border-radius:999px; padding:15px 22px; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:16px; cursor:pointer; transition:background .2s, transform .2s; }
.mega-modal-submit:hover{ background:#C77F00; transform:translateY(-2px); }
body.mega-modal-open{ overflow:hidden; }
@media (max-width:600px){ .mega-modal-card{ margin-top:4vh; padding:26px 18px 22px; } }

/* ---- Mobile-only Emergency Line button (next to logo) ---- */
.header-emergency{ display:none; }
@media (max-width:960px){
  .header-emergency{ display:inline-flex; align-items:center; gap:7px; margin-left:12px; margin-right:auto; background:var(--red,#F4A100); color:#1C1A19; font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:13px; line-height:1; padding:10px 14px; border-radius:999px; box-shadow:0 6px 16px rgba(244,161,0,.3); white-space:nowrap; text-decoration:none; }
  .header-emergency:hover{ background:var(--red-deep,#C77F00); }
  .header-emergency svg{ width:16px; height:16px; flex-shrink:0; }
}
@media (max-width:380px){
  .header-emergency span{ display:none; }
  .header-emergency{ margin-left:10px; padding:10px 12px; }
}
