/* =========================================================================
   /data-recovery/mississauga — local SEO city landing page motif
   Loads after page-data-recovery.css. Distinct from media-type siblings:
     · NO new accent color (uses parent /data-recovery/ red — the
       differentiation here is CONTENT not visual motif since this is
       a city page not a media page)
     · Skyline-silhouette hero (vs HDD platter / SSD chip / phone split / RAID rack)
     · 8-route directions grid (totally unique — no other page has this)
     · 4-card services-cross-sell grid (links back to media pages)
     · 6-block "why us" reasoning grid (different layout from other pages)
     · 4-column neighborhoods directory (totally unique)
     · CTA with map-card layout (mirrors phone CTA pattern intentionally
       to keep the "local feel" consistent across consumer-facing pages)
   ========================================================================= */

:root {
  /* Re-using parent --accent (red) but with a few local-specific tints */
  --city-accent:        var(--accent, #E5322D);
  --city-accent-deep:   #b8231e;
  --city-accent-tint:   rgba(229, 50, 45, 0.08);
  --city-paper:         #ffffff;
  --city-bg:            #f7f5f2;          /* warm off-white — friendly local feel */
  --city-bg-alt:        #faf8f4;
  --city-ink:           #131217;
  --city-line:          rgba(19, 18, 23, 0.10);
  --city-line-strong:   rgba(19, 18, 23, 0.22);
}

/* ---- Hero (cartographic motif on right — matches sibling pattern) -- */

.city-hero {
  position: relative;
  min-height: 92vh;
  padding: 130px 32px 100px;
  background: var(--city-bg);
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* Topographic / contour-line texture in the background — gives the
   page a "map paper" feel without being literal. Layers two repeating
   gradients at offset angles to suggest topographic elevation lines. */
.city-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 78% 50%, rgba(229, 50, 45, 0.10), transparent 55%),
    repeating-linear-gradient(105deg, transparent 0 22px, rgba(19,18,23,0.020) 22px 23px),
    repeating-linear-gradient(15deg,  transparent 0 36px, rgba(19,18,23,0.015) 36px 37px);
  pointer-events: none;
}

/* Faint warm-paper grain layer (additional texture, very subtle) */
.city-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 30% 100%, rgba(180, 140, 90, 0.06), transparent 50%),
    radial-gradient(ellipse at 0% 0%,    rgba(180, 140, 90, 0.04), transparent 60%);
  pointer-events: none;
}

.city-hero .hero-grid { opacity: 0.18; }

/* The map motif — right-aligned to match HDD/SSD/Phone/RAID hero pattern */
.city-map-stage {
  position: absolute;
  right: -80px;
  top: 50%;
  transform: translateY(-50%);
  width: min(85vh, 720px);
  height: min(85vh, 720px);
  pointer-events: none;
  color: var(--city-ink);
  z-index: 1;
}
.city-map {
  width: 100%;
  height: 100%;
  display: block;
}

/* Pulsing distance ring — animates outward from the target marker */
.city-rings circle:first-child {
  animation: city-ring-pulse 3.4s ease-out infinite;
  transform-origin: 300px 300px;
}
@keyframes city-ring-pulse {
  0%   { transform: scale(0.5); opacity: 0; }
  20%  { opacity: 0.85; }
  100% { transform: scale(2.6); opacity: 0; }
}

/* Crosshair marker — gentle breathing pulse */
.city-target circle:nth-child(1) {
  animation: city-target-breath 3s ease-in-out infinite;
  transform-origin: 300px 300px;
}
@keyframes city-target-breath {
  0%, 100% { transform: scale(1);    opacity: 0.10; }
  50%      { transform: scale(1.25); opacity: 0.25; }
}

@media (prefers-reduced-motion: reduce) {
  .city-rings circle:first-child,
  .city-target circle:nth-child(1) { animation: none; }
}

.city-meta {
  position: relative;
  z-index: 4;
  color: var(--city-ink);
}

.city-hero-content {
  position: relative;
  z-index: 5;
  max-width: 620px;
}

.city-hero-headline {
  font-family: var(--display-font);
  font-weight: 600;
  font-size: clamp(56px, 9vw, 132px);
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--city-ink);
  margin: 0 0 32px;
}
.city-hero-headline em {
  font-style: italic;
  font-family: var(--serif-font, 'Instrument Serif'), serif;
  font-weight: 400;
  color: var(--city-accent);
  display: inline-block;
}

.city-hero-sub {
  font-size: clamp(17px, 1.4vw, 21px);
  color: var(--ink-dim);
  max-width: 620px;
  line-height: 1.6;
  margin: 0 0 36px;
}

.city-hero-ctas {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.city-cta-primary,
.city-cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  border-radius: 100px;
  font-family: var(--display-font);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: all .25s ease;
  cursor: pointer;
}
.city-cta-primary {
  background: var(--city-accent);
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(229, 50, 45, 0.30);
}
.city-cta-primary:hover {
  background: var(--city-accent-deep);
  transform: translateY(-2px);
  box-shadow: 0 20px 40px rgba(229, 50, 45, 0.35);
}
.city-cta-secondary {
  background: transparent;
  color: var(--city-ink) !important;
  border: 1.5px solid var(--city-ink);
}
.city-cta-secondary:hover {
  background: var(--city-ink);
  color: #fff !important;
}

/* Hero stats row — 4 quick metrics under the CTAs (matches the
   meta-pill rhythm of the HDD page hero but with bigger numbers) */
.city-hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--city-line);
  padding-top: 24px;
  margin-top: 4px;
}

.city-stat {
  padding-right: 18px;
  border-right: 1px solid var(--city-line);
}
.city-stat:last-child {
  border-right: none;
  padding-right: 0;
}

.city-stat-num {
  font-family: var(--display-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--city-accent);
  line-height: 1;
  letter-spacing: -0.025em;
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 6px;
}
.city-stat-num span {
  font-family: var(--mono-font);
  font-size: 11px;
  font-weight: 500;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.city-stat-key {
  font-family: var(--mono-font);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  line-height: 1.3;
}

/* ---- Directions section --------------------------------------------- */

.city-directions {
  padding: 140px 32px;
  background: var(--city-paper);
  border-top: 1px solid var(--line);
  position: relative;
}

.city-directions-inner,
.city-services-inner,
.city-why-inner,
.city-areas-inner,
.city-quote-inner,
.city-faq-inner,
.city-cta-inner {
  max-width: 1240px;
  margin: 0 auto;
}

.city-directions-title,
.city-services-title,
.city-why-title,
.city-areas-title,
.city-quote-title,
.city-faq-title,
.city-cta h2 {
  font-family: var(--display-font);
  font-weight: 600;
  font-size: clamp(38px, 5.4vw, 68px);
  line-height: 1.04;
  letter-spacing: -0.028em;
  color: var(--ink);
  margin: 0 0 22px;
  max-width: 880px;
}
.city-directions-title em,
.city-services-title em,
.city-why-title em,
.city-areas-title em,
.city-quote-title em,
.city-faq-title em,
.city-cta h2 em {
  font-style: italic;
  font-family: var(--serif-font, 'Instrument Serif'), serif;
  font-weight: 400;
  color: var(--city-accent);
}

.city-directions-lede,
.city-services-lede,
.city-areas-lede,
.city-quote-lede {
  font-size: 17px;
  color: var(--ink-dim);
  max-width: 720px;
  line-height: 1.65;
  margin: 0 0 56px;
}

.city-routes {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 32px;
}

.city-route {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 16px;
  padding: 22px 26px;
  background: var(--city-bg);
  border: 1px solid var(--city-line);
  border-radius: 12px;
  border-left: 3px solid var(--city-accent);
  transition: border-color .3s ease, transform .3s ease, background .3s ease;
}
.city-route:hover {
  background: var(--city-bg-alt);
  border-color: var(--city-accent);
  transform: translateX(4px);
}

.city-route-from {
  font-family: var(--display-font);
  font-size: 16px;
  color: var(--ink);
  letter-spacing: -0.012em;
  font-weight: 500;
}
.city-route-from strong {
  color: var(--city-accent);
  font-weight: 600;
}

.city-route-time {
  font-family: var(--mono-font);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  font-weight: 600;
  text-align: right;
  white-space: nowrap;
}

.city-route-detail {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-dim);
  grid-column: 1 / -1;
}

.city-directions-note {
  font-size: 14px;
  color: var(--ink-dim);
  font-style: italic;
  text-align: center;
  background: var(--city-bg);
  padding: 18px 24px;
  border-radius: 10px;
  border: 1px dashed var(--city-line-strong);
  margin: 0;
}
.city-directions-note strong { color: var(--ink); font-weight: 600; }

/* ---- Services cross-sell grid --------------------------------------- */

.city-services {
  padding: 140px 32px;
  background: var(--city-bg);
  border-top: 1px solid var(--line);
}

.city-services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.city-service-card {
  display: block;
  padding: 32px 32px 28px;
  background: var(--city-paper);
  border: 1px solid var(--city-line-strong);
  border-radius: 16px;
  transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease;
  position: relative;
  overflow: hidden;
}
.city-service-card::after {
  content: '→';
  position: absolute;
  right: 28px;
  top: 28px;
  font-size: 20px;
  color: var(--city-accent);
  opacity: 0;
  transition: opacity .25s ease, transform .3s ease;
}
.city-service-card:hover {
  transform: translateY(-4px);
  border-color: var(--city-accent);
  box-shadow: 0 24px 48px rgba(19, 18, 23, 0.07);
}
.city-service-card:hover::after {
  opacity: 1;
  transform: translateX(6px);
}

.city-service-tag {
  font-family: var(--mono-font);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--city-accent);
  margin-bottom: 14px;
  font-weight: 600;
}

.city-service-card h3 {
  font-family: var(--display-font);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 0 0 12px;
  line-height: 1.25;
}

.city-service-card p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-dim);
  margin: 0 0 16px;
}

.city-service-meta {
  font-family: var(--mono-font);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  border-top: 1px dashed var(--city-line-strong);
  padding-top: 12px;
}

/* ---- "Why us" 6-block grid ------------------------------------------ */

.city-why {
  padding: 140px 32px;
  background: var(--city-paper);
  border-top: 1px solid var(--line);
}

.city-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 56px;
}

.city-why-block {
  padding: 28px 30px 26px;
  background: var(--city-bg);
  border: 1px solid var(--city-line);
  border-radius: 14px;
  transition: border-color .3s ease, transform .3s ease;
}
.city-why-block:hover {
  border-color: var(--city-accent);
  transform: translateY(-3px);
}

.city-why-num {
  font-family: var(--mono-font);
  font-size: 28px;
  font-weight: 700;
  color: var(--city-accent);
  line-height: 1;
  margin-bottom: 14px;
  letter-spacing: -0.02em;
}

.city-why-block h3 {
  font-family: var(--display-font);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.014em;
  color: var(--ink);
  margin: 0 0 12px;
  line-height: 1.3;
}

.city-why-block p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-dim);
  margin: 0;
}

/* ---- Neighborhoods directory ---------------------------------------- */

.city-areas {
  padding: 140px 32px;
  background: var(--city-bg);
  border-top: 1px solid var(--line);
}

.city-areas-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-bottom: 48px;
}

.city-area-block {
  padding: 26px 26px 24px;
  background: var(--city-paper);
  border: 1px solid var(--city-line);
  border-radius: 12px;
}

.city-area-block h4 {
  font-family: var(--display-font);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.012em;
  color: var(--city-accent);
  margin: 0 0 14px;
  position: relative;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--city-line-strong);
}

.city-area-block ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.city-area-block li {
  font-size: 14px;
  color: var(--ink-dim);
  padding-left: 14px;
  position: relative;
  line-height: 1.5;
}
.city-area-block li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--city-accent);
  opacity: 0.6;
}

/* Broader-area pills */
.city-areas-broader {
  text-align: center;
  padding: 28px 32px;
  background: var(--city-paper);
  border: 1px solid var(--city-line);
  border-radius: 14px;
}

.city-broader-title {
  font-family: var(--mono-font);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 16px;
}

.city-broader-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.city-broader-list span {
  display: inline-block;
  padding: 6px 14px;
  background: var(--city-bg);
  border: 1px solid var(--city-line);
  border-radius: 100px;
  font-size: 13px;
  font-family: var(--display-font);
  color: var(--ink);
  font-weight: 500;
  transition: border-color .2s ease, color .2s ease;
}
.city-broader-list span:hover {
  border-color: var(--city-accent);
  color: var(--city-accent);
}

/* ---- Quote builder section ------------------------------------------ */

.city-quote {
  padding: 140px 32px 120px;
  background: var(--city-paper);
  border-top: 1px solid var(--line);
}

.city-quote .drb-shell {
  background: var(--city-bg);
  border-color: var(--city-line-strong);
}

/* ---- FAQ -------------------------------------------------------------- */

.city-faq {
  padding: 140px 32px;
  background: var(--city-bg);
  border-top: 1px solid var(--line);
}

.city-faq-list {
  margin-top: 56px;
  border-top: 1px solid var(--city-line);
}

.city-faq-item {
  border-bottom: 1px solid var(--city-line);
}

.city-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 26px 60px 26px 0;
  font-family: var(--display-font);
  font-size: 19px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.012em;
  position: relative;
  transition: color .2s ease;
}
.city-faq-item summary::-webkit-details-marker { display: none; }
.city-faq-item summary::after {
  content: '';
  position: absolute;
  right: 8px;
  top: 50%;
  width: 12px;
  height: 12px;
  border-right: 2px solid var(--city-accent);
  border-bottom: 2px solid var(--city-accent);
  transform: translateY(-65%) rotate(45deg);
  transition: transform .25s ease;
}
.city-faq-item[open] summary::after {
  transform: translateY(-30%) rotate(225deg);
}
.city-faq-item summary:hover { color: var(--city-accent); }

.city-faq-item p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-dim);
  padding: 0 60px 26px 0;
  margin: 0;
}

/* ---- CTA — split with map card -------------------------------------- */

.city-cta {
  padding: 140px 32px;
  background: var(--city-paper);
  border-top: 1px solid var(--line);
}

.city-cta-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: stretch;
}

.city-cta-text h2 { margin-bottom: 22px; }

.city-cta-sub {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-dim);
  max-width: 560px;
  margin: 0 0 28px;
}

.city-cta-buttons {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.city-cta-card {
  background: var(--city-ink);
  color: #fff;
  border-radius: 18px;
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
}
.city-cta-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 90% 10%, rgba(229, 50, 45, 0.22), transparent 55%);
  pointer-events: none;
}

.city-cta-card-tag {
  font-family: var(--mono-font);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--city-accent);
  font-weight: 700;
  margin-bottom: 14px;
  position: relative;
  z-index: 1;
}

.city-cta-card h3 {
  font-family: var(--display-font);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: #fff;
  margin: 0 0 18px;
  line-height: 1.35;
  position: relative;
  z-index: 1;
}

.city-cta-addr {
  font-family: var(--mono-font);
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 22px;
  position: relative;
  z-index: 1;
}

.city-cta-card-list {
  list-style: none;
  margin: 0 0 22px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  z-index: 1;
}
.city-cta-card-list li {
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.78);
  padding-left: 14px;
  position: relative;
  line-height: 1.5;
}
.city-cta-card-list li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--city-accent);
  font-weight: 700;
}
.city-cta-card-list b { color: #fff; font-weight: 600; }

.city-cta-map-link {
  display: inline-block;
  font-family: var(--display-font);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--city-accent) !important;
  border-bottom: 1px solid var(--city-accent);
  padding-bottom: 2px;
  position: relative;
  z-index: 1;
  transition: color .2s ease;
}
.city-cta-map-link:hover { color: #fff !important; border-color: #fff; }

/* ---- Section eyebrow uses parent red — no override needed ---------- */

/* ---- Responsive ------------------------------------------------------- */

@media (max-width: 1100px) {
  .city-map-stage { width: 52vw; opacity: 0.32; right: -22%; }
  .city-hero-content { max-width: 540px; }
  .city-routes { grid-template-columns: 1fr; }
  .city-services-grid { grid-template-columns: 1fr; }
  .city-why-grid { grid-template-columns: repeat(2, 1fr); }
  .city-areas-grid { grid-template-columns: repeat(2, 1fr); }
  .city-cta-grid { grid-template-columns: 1fr; }
  .city-hero-stats { grid-template-columns: repeat(2, 1fr); gap: 14px 0; }
  .city-stat:nth-child(2) { border-right: none; padding-right: 0; }
}

@media (max-width: 820px) {
  .city-hero {
    padding: 110px 20px 60px;
    min-height: auto;
    flex-direction: column;
    align-items: stretch;
  }
  .city-hero-headline { font-size: clamp(40px, 10vw, 64px); margin-bottom: 20px; }
  .city-hero-sub { font-size: 16px; margin-bottom: 28px; }
  .city-meta { font-size: 9px !important; letter-spacing: 0.10em !important; }
  .city-map-stage {
    position: relative;
    right: auto; top: auto; transform: none;
    width: 80vw;
    height: 80vw;
    max-width: 360px;
    max-height: 360px;
    margin: 32px auto 0;
    opacity: 0.8;
    order: 99;
  }
  .city-directions, .city-services, .city-why,
  .city-areas, .city-quote, .city-faq, .city-cta { padding: 80px 20px; }
  .city-why-grid { grid-template-columns: 1fr; }
  .city-areas-grid { grid-template-columns: 1fr; }
  .city-route { grid-template-columns: 1fr; }
  .city-route-time { text-align: left; }
  .city-cta-buttons { flex-direction: column; align-items: stretch; }
  .city-cta-buttons a { justify-content: center; }
  .city-stat-num { font-size: 26px; }
}

@media (max-width: 540px) {
  .city-hero-ctas { flex-direction: column; align-items: stretch; }
  .city-hero-ctas a { justify-content: center; }
  .city-hero-stats { grid-template-columns: 1fr; gap: 12px; }
  .city-stat { border-right: none !important; border-bottom: 1px dashed var(--city-line); padding: 0 0 12px 0; }
  .city-stat:last-child { border-bottom: none; padding-bottom: 0; }
}
