/* locations.css: scoped page-specific styles for toronto, north-york, etobicoke, mississauga, oakville. */

/* toronto.html */
body.page-toronto .plumbing-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
body.page-toronto .plumbing-service-card {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
body.page-toronto .plumbing-service-card:hover {
      border-color: var(--navy-900);
      box-shadow: var(--shadow-hover);
    }
body.page-toronto .plumbing-service-card__icon {
      width: 36px;
      height: 36px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-toronto .plumbing-service-card h3 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 22px;
      letter-spacing: -0.003em;
      line-height: 1.1;
      margin: 0;
      color: var(--navy-900);
    }
body.page-toronto .plumbing-service-card p {
      font-size: 14px;
      color: var(--steel-700);
      line-height: 1.55;
      margin: 0;
    }
body.page-toronto .trust-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line-rev);
      margin-top: 64px;
    }
body.page-toronto .trust-item {
      padding: 40px 32px 32px 0;
      border-right: 1px solid var(--line-rev);
    }
body.page-toronto .trust-item:last-child { border-right: none; padding-right: 0; }
body.page-toronto .trust-item:not(:first-child) { padding-left: 32px; }
body.page-toronto .trust-item__num {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(48px, 5vw, 72px);
      line-height: 0.96;
      letter-spacing: -0.02em;
      color: var(--paper);
      margin-bottom: 10px;
    }
body.page-toronto .trust-item__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      color: var(--steel-300);
      text-transform: uppercase;
      display: block;
    }
body.page-toronto .trust-item__sub {
      font-size: 14px;
      color: var(--steel-500);
      margin-top: 6px;
      line-height: 1.5;
    }
body.page-toronto .neighborhood-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
    }
body.page-toronto .neighborhood-tile {
      padding: 28px 26px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: background 0.2s ease;
    }
body.page-toronto .neighborhood-tile:hover { background: var(--paper-2); }
body.page-toronto .neighborhood-tile__name {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      letter-spacing: -0.003em;
      color: var(--navy-900);
      margin: 0;
    }
body.page-toronto .neighborhood-tile__sub {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-toronto .local-trust-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 72px;
      align-items: start;
    }
body.page-toronto .local-trust-grid p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.65;
      margin: 0 0 18px;
    }
body.page-toronto .local-trust-grid p:last-child { margin-bottom: 0; }
body.page-toronto .local-creds {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
body.page-toronto .local-creds__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0 0 6px;
    }
body.page-toronto .local-creds__item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-toronto .local-creds__item svg {
      width: 18px;
      height: 18px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-toronto .area-strip { padding: 56px 0; background: var(--paper-2); border-top: 1px solid var(--line); }
body.page-toronto .area-strip__inner {
      display: flex;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
    }
body.page-toronto .area-strip__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-toronto .area-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      list-style: none;
      padding: 0;
      margin: 0;
    }
body.page-toronto .area-pills a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 18px;
      border: 1px solid var(--line);
      background: var(--paper);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--navy-900);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
    }
body.page-toronto .area-pills a:hover {
      border-color: var(--navy-900);
      background: var(--paper);
    }
body.page-toronto .area-pills a svg {
      width: 12px;
      height: 12px;
    }
body.page-toronto .quote-section .container {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 80px;
      align-items: start;
    }
body.page-toronto .quote-section__left h2 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(36px, 4.5vw, 60px);
      letter-spacing: -0.008em;
      line-height: 1.04;
      margin: 12px 0 22px;
      color: var(--navy-900);
      text-wrap: balance;
    }
body.page-toronto .quote-section__left p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.6;
      margin: 0 0 32px;
      max-width: 440px;
    }
body.page-toronto .quote-section__trust {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 32px;
      padding-top: 32px;
      border-top: 1px solid var(--line);
    }
body.page-toronto .quote-section__trust-item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-toronto .quote-section__trust-item svg {
      width: 20px;
      height: 20px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-toronto .quote-section .quote-form {
      max-width: none;
      margin-left: 0;
    }
@media (max-width: 1100px) {
body.page-toronto .plumbing-services-grid { grid-template-columns: repeat(2, 1fr); }
body.page-toronto .neighborhood-grid { grid-template-columns: repeat(3, 1fr); }

    
}
@media (max-width: 920px) {
body.page-toronto .plumbing-services-grid { grid-template-columns: 1fr; }
body.page-toronto .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
body.page-toronto .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
body.page-toronto .trust-item { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line-rev); }
body.page-toronto .trust-item:not(:first-child) { padding-left: 0; }
body.page-toronto .trust-item:nth-child(odd) { border-right: 1px solid var(--line-rev); padding-right: 24px; }
body.page-toronto .trust-item:nth-child(even) { padding-left: 24px; }
body.page-toronto .local-trust-grid { grid-template-columns: 1fr; gap: 40px; }
body.page-toronto .quote-section .container { grid-template-columns: 1fr; gap: 48px; }
body.page-toronto .quote-section__left p { max-width: none; }

    
}
@media (max-width: 600px) {
body.page-toronto .neighborhood-grid { grid-template-columns: 1fr; }

    
}

/* north-york.html */
body.page-north-york .plumbing-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
body.page-north-york .plumbing-service-card {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
body.page-north-york .plumbing-service-card:hover {
      border-color: var(--navy-900);
      box-shadow: var(--shadow-hover);
    }
body.page-north-york .plumbing-service-card__icon {
      width: 36px;
      height: 36px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-north-york .plumbing-service-card h3 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 22px;
      letter-spacing: -0.003em;
      line-height: 1.1;
      margin: 0;
      color: var(--navy-900);
    }
body.page-north-york .plumbing-service-card p {
      font-size: 14px;
      color: var(--steel-700);
      line-height: 1.55;
      margin: 0;
    }
body.page-north-york .trust-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line-rev);
      margin-top: 64px;
    }
body.page-north-york .trust-item {
      padding: 40px 32px 32px 0;
      border-right: 1px solid var(--line-rev);
    }
body.page-north-york .trust-item:last-child { border-right: none; padding-right: 0; }
body.page-north-york .trust-item:not(:first-child) { padding-left: 32px; }
body.page-north-york .trust-item__num {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(48px, 5vw, 72px);
      line-height: 0.96;
      letter-spacing: -0.02em;
      color: var(--paper);
      margin-bottom: 10px;
    }
body.page-north-york .trust-item__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      color: var(--steel-300);
      text-transform: uppercase;
      display: block;
    }
body.page-north-york .trust-item__sub {
      font-size: 14px;
      color: var(--steel-500);
      margin-top: 6px;
      line-height: 1.5;
    }
body.page-north-york .neighborhood-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
    }
body.page-north-york .neighborhood-tile {
      padding: 28px 26px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: background 0.2s ease;
    }
body.page-north-york .neighborhood-tile:hover { background: var(--paper-2); }
body.page-north-york .neighborhood-tile__name {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      letter-spacing: -0.003em;
      color: var(--navy-900);
      margin: 0;
    }
body.page-north-york .neighborhood-tile__sub {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-north-york .local-trust-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 72px;
      align-items: start;
    }
body.page-north-york .local-trust-grid p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.65;
      margin: 0 0 18px;
    }
body.page-north-york .local-trust-grid p:last-child { margin-bottom: 0; }
body.page-north-york .local-creds {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
body.page-north-york .local-creds__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0 0 6px;
    }
body.page-north-york .local-creds__item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-north-york .local-creds__item svg {
      width: 18px;
      height: 18px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-north-york .area-strip { padding: 56px 0; background: var(--paper-2); border-top: 1px solid var(--line); }
body.page-north-york .area-strip__inner {
      display: flex;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
    }
body.page-north-york .area-strip__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-north-york .area-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      list-style: none;
      padding: 0;
      margin: 0;
    }
body.page-north-york .area-pills a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 18px;
      border: 1px solid var(--line);
      background: var(--paper);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--navy-900);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
    }
body.page-north-york .area-pills a:hover {
      border-color: var(--navy-900);
      background: var(--paper);
    }
body.page-north-york .area-pills a svg {
      width: 12px;
      height: 12px;
    }
body.page-north-york .quote-section .container {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 80px;
      align-items: start;
    }
body.page-north-york .quote-section__left h2 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(36px, 4.5vw, 60px);
      letter-spacing: -0.008em;
      line-height: 1.04;
      margin: 12px 0 22px;
      color: var(--navy-900);
      text-wrap: balance;
    }
body.page-north-york .quote-section__left p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.6;
      margin: 0 0 32px;
      max-width: 440px;
    }
body.page-north-york .quote-section__trust {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 32px;
      padding-top: 32px;
      border-top: 1px solid var(--line);
    }
body.page-north-york .quote-section__trust-item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-north-york .quote-section__trust-item svg {
      width: 20px;
      height: 20px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-north-york .quote-section .quote-form {
      max-width: none;
      margin-left: 0;
    }
@media (max-width: 1100px) {
body.page-north-york .plumbing-services-grid { grid-template-columns: repeat(2, 1fr); }
body.page-north-york .neighborhood-grid { grid-template-columns: repeat(3, 1fr); }

    
}
@media (max-width: 920px) {
body.page-north-york .plumbing-services-grid { grid-template-columns: 1fr; }
body.page-north-york .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
body.page-north-york .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
body.page-north-york .trust-item { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line-rev); }
body.page-north-york .trust-item:not(:first-child) { padding-left: 0; }
body.page-north-york .trust-item:nth-child(odd) { border-right: 1px solid var(--line-rev); padding-right: 24px; }
body.page-north-york .trust-item:nth-child(even) { padding-left: 24px; }
body.page-north-york .local-trust-grid { grid-template-columns: 1fr; gap: 40px; }
body.page-north-york .quote-section .container { grid-template-columns: 1fr; gap: 48px; }
body.page-north-york .quote-section__left p { max-width: none; }

    
}
@media (max-width: 600px) {
body.page-north-york .neighborhood-grid { grid-template-columns: 1fr; }

    
}

/* etobicoke.html */
body.page-etobicoke .plumbing-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
body.page-etobicoke .plumbing-service-card {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
body.page-etobicoke .plumbing-service-card:hover {
      border-color: var(--navy-900);
      box-shadow: var(--shadow-hover);
    }
body.page-etobicoke .plumbing-service-card__icon {
      width: 36px;
      height: 36px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-etobicoke .plumbing-service-card h3 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 22px;
      letter-spacing: -0.003em;
      line-height: 1.1;
      margin: 0;
      color: var(--navy-900);
    }
body.page-etobicoke .plumbing-service-card p {
      font-size: 14px;
      color: var(--steel-700);
      line-height: 1.55;
      margin: 0;
    }
body.page-etobicoke .trust-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line-rev);
      margin-top: 64px;
    }
body.page-etobicoke .trust-item {
      padding: 40px 32px 32px 0;
      border-right: 1px solid var(--line-rev);
    }
body.page-etobicoke .trust-item:last-child { border-right: none; padding-right: 0; }
body.page-etobicoke .trust-item:not(:first-child) { padding-left: 32px; }
body.page-etobicoke .trust-item__num {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(48px, 5vw, 72px);
      line-height: 0.96;
      letter-spacing: -0.02em;
      color: var(--paper);
      margin-bottom: 10px;
    }
body.page-etobicoke .trust-item__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      color: var(--steel-300);
      text-transform: uppercase;
      display: block;
    }
body.page-etobicoke .trust-item__sub {
      font-size: 14px;
      color: var(--steel-500);
      margin-top: 6px;
      line-height: 1.5;
    }
body.page-etobicoke .neighborhood-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
    }
body.page-etobicoke .neighborhood-tile {
      padding: 28px 26px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: background 0.2s ease;
    }
body.page-etobicoke .neighborhood-tile:hover { background: var(--paper-2); }
body.page-etobicoke .neighborhood-tile__name {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      letter-spacing: -0.003em;
      color: var(--navy-900);
      margin: 0;
    }
body.page-etobicoke .neighborhood-tile__sub {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-etobicoke .local-trust-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 72px;
      align-items: start;
    }
body.page-etobicoke .local-trust-grid p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.65;
      margin: 0 0 18px;
    }
body.page-etobicoke .local-trust-grid p:last-child { margin-bottom: 0; }
body.page-etobicoke .local-creds {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
body.page-etobicoke .local-creds__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0 0 6px;
    }
body.page-etobicoke .local-creds__item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-etobicoke .local-creds__item svg {
      width: 18px;
      height: 18px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-etobicoke .area-strip { padding: 56px 0; background: var(--paper-2); border-top: 1px solid var(--line); }
body.page-etobicoke .area-strip__inner {
      display: flex;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
    }
body.page-etobicoke .area-strip__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-etobicoke .area-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      list-style: none;
      padding: 0;
      margin: 0;
    }
body.page-etobicoke .area-pills a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 18px;
      border: 1px solid var(--line);
      background: var(--paper);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--navy-900);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
    }
body.page-etobicoke .area-pills a:hover {
      border-color: var(--navy-900);
      background: var(--paper);
    }
body.page-etobicoke .area-pills a svg {
      width: 12px;
      height: 12px;
    }
body.page-etobicoke .quote-section .container {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 80px;
      align-items: start;
    }
body.page-etobicoke .quote-section__left h2 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(36px, 4.5vw, 60px);
      letter-spacing: -0.008em;
      line-height: 1.04;
      margin: 12px 0 22px;
      color: var(--navy-900);
      text-wrap: balance;
    }
body.page-etobicoke .quote-section__left p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.6;
      margin: 0 0 32px;
      max-width: 440px;
    }
body.page-etobicoke .quote-section__trust {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 32px;
      padding-top: 32px;
      border-top: 1px solid var(--line);
    }
body.page-etobicoke .quote-section__trust-item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-etobicoke .quote-section__trust-item svg {
      width: 20px;
      height: 20px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-etobicoke .quote-section .quote-form {
      max-width: none;
      margin-left: 0;
    }
@media (max-width: 1100px) {
body.page-etobicoke .plumbing-services-grid { grid-template-columns: repeat(2, 1fr); }
body.page-etobicoke .neighborhood-grid { grid-template-columns: repeat(3, 1fr); }

    
}
@media (max-width: 920px) {
body.page-etobicoke .plumbing-services-grid { grid-template-columns: 1fr; }
body.page-etobicoke .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
body.page-etobicoke .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
body.page-etobicoke .trust-item { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line-rev); }
body.page-etobicoke .trust-item:not(:first-child) { padding-left: 0; }
body.page-etobicoke .trust-item:nth-child(odd) { border-right: 1px solid var(--line-rev); padding-right: 24px; }
body.page-etobicoke .trust-item:nth-child(even) { padding-left: 24px; }
body.page-etobicoke .local-trust-grid { grid-template-columns: 1fr; gap: 40px; }
body.page-etobicoke .quote-section .container { grid-template-columns: 1fr; gap: 48px; }
body.page-etobicoke .quote-section__left p { max-width: none; }

    
}
@media (max-width: 600px) {
body.page-etobicoke .neighborhood-grid { grid-template-columns: 1fr; }

    
}

/* mississauga.html */
body.page-mississauga .plumbing-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
body.page-mississauga .plumbing-service-card {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
body.page-mississauga .plumbing-service-card:hover {
      border-color: var(--navy-900);
      box-shadow: var(--shadow-hover);
    }
body.page-mississauga .plumbing-service-card__icon {
      width: 36px;
      height: 36px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-mississauga .plumbing-service-card h3 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 22px;
      letter-spacing: -0.003em;
      line-height: 1.1;
      margin: 0;
      color: var(--navy-900);
    }
body.page-mississauga .plumbing-service-card p {
      font-size: 14px;
      color: var(--steel-700);
      line-height: 1.55;
      margin: 0;
    }
body.page-mississauga .trust-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line-rev);
      margin-top: 64px;
    }
body.page-mississauga .trust-item {
      padding: 40px 32px 32px 0;
      border-right: 1px solid var(--line-rev);
    }
body.page-mississauga .trust-item:last-child { border-right: none; padding-right: 0; }
body.page-mississauga .trust-item:not(:first-child) { padding-left: 32px; }
body.page-mississauga .trust-item__num {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(48px, 5vw, 72px);
      line-height: 0.96;
      letter-spacing: -0.02em;
      color: var(--paper);
      margin-bottom: 10px;
    }
body.page-mississauga .trust-item__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      color: var(--steel-300);
      text-transform: uppercase;
      display: block;
    }
body.page-mississauga .trust-item__sub {
      font-size: 14px;
      color: var(--steel-500);
      margin-top: 6px;
      line-height: 1.5;
    }
body.page-mississauga .neighborhood-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
    }
body.page-mississauga .neighborhood-tile {
      padding: 28px 26px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: background 0.2s ease;
    }
body.page-mississauga .neighborhood-tile:hover { background: var(--paper-2); }
body.page-mississauga .neighborhood-tile__name {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      letter-spacing: -0.003em;
      color: var(--navy-900);
      margin: 0;
    }
body.page-mississauga .neighborhood-tile__sub {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-mississauga .local-trust-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 72px;
      align-items: start;
    }
body.page-mississauga .local-trust-grid p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.65;
      margin: 0 0 18px;
    }
body.page-mississauga .local-trust-grid p:last-child { margin-bottom: 0; }
body.page-mississauga .local-creds {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
body.page-mississauga .local-creds__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0 0 6px;
    }
body.page-mississauga .local-creds__item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-mississauga .local-creds__item svg {
      width: 18px;
      height: 18px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-mississauga .area-strip { padding: 56px 0; background: var(--paper-2); border-top: 1px solid var(--line); }
body.page-mississauga .area-strip__inner {
      display: flex;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
    }
body.page-mississauga .area-strip__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-mississauga .area-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      list-style: none;
      padding: 0;
      margin: 0;
    }
body.page-mississauga .area-pills a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 18px;
      border: 1px solid var(--line);
      background: var(--paper);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--navy-900);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
    }
body.page-mississauga .area-pills a:hover {
      border-color: var(--navy-900);
      background: var(--paper);
    }
body.page-mississauga .area-pills a svg {
      width: 12px;
      height: 12px;
    }
body.page-mississauga .quote-section .container {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 80px;
      align-items: start;
    }
body.page-mississauga .quote-section__left h2 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(36px, 4.5vw, 60px);
      letter-spacing: -0.008em;
      line-height: 1.04;
      margin: 12px 0 22px;
      color: var(--navy-900);
      text-wrap: balance;
    }
body.page-mississauga .quote-section__left p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.6;
      margin: 0 0 32px;
      max-width: 440px;
    }
body.page-mississauga .quote-section__trust {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 32px;
      padding-top: 32px;
      border-top: 1px solid var(--line);
    }
body.page-mississauga .quote-section__trust-item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-mississauga .quote-section__trust-item svg {
      width: 20px;
      height: 20px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-mississauga .quote-section .quote-form {
      max-width: none;
      margin-left: 0;
    }
@media (max-width: 1100px) {
body.page-mississauga .plumbing-services-grid { grid-template-columns: repeat(2, 1fr); }
body.page-mississauga .neighborhood-grid { grid-template-columns: repeat(3, 1fr); }

    
}
@media (max-width: 920px) {
body.page-mississauga .plumbing-services-grid { grid-template-columns: 1fr; }
body.page-mississauga .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
body.page-mississauga .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
body.page-mississauga .trust-item { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line-rev); }
body.page-mississauga .trust-item:not(:first-child) { padding-left: 0; }
body.page-mississauga .trust-item:nth-child(odd) { border-right: 1px solid var(--line-rev); padding-right: 24px; }
body.page-mississauga .trust-item:nth-child(even) { padding-left: 24px; }
body.page-mississauga .local-trust-grid { grid-template-columns: 1fr; gap: 40px; }
body.page-mississauga .quote-section .container { grid-template-columns: 1fr; gap: 48px; }
body.page-mississauga .quote-section__left p { max-width: none; }

    
}
@media (max-width: 600px) {
body.page-mississauga .neighborhood-grid { grid-template-columns: 1fr; }

    
}

/* oakville.html */
body.page-oakville .plumbing-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
body.page-oakville .plumbing-service-card {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
body.page-oakville .plumbing-service-card:hover {
      border-color: var(--navy-900);
      box-shadow: var(--shadow-hover);
    }
body.page-oakville .plumbing-service-card__icon {
      width: 36px;
      height: 36px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-oakville .plumbing-service-card h3 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 22px;
      letter-spacing: -0.003em;
      line-height: 1.1;
      margin: 0;
      color: var(--navy-900);
    }
body.page-oakville .plumbing-service-card p {
      font-size: 14px;
      color: var(--steel-700);
      line-height: 1.55;
      margin: 0;
    }
body.page-oakville .trust-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line-rev);
      margin-top: 64px;
    }
body.page-oakville .trust-item {
      padding: 40px 32px 32px 0;
      border-right: 1px solid var(--line-rev);
    }
body.page-oakville .trust-item:last-child { border-right: none; padding-right: 0; }
body.page-oakville .trust-item:not(:first-child) { padding-left: 32px; }
body.page-oakville .trust-item__num {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(48px, 5vw, 72px);
      line-height: 0.96;
      letter-spacing: -0.02em;
      color: var(--paper);
      margin-bottom: 10px;
    }
body.page-oakville .trust-item__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      color: var(--steel-300);
      text-transform: uppercase;
      display: block;
    }
body.page-oakville .trust-item__sub {
      font-size: 14px;
      color: var(--steel-500);
      margin-top: 6px;
      line-height: 1.5;
    }
body.page-oakville .neighborhood-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
    }
body.page-oakville .neighborhood-tile {
      padding: 28px 26px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      background: var(--paper);
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: background 0.2s ease;
    }
body.page-oakville .neighborhood-tile:hover { background: var(--paper-2); }
body.page-oakville .neighborhood-tile__name {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      letter-spacing: -0.003em;
      color: var(--navy-900);
      margin: 0;
    }
body.page-oakville .neighborhood-tile__sub {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-oakville .local-trust-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 72px;
      align-items: start;
    }
body.page-oakville .local-trust-grid p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.65;
      margin: 0 0 18px;
    }
body.page-oakville .local-trust-grid p:last-child { margin-bottom: 0; }
body.page-oakville .local-creds {
      background: var(--paper);
      border: 1px solid var(--line);
      padding: 32px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
body.page-oakville .local-creds__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0 0 6px;
    }
body.page-oakville .local-creds__item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-oakville .local-creds__item svg {
      width: 18px;
      height: 18px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-oakville .area-strip { padding: 56px 0; background: var(--paper-2); border-top: 1px solid var(--line); }
body.page-oakville .area-strip__inner {
      display: flex;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
    }
body.page-oakville .area-strip__label {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--steel-500);
      margin: 0;
    }
body.page-oakville .area-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      list-style: none;
      padding: 0;
      margin: 0;
    }
body.page-oakville .area-pills a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 18px;
      border: 1px solid var(--line);
      background: var(--paper);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--navy-900);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
    }
body.page-oakville .area-pills a:hover {
      border-color: var(--navy-900);
      background: var(--paper);
    }
body.page-oakville .area-pills a svg {
      width: 12px;
      height: 12px;
    }
body.page-oakville .quote-section .container {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 80px;
      align-items: start;
    }
body.page-oakville .quote-section__left h2 {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(36px, 4.5vw, 60px);
      letter-spacing: -0.008em;
      line-height: 1.04;
      margin: 12px 0 22px;
      color: var(--navy-900);
      text-wrap: balance;
    }
body.page-oakville .quote-section__left p {
      font-size: 16px;
      color: var(--steel-700);
      line-height: 1.6;
      margin: 0 0 32px;
      max-width: 440px;
    }
body.page-oakville .quote-section__trust {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-top: 32px;
      padding-top: 32px;
      border-top: 1px solid var(--line);
    }
body.page-oakville .quote-section__trust-item {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 14px;
      color: var(--navy-900);
    }
body.page-oakville .quote-section__trust-item svg {
      width: 20px;
      height: 20px;
      color: var(--navy-900);
      flex-shrink: 0;
    }
body.page-oakville .quote-section .quote-form {
      max-width: none;
      margin-left: 0;
    }
@media (max-width: 1100px) {
body.page-oakville .plumbing-services-grid { grid-template-columns: repeat(2, 1fr); }
body.page-oakville .neighborhood-grid { grid-template-columns: repeat(3, 1fr); }

    
}
@media (max-width: 920px) {
body.page-oakville .plumbing-services-grid { grid-template-columns: 1fr; }
body.page-oakville .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
body.page-oakville .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
body.page-oakville .trust-item { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line-rev); }
body.page-oakville .trust-item:not(:first-child) { padding-left: 0; }
body.page-oakville .trust-item:nth-child(odd) { border-right: 1px solid var(--line-rev); padding-right: 24px; }
body.page-oakville .trust-item:nth-child(even) { padding-left: 24px; }
body.page-oakville .local-trust-grid { grid-template-columns: 1fr; gap: 40px; }
body.page-oakville .quote-section .container { grid-template-columns: 1fr; gap: 48px; }
body.page-oakville .quote-section__left p { max-width: none; }

    
}
@media (max-width: 600px) {
body.page-oakville .neighborhood-grid { grid-template-columns: 1fr; }

    
}
