/* =========================================================
Pagina Rank 2 - Provincia di Novara
CSS dedicato, da caricare dopo /css/style.css
========================================================= */

.service-page {
  background: var(--paper);
}

.area-rank2-page {
  overflow: hidden;
}

.area-rank2-page .service-section,
.area-rank2-breadcrumb {
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}

.area-rank2-page .service-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}

.area-rank2-page .section-heading {
  padding-top: 28px;
  border-top: 1px solid var(--line-strong);
}

.area-rank2-page .section-heading::before,
.area-rank2-presence-copy::before,
.area-rank2-cities-heading::before,
.area-rank2-services-heading::before,
.evaluation-copy::before {
  content: "";
  display: block;
  width: 88px;
  height: 3px;
  margin-bottom: 26px;
  background: var(--accent);
}

.area-rank2-page a:not(.hero-buttons a):not(.site-nav a):not(.footer a):not(.contatti-azioni a) {
  color: var(--accent);
  font-weight: 850;
  transition: color var(--speed), transform var(--speed), border-color var(--speed);
}

.area-rank2-page a:not(.hero-buttons a):not(.site-nav a):not(.footer a):not(.contatti-azioni a):hover {
  color: var(--accent-dark);
}

/* =========================================================
Hero
========================================================= */

.area-rank2-hero {
  min-height: 88svh;
  background:
    radial-gradient(circle at 50% 30%, rgba(184, 121, 69, 0.24), transparent 34rem),
    linear-gradient(180deg, rgba(8, 13, 18, 0.22), rgba(8, 13, 18, 0.50)),
    url("../img/brochure.png") center center / cover no-repeat;
}

.area-rank2-hero h1 {
  max-width: 980px;
}

.area-rank2-hero .hero-content p:not(.eyebrow) {
  max-width: 800px;
}

/* =========================================================
Breadcrumb
========================================================= */

.area-rank2-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding-top: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
  background: var(--paper-light);
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 750;
}

.area-rank2-breadcrumb a {
  color: var(--ink-soft);
}

.area-rank2-breadcrumb strong {
  color: var(--accent-dark);
}

/* =========================================================
Introduzione locale
========================================================= */

.area-rank2-intro {
  background: linear-gradient(180deg, var(--paper-light), var(--paper));
}

.area-rank2-intro-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(380px, 1fr);
  gap: clamp(42px, 6vw, 86px);
  align-items: start;
}

.area-rank2-intro-copy {
  padding-top: 28px;
  border-top: 1px solid var(--line-strong);
}

.area-rank2-intro-copy p {
  max-width: 760px;
}
.area-rank2-intro-heading {
  display: flex;
  flex-direction: column;
}

.area-rank2-intro-image {
  position: relative;
  overflow: hidden;
  margin-top: clamp(34px, 5vw, 58px);
  padding-top: 28px;
  border-top: 1px solid var(--line-strong);
  border-radius: var(--radius-image) var(--radius-image) 90px var(--radius-image);
}

.area-rank2-intro-image::before {
  content: "";
  display: block;
  width: 88px;
  height: 3px;
  margin-bottom: 26px;
  background: var(--accent);
}

.area-rank2-intro-image::after {
  content: "";
  position: absolute;
  inset: calc(28px + 18px) 18px 18px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 22px;
  pointer-events: none;
}

.area-rank2-intro-image img {
  width: 100%;
  height: clamp(320px, 34vw, 480px);
  display: block;
  object-fit: cover;
  box-shadow: var(--shadow-image);
}
/* =========================================================
Presenza reale
========================================================= */

.area-rank2-presence {
  position: relative;
  background: var(--paper);
}

.area-rank2-presence::before {
  content: "";
  position: absolute;
  left: var(--pad-x);
  right: var(--pad-x);
  top: var(--section-y);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
}

.area-rank2-presence-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 0.58fr);
  gap: clamp(38px, 5vw, 84px);
  align-items: start;
}

.area-rank2-presence-copy {
  position: relative;
  padding-top: clamp(18px, 2.4vw, 30px);
  border-top: 1px solid var(--line-strong);
}

.area-rank2-presence-copy::before {
  content: "";
  display: block;
  width: 88px;
  height: 3px;
  margin-bottom: 26px;
  background: var(--accent);
}

.area-rank2-presence-copy h2 {
  max-width: 860px;
}

.area-rank2-presence-copy p {
  max-width: 820px;
}

.area-rank2-proof-panel {
  position: relative;
  padding: clamp(26px, 3vw, 38px) 0;
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  background: transparent;
  box-shadow: none;
}

.area-rank2-proof-panel > span {
  display: inline-flex;
  margin-bottom: 26px;
  color: var(--accent-dark);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.area-rank2-proof-step {
  position: relative;
  padding: 24px 0;
  border-top: 1px solid var(--line);
}

.area-rank2-proof-step:first-of-type {
  border-top: 0;
  padding-top: 0;
}

.area-rank2-proof-step strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-family: var(--font-title);
  font-size: clamp(1.28rem, 1.8vw, 1.62rem);
  line-height: 1.08;
  letter-spacing: -0.035em;
}

.area-rank2-proof-step p {
  max-width: 420px;
  font-size: 0.96rem;
  line-height: 1.58;
}

@media (max-width: 980px) {
  .area-rank2-presence-inner {
    grid-template-columns: 1fr;
  }
}
/* =========================================================
Città Rank 3
========================================================= */

.area-rank2-cities {
  background: linear-gradient(180deg, var(--paper), #fbf8f3);
}

.area-rank2-cities-heading {
  max-width: 920px;
  margin-bottom: clamp(48px, 6vw, 86px);
  padding-top: 28px;
  border-top: 1px solid var(--line-strong);
}

.area-rank2-cities-heading p:not(.eyebrow) {
  max-width: 720px;
}

.area-rank2-city-feature {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1.08fr);
  gap: clamp(34px, 5vw, 76px);
  align-items: stretch;
  margin-bottom: clamp(46px, 6vw, 80px);
}

.city-feature-copy {
  display: flex;
  min-width: 0;
  flex-direction: column;
  justify-content: center;
  padding: clamp(26px, 3vw, 38px) 0;
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line);
}

.city-feature-copy .city-number {
  margin-bottom: 22px;
}

.city-feature-copy h3 {
  font-size: clamp(2.1rem, 4vw, 3.7rem);
}

.city-feature-copy a,
.city-row a,
.area-service-item a {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-top: 18px;
}

.city-feature-copy a::after,
.city-row a::after,
.area-service-item a::after {
  content: "→";
  margin-left: 9px;
  transition: transform var(--speed);
}

.city-feature-copy a:hover::after,
.city-row a:hover::after,
.area-service-item a:hover::after {
  transform: translateX(5px);
}

.city-feature-image {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  border-radius: var(--radius-image) 110px var(--radius-image) var(--radius-image);
  box-shadow: var(--shadow-image);
}

.city-feature-image::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 22px;
  pointer-events: none;
}

.city-feature-image img {
  height: 100%;
  min-height: 430px;
  object-fit: cover;
}

.area-rank2-city-rows {
  display: grid;
  border-top: 1px solid var(--line-strong);
}

.city-row {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  gap: clamp(18px, 3vw, 42px);
  align-items: center;
  padding: clamp(28px, 4vw, 42px) 0;
  border-bottom: 1px solid var(--line);
}

.city-row h3 {
  margin-bottom: 8px;
}

.city-row p {
  max-width: 720px;
  margin: 0;
}

.city-row a {
  white-space: nowrap;
}

/* =========================================================
   8. IMMAGINE AMPIA EDITORIALE
========================================================= */

.area-rank2-wide-image {
  position: relative;
  min-height: clamp(520px, 62vw, 760px);
  display: flex;
  align-items: center;
  overflow: hidden;
  color: var(--white);
  isolation: isolate;
}

.area-rank2-wide-image img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.area-rank2-wide-image::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(8, 13, 18, 0.82), rgba(8, 13, 18, 0.42), rgba(8, 13, 18, 0.18)),
    radial-gradient(circle at 24% 50%, rgba(184, 121, 69, 0.24), transparent 34rem);
}

.area-rank2-wide-panel {
  position: relative;
  z-index: 3;
  width: min(860px, calc(100% - 44px));
  margin-left: var(--pad-x);
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.area-rank2-wide-panel .eyebrow {
  color: var(--accent-soft);
}

.area-rank2-wide-panel h2 {
  max-width: 840px;
  margin-bottom: clamp(22px, 3vw, 34px);
  color: var(--white);
}

.area-rank2-wide-panel p {
  max-width: 780px;
  color: rgba(255, 255, 255, 0.80);
}

.area-rank2-wide-panel p + p {
  margin-top: 18px;
}

@media (max-width: 720px) {
  .area-rank2-wide-image {
    min-height: 560px;
    align-items: center;
  }

  .area-rank2-wide-panel {
    width: calc(100% - 36px);
    margin-left: 18px;
    margin-right: 18px;
  }
}

/* =========================================================
9. Prima valutazione / aree senza pagina dedicata
========================================================= */

.area-rank2-evaluation {
  background: linear-gradient(180deg, var(--paper-light), var(--paper));
}

.area-rank2-evaluation-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(330px, 0.72fr);
  column-gap: clamp(42px, 6vw, 86px);
  row-gap: clamp(18px, 2.8vw, 34px);
  align-items: center;
}

.evaluation-copy {
  position: relative;
  padding-top: 28px;
  border-top: 1px solid var(--line-strong);
}

.evaluation-copy::before {
  content: "";
  display: block;
  width: 88px;
  height: 3px;
  margin-bottom: 26px;
  background: var(--accent);
}

.evaluation-copy a {
  color: var(--accent-dark);
  font-weight: 800;
  border-bottom: 1px solid rgba(184, 121, 69, 0.36);
}

.evaluation-copy a:hover {
  color: var(--accent);
  border-color: currentColor;
}

.evaluation-image {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-image) var(--radius-image) var(--radius-image) 110px;
  box-shadow: var(--shadow-image);
}

.evaluation-image::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 22px;
  pointer-events: none;
}

.evaluation-image img {
  display: block;
  width: 100%;
  height: clamp(380px, 38vw, 560px);
  object-fit: cover;
  transition: transform var(--speed-slow), filter var(--speed-slow);
}

.evaluation-image:hover img {
  transform: scale(1.04);
  filter: saturate(1.05) contrast(1.03);
}

.area-rank2-evaluation-full {
  grid-column: 1 / -1;
  padding-top: clamp(18px, 2.6vw, 28px);
  border-top: 1px solid var(--line);
}

.area-rank2-evaluation-full p {
  max-width: 980px;
}

.area-rank2-evaluation-full p + p {
  margin-top: 16px;
}

.area-rank2-evaluation-full.scroll-reveal,
.area-rank2-evaluation-full.scroll-reveal-text {
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
  will-change: auto !important;
}

@media (max-width: 980px) {
  .area-rank2-evaluation-inner {
    grid-template-columns: 1fr;
  }

  .evaluation-image {
    border-radius: var(--radius-image);
  }

  .evaluation-image img {
    height: 360px;
  }
}

@media (max-width: 520px) {
  .evaluation-image img {
    height: 290px;
  }
}
/* =========================================================
   10. SERVIZI DISPONIBILI NELLA ZONA
========================================================= */

.area-rank2-services {
  background: linear-gradient(180deg, var(--paper), var(--paper-light));
}

.area-rank2-services-head,
.area-rank2-services .area-rank2-section-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.58fr);
  grid-template-areas:
    "eyebrow testo"
    "titolo testo";
  column-gap: clamp(38px, 5vw, 76px);
  row-gap: 14px;
  align-items: end;
  padding-top: clamp(28px, 3vw, 40px);
  margin-bottom: clamp(34px, 4vw, 52px);
  border-top: 1px solid var(--line-strong);
}

.area-rank2-services-head .eyebrow,
.area-rank2-services .area-rank2-section-head .eyebrow {
  grid-area: eyebrow;
  margin-bottom: 0;
}

.area-rank2-services-head h2,
.area-rank2-services .area-rank2-section-head h2 {
  grid-area: titolo;
  max-width: 820px;
  margin: 0;
}

.area-rank2-services-head p:not(.eyebrow),
.area-rank2-services .area-rank2-section-head p:not(.eyebrow) {
  grid-area: testo;
  justify-self: end;
  align-self: end;
  max-width: 520px;
  margin: 0;
  padding-top: 26px;
  border-top: 1px solid var(--line-strong);
}

@media (max-width: 980px) {
  .area-rank2-services-head,
  .area-rank2-services .area-rank2-section-head {
    grid-template-columns: 1fr;
    grid-template-areas:
      "eyebrow"
      "titolo"
      "testo";
  }

  .area-rank2-services-head p:not(.eyebrow),
  .area-rank2-services .area-rank2-section-head p:not(.eyebrow) {
    justify-self: start;
    max-width: 720px;
  }
}

.area-rank2-services-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 clamp(42px, 5vw, 78px);
  border-top: 1px solid var(--line-strong);
}

.area-service-item {
  position: relative;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  column-gap: clamp(18px, 2.4vw, 28px);
  align-items: start;
  min-height: 0;
  padding: clamp(30px, 4vw, 44px) 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
  transition: border-color var(--speed);
}

.area-service-item::before,
.area-service-item::after {
  content: none;
}

.area-service-item > span {
  grid-column: 1;
  grid-row: 1 / span 3;
  display: inline-flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding-top: 5px;
  color: var(--accent-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.14em;
}

.area-service-item h3 {
  grid-column: 2;
  grid-row: 1;
  max-width: 460px;
  margin: 0 0 12px;
  color: var(--ink);
  font-size: clamp(1.34rem, 2vw, 1.82rem);
  line-height: 1.04;
}

.area-service-item p {
  grid-column: 2;
  grid-row: 2;
  max-width: 560px;
  margin: 0;
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.58;
}

.area-service-item a {
  grid-column: 2;
  grid-row: 3;
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-top: 22px;
  padding: 0;
  color: var(--accent-dark);
  font-size: 0.94rem;
  font-weight: 850;
  transition: color var(--speed), transform var(--speed);
}

.area-service-item a::after {
  content: "→";
  margin-left: 9px;
  transition: transform var(--speed);
}

.area-service-item:hover {
  border-color: var(--line-strong);
}

.area-service-item:hover a {
  color: var(--accent);
  transform: translateX(3px);
}

.area-service-item:hover a::after {
  transform: translateX(5px);
}

.area-rank2-services .scroll-reveal,
.area-rank2-services .scroll-reveal-text {
  filter: none !important;
}

@media (max-width: 720px) {
  .area-rank2-services-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .area-service-item {
    grid-template-columns: 46px minmax(0, 1fr);
    min-height: 0;
    padding: 28px 0;
    border-radius: 0;
    background: transparent;
  }

  .area-service-item:hover {
    transform: none;
  }
}


/* =========================================================
Contatti
========================================================= */

.area-rank2-contact,
.area-rank2-contact.contatti {
  background: var(--paper-light);
}

.area-rank2-contact .contatti-testo h2 {
  max-width: 760px;
}

.area-rank2-contact .contatti-testo p:not(.eyebrow) {
  max-width: 760px;
}

/* Titoli "Servizi" e "Aree collegate" come Pavia */
.area-rank2-contact .contatti-sidebar h3,
.area-rank2-contact .contatti-sidebar-blocco h3 {
  margin-bottom: 14px;
  color: var(--ink);
  font-family: var(--font-title);
  font-size: clamp(1.45rem, 2.1vw, 1.95rem);
  font-weight: 720;
  line-height: 1.05;
  letter-spacing: -0.04em;
}

/* Liste sidebar come Pavia */
.area-rank2-contact .contatti-sidebar ul,
.area-rank2-contact .contatti-sidebar-blocco ul {
  display: grid;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--line);
  list-style: none;
}

.area-rank2-contact .contatti-sidebar li,
.area-rank2-contact .contatti-sidebar-blocco li {
  margin: 0;
  padding: 0;
  border-bottom: 1px solid var(--line);
}

/* Link "Servizi" e "Aree collegate" come Pavia */
.area-rank2-contact .contatti-sidebar a,
.area-rank2-contact .contatti-sidebar-blocco a,
.area-rank2-page .area-rank2-contact .contatti-sidebar a,
.area-rank2-page .area-rank2-contact .contatti-sidebar-blocco a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  padding: 12px 0;
  color: var(--ink-soft) !important;
  font-family: var(--font-body);
  font-size: 0.94rem;
  font-weight: 600 !important;
  line-height: 1.25;
  letter-spacing: 0;
  text-transform: none;
  text-decoration: none;
  transition: color var(--speed), padding-left var(--speed);
}

.area-rank2-contact .contatti-sidebar a::after,
.area-rank2-contact .contatti-sidebar-blocco a::after {
  content: "→";
  color: var(--accent);
  font-family: var(--font-body);
  font-size: 0.94rem;
  font-weight: 800;
  transition: transform var(--speed);
}

.area-rank2-contact .contatti-sidebar a:hover,
.area-rank2-contact .contatti-sidebar-blocco a:hover,
.area-rank2-page .area-rank2-contact .contatti-sidebar a:hover,
.area-rank2-page .area-rank2-contact .contatti-sidebar-blocco a:hover {
  color: var(--ink) !important;
  padding-left: 8px;
  transform: none;
}

.area-rank2-contact .contatti-sidebar a:hover::after,
.area-rank2-contact .contatti-sidebar-blocco a:hover::after {
  transform: translateX(6px);
}

@media (max-width: 980px) {
  .area-rank2-contact .contatti-sidebar {
    border-left: 0;
    border-top: 1px solid var(--line-strong);
  }
}
/* =========================================================
Responsive
========================================================= */

@media (max-width: 980px) {
  .area-rank2-intro-inner,
  .area-rank2-presence-inner,
  .area-rank2-city-feature,
  .area-rank2-evaluation-inner,
  .area-rank2-nearby-inner,
  .area-rank2-faq-inner {
    grid-template-columns: 1fr;
  }

  .city-feature-image,
  .evaluation-image {
    min-height: 360px;
  }

  .city-row {
    grid-template-columns: 58px minmax(0, 1fr);
  }

  .city-row a {
    grid-column: 2;
    white-space: normal;
  }

  .area-rank2-services-grid {
    grid-template-columns: 1fr;
  }

  .area-service-item,
  .area-service-item:nth-child(even) {
    padding-left: 0;
    padding-right: 0;
  }

  .area-service-item:nth-child(odd) {
    border-right: 0;
  }
}

@media (max-width: 640px) {
  .area-rank2-breadcrumb {
    font-size: 0.8rem;
  }

  .area-rank2-hero {
    min-height: 82svh;
  }

  .area-rank2-editorial-panel {
    padding: 26px 22px;
    border-radius: 22px;
  }

  .city-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .city-row a {
    grid-column: auto;
  }

  .presence-point {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .city-feature-image,
  .evaluation-image {
    border-radius: 24px;
  }
}
/* =========================================================
FIX SEZIONE CITTÀ RANK 3 - STILE PAVIA
========================================================= */

.area-rank2-cities {
  background:
    radial-gradient(circle at 86% 10%, rgba(184, 121, 69, 0.09), transparent 34rem),
    linear-gradient(180deg, var(--paper), #fbf8f3);
}

.area-rank2-city-feature {
  display: grid;
  grid-template-columns: minmax(360px, 1.02fr) minmax(0, 0.98fr);
  gap: clamp(34px, 5vw, 76px);
  align-items: center;
  margin-bottom: clamp(46px, 6vw, 82px);
}

.area-rank2-city-media {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-image);
  box-shadow: var(--shadow-image);
}

.area-rank2-city-media::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 22px;
  pointer-events: none;
}

.area-rank2-city-media img {
  display: block;
  width: 100%;
  height: clamp(360px, 37vw, 520px);
  object-fit: cover;
  transition: transform var(--speed-slow), filter var(--speed-slow);
}

.area-rank2-city-media:hover img {
  transform: scale(1.035);
  filter: saturate(1.04) contrast(1.03);
}

.area-rank2-city-main {
  position: relative;
  padding: clamp(22px, 3vw, 34px) 0;
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line);
}

.area-rank2-city-main::before {
  content: "";
  display: block;
  width: 88px;
  height: 3px;
  margin-bottom: 26px;
  background: var(--accent);
}

.area-rank2-city-main > span {
  display: inline-flex;
  margin-bottom: 16px;
  color: var(--accent-dark);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.area-rank2-city-main h2,
.area-rank2-city-main h3 {
  max-width: 620px;
  margin-bottom: 18px;
  font-size: clamp(2.9rem, 5.2vw, 4.35rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

.area-rank2-city-main p {
  max-width: 660px;
}

.area-rank2-city-main a {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-top: 26px;
  color: var(--accent-dark);
  font-weight: 850;
  transition: color var(--speed), transform var(--speed);
}

.area-rank2-city-main a::after {
  content: "→";
  margin-left: 10px;
  transition: transform var(--speed);
}

.area-rank2-city-main a:hover {
  color: var(--accent);
  transform: translateX(3px);
}

.area-rank2-city-main a:hover::after {
  transform: translateX(5px);
}

.area-rank2-city-index {
  display: grid;
  border-top: 1px solid var(--line-strong);
}

.area-rank2-city-row {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: clamp(18px, 3vw, 42px);
  align-items: center;
  padding: clamp(26px, 3vw, 36px) 0;
  border-bottom: 1px solid var(--line);
  transition: border-color var(--speed), padding-left var(--speed);
}

.area-rank2-city-row > span {
  color: var(--accent-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.16em;
}

.area-rank2-city-row h2,
.area-rank2-city-row h3 {
  margin-bottom: 8px;
  font-size: clamp(2.9rem, 5.2vw, 4.35rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

.area-rank2-city-row p {
  max-width: 680px;
  font-size: 0.96rem;
  line-height: 1.58;
}

.area-rank2-city-row a {
  display: inline-flex;
  align-items: center;
  justify-self: end;
  color: var(--accent-dark);
  font-size: 0.94rem;
  font-weight: 850;
  white-space: nowrap;
  transition: color var(--speed), transform var(--speed);
}

.area-rank2-city-row a::after {
  content: "→";
  margin-left: 9px;
  transition: transform var(--speed);
}

.area-rank2-city-row:hover {
  border-color: var(--line-strong);
  padding-left: 10px;
}

.area-rank2-city-row:hover a {
  color: var(--accent);
  transform: translateX(3px);
}

.area-rank2-city-row:hover a::after {
  transform: translateX(5px);
}

.area-rank2-cities .scroll-reveal,
.area-rank2-cities .scroll-reveal-text,
.area-rank2-cities .scroll-reveal-media {
  filter: none !important;
}

@media (max-width: 980px) {
  .area-rank2-city-feature {
    grid-template-columns: 1fr;
  }

  .area-rank2-city-row {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .area-rank2-city-row a {
    grid-column: 2;
    justify-self: start;
    margin-top: 14px;
  }
}

@media (max-width: 720px) {
  .area-rank2-city-media {
    border-radius: 22px;
  }

  .area-rank2-city-media::after {
    inset: 12px;
    border-radius: 14px;
  }

  .area-rank2-city-media img {
    height: 320px;
  }

  .area-rank2-city-main {
    padding: 28px 0;
  }

  .area-rank2-city-row {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 16px;
    padding: 24px 0;
  }

  .area-rank2-city-row:hover {
    padding-left: 0;
  }

  .area-rank2-city-row:hover a {
    transform: none;
  }
}
/* =========================================================
FIX LINK TESTUALI NELLE RIGHE CITTÀ
La freccia resta solo sui link CTA della riga,
non sui link inseriti dentro i paragrafi.
========================================================= */

.area-rank2-city-row p a,
.area-rank2-city-main p a {
  display: inline;
  width: auto;
  align-items: initial;
  justify-self: auto;
  margin-top: 0;
  color: var(--accent);
  font-size: inherit;
  font-weight: 850;
  line-height: inherit;
  white-space: normal;
  text-decoration: underline;
  text-underline-offset: 4px;
  transform: none;
}

.area-rank2-city-row p a::after,
.area-rank2-city-main p a::after {
  content: none;
  display: none;
  margin-left: 0;
}

.area-rank2-city-row:hover p a,
.area-rank2-city-main:hover p a {
  color: var(--accent-dark);
  transform: none;
}
/* =========================================================
FIX H1 HERO MOBILE PAGINE AREA
Evita che il titolo esca dallo schermo su smartphone
========================================================= */

@media (max-width: 720px) {
  .area-rank2-hero {
    padding-left: 18px;
    padding-right: 18px;
    overflow: hidden;
  }

  .area-rank2-hero .hero-content {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .area-rank2-hero h1 {
    width: 100%;
    max-width: 100%;
    font-size: clamp(2.25rem, 11vw, 3.45rem);
    line-height: 0.98;
    letter-spacing: -0.055em;
    white-space: normal;
    overflow-wrap: normal;
    word-break: normal;
  }

  .area-rank2-hero h1 span {
    white-space: normal !important;
  }

  .area-rank2-hero .hero-content p:not(.eyebrow) {
    max-width: 100%;
    font-size: clamp(1rem, 4.2vw, 1.12rem);
    line-height: 1.55;
  }
}

@media (max-width: 420px) {
  .area-rank2-hero h1 {
    font-size: clamp(2.05rem, 10.5vw, 3rem);
  }
}
