/* OKTAKEIT — premium B2B, neutral + accent */
:root {
  --bg: #f2f1ef;
  --bg-elevated: #fafaf8;
  --surface: #ffffff;
  --ink: #121212;
  --ink-muted: #4a4a48;
  --border: rgba(18, 18, 18, 0.09);
  --border-strong: rgba(18, 18, 18, 0.14);
  --accent: #9c2d1a;
  --accent-hover: #7a2314;
  --accent-soft: rgba(156, 45, 26, 0.08);
  --shadow-sm: 0 1px 2px rgba(18, 18, 18, 0.05);
  --shadow-md: 0 8px 30px rgba(18, 18, 18, 0.08);
  --shadow-lg: 0 24px 60px rgba(18, 18, 18, 0.12);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --font-sans: "Inter", system-ui, sans-serif;
  --font-serif: "Source Serif 4", Georgia, serif;
  --container: min(1120px, calc(100% - 3rem));
  --header-scale: 1.1;
  /* Allineamento testo "Idee" sotto la O del logo (padding trasparente tipico del PNG) */
  --header-mobile-picker-nudge: 0.3rem;
  /* Rifinitura manuale K↔O e m↔hamburger (tipografia vs box); 0 = solo calcolo automatico */
  --header-optical-nudge: 0px;
  --header-h: calc(5.75rem * var(--header-scale));
  --sol-strip-h: 2.625rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

h1, h2, h3 {
  font-family: var(--font-serif);
  font-weight: 600;
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: var(--ink);
}

h1 { font-size: clamp(2.125rem, 4vw + 1rem, 3.25rem); }
h2 { font-size: clamp(1.65rem, 2vw + 1rem, 2.125rem); }
h3 { font-size: 1.2rem; }

p { margin: 0 0 1rem; }
ul, ol { margin: 0; padding: 0; }

a {
  color: var(--accent);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

a:hover {
  color: var(--accent-hover);
}

.container {
  width: var(--container);
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 200;
  padding: 0.75rem 1.25rem;
  background: var(--ink);
  color: #fff;
  font-weight: 600;
}

.skip-link:focus {
  left: 1rem;
  top: 1rem;
}

/* —— Brand / logo —— */
.brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: var(--ink);
}

.brand:hover {
  color: var(--ink);
}

.brand__mark {
  flex-shrink: 0;
  color: var(--ink);
}

/* Logo PNG: +200% sulle ex SVG 44px / 40px → triplo (300% della base) */
.brand__mark--img {
  display: block;
  object-fit: contain;
}

.brand__mark--header {
  width: calc(5.5rem * var(--header-scale));
  height: calc(5.5rem * var(--header-scale));
}

.site-footer .brand__mark--footer {
  width: 7.5rem; /* 40px × 3 */
  height: 7.5rem;
  filter: brightness(0) invert(1);
}

.brand__text {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: -0.03em;
  line-height: 1;
}

.site-header .brand__text {
  font-size: calc(1.15rem * var(--header-scale));
}

.brand__text span {
  font-weight: 600;
  color: var(--ink-muted);
}

.site-footer .brand__text span {
  color: #a8a8a4;
}

/* —— Header —— */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(242, 241, 239, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}

/* Header un filo più vicino ai bordi rispetto al resto del layout */
.site-header .header-top.container {
  width: min(1120px, calc(100% - 2rem));
}

.header-top {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  column-gap: 1.25rem;
  row-gap: 0;
}

.header-inner {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  justify-content: flex-start;
  min-width: 0;
  min-height: var(--header-h);
  gap: calc(1.5rem * var(--header-scale));
}

.header-top > .nav {
  flex: 0 0 auto;
}

.header-top > .sol-strip {
  flex: 1 0 100%;
  width: 100%;
  min-width: 100%;
}

.sol-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.85rem;
  padding: 0.3rem 0 0.55rem;
  margin: 0;
  border-top: 1px solid var(--border);
  font-size: 0.8125rem;
  font-weight: 500;
}

.sol-strip__label {
  flex-shrink: 0;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.sol-strip__sep {
  flex-shrink: 0;
  color: var(--ink-muted);
  margin-right: 0.15rem;
}

.sol-strip__link {
  flex-shrink: 0;
  color: var(--ink-muted);
  text-decoration: none;
  white-space: nowrap;
  padding: 0.15rem 0;
}

.sol-strip__link:hover {
  color: var(--ink);
}

.sol-strip__link[aria-current="page"] {
  color: var(--accent);
  font-weight: 600;
}

.sol-strip__link--more {
  font-weight: 600;
}

.sol-strip__link--more:hover {
  color: var(--accent);
}

.nav-toggle {
  display: none;
  width: calc(2.75rem * var(--header-scale));
  height: calc(2.75rem * var(--header-scale));
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: var(--radius-sm);
  color: var(--ink);
}

.nav-toggle-bar {
  display: block;
  width: calc(1.35rem * var(--header-scale));
  height: 2px;
  background: currentColor;
  margin: calc(0.22rem * var(--header-scale)) auto;
  transition: transform 0.2s, opacity 0.2s;
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
  transform: translateY(calc(6px * var(--header-scale))) rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) {
  opacity: 0;
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
  transform: translateY(calc(-6px * var(--header-scale))) rotate(-45deg);
}

.nav__sol-mobile {
  display: none;
}

/* Mobile header: due tendine (Idee / Lingua) — visibili sotto i 768px */
.header-mobile-pickers {
  display: none;
}

.header-dd {
  position: relative;
}

.header-dd__summary {
  cursor: pointer;
  list-style: none;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ink-muted);
  padding: 0.15rem 0;
  border: none;
  border-radius: 0;
  background: transparent;
  white-space: nowrap;
  max-width: 42vw;
  overflow: visible;
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

.header-dd__summary:hover,
.header-dd__summary:focus-visible {
  color: var(--ink);
}

.header-dd__summary::-webkit-details-marker {
  display: none;
}

.header-dd__summary::marker {
  display: none;
  content: "";
}

/* Chevron: indica che è apribile */
.header-dd__summary::after {
  content: "";
  display: block;
  width: 0.35rem;
  height: 0.35rem;
  margin-left: 0.1rem;
  margin-top: 0.05rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  opacity: 0.85;
  flex-shrink: 0;
}

.header-dd[open] > .header-dd__summary::after {
  transform: rotate(-135deg);
  margin-top: 0.2rem;
}

.header-dd__panel {
  position: absolute;
  left: 0;
  top: calc(100% + 0.35rem);
  min-width: min(16rem, 92vw);
  max-width: min(20rem, 94vw);
  max-height: min(70vh, 22rem);
  overflow: auto;
  padding: 0.65rem 0.85rem;
  background: rgba(250, 250, 248, 0.98);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
  z-index: 120;
}

.header-dd__panel--lang {
  min-width: min(12rem, 88vw);
  max-height: none;
}

.header-dd__nav {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
}

.header-dd__nav a,
.header-dd__more,
.header-dd__lang {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--ink-muted);
  text-decoration: none;
  padding: 0.4rem 0;
  line-height: 1.35;
}

.header-dd__lang {
  font-family: inherit;
  display: block;
  width: 100%;
  border: none;
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.header-dd__nav a:hover,
.header-dd__more:hover,
.header-dd__lang:hover {
  color: var(--ink);
}

.header-dd__lang[aria-current="page"] {
  color: var(--accent);
  font-weight: 600;
}

.header-dd__more {
  margin-top: 0.35rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--border);
  font-weight: 600;
}

.nav {
  display: flex;
  align-items: center;
  gap: 0.25rem 1.75rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.nav__link {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink-muted);
  text-decoration: none;
}

.nav__link:hover {
  color: var(--ink);
}

.nav__link--active {
  color: var(--accent);
}

.nav__cta {
  margin-left: 0.5rem;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.lang-wrap {
  display: flex;
  align-items: center;
}

.lang-select {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 500;
  padding: 0.35rem 1.75rem 0.35rem 0.5rem;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background-color: var(--surface);
  color: var(--ink);
  cursor: pointer;
  max-width: 9.5rem;
}

.lang-select:focus {
  outline: 2px solid var(--accent-soft);
  outline-offset: 2px;
}

/* —— Buttons —— */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.65rem 1.35rem;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s, box-shadow 0.2s;
}

.btn-sm {
  padding: 0.5rem 1.1rem;
  font-size: 0.85rem;
}

.btn-lg {
  padding: 0.85rem 1.65rem;
  font-size: 0.95rem;
}

.btn-block {
  width: 100%;
}

.btn-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: var(--shadow-sm);
}

.btn-primary:hover {
  background: var(--accent-hover);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.btn-secondary {
  background: var(--surface);
  color: var(--ink);
  border-color: var(--border-strong);
}

.btn-secondary:hover {
  border-color: var(--ink-muted);
  color: var(--ink);
}

/* —— Sections —— */
.section {
  padding: clamp(3.5rem, 8vw, 6rem) 0;
}

.section--tight {
  padding: clamp(2.5rem, 5vw, 3.5rem) 0;
}

.section--surface {
  background: var(--surface);
}

.section--elevated {
  background: var(--bg-elevated);
}

.section__head {
  max-width: 38rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}

.section__head--center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.section__head p:last-child {
  margin-bottom: 0;
}

.section__kicker {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.75rem;
}

.section__lead {
  font-size: 1.05rem;
  color: var(--ink-muted);
  margin-top: 0.75rem;
}

.section__lead--invest-web {
  margin-top: 0.65rem;
  max-width: 40rem;
  margin-inline: auto;
}

/* A capo dopo “. ” nei testi i18n (newline nelle stringhe) */
.section__head--center .section__lead {
  white-space: pre-line;
}

/* —— Hero —— */
.hero {
  padding: clamp(2.5rem, 6vw, 4rem) 0 clamp(3rem, 7vw, 5rem);
  border-bottom: 1px solid var(--border);
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr minmax(240px, 38%);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.hero__statement {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 1rem;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.75rem;
}

.hero__note {
  margin-top: 1.25rem;
  font-size: 0.875rem;
  color: var(--ink-muted);
}

.hero__visual {
  display: flex;
  justify-content: center;
}

/* —— Cards —— */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1.5rem 1.35rem;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

.card__link {
  text-decoration: none;
  color: inherit;
  display: block;
  height: 100%;
}

.card__link:hover h3 {
  color: var(--accent);
}

.card h3 {
  margin: 0 0 0.5rem;
  font-size: 1.15rem;
}

.card p:last-child {
  margin-bottom: 0;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}

/* —— Device mockup —— */
.device {
  position: relative;
  width: 100%;
  max-width: 260px;
  margin-inline: auto;
  padding: 0.55rem;
  border-radius: 2.1rem;
  background: linear-gradient(152deg, #252525 0%, #0d0d0d 100%);
  box-shadow: var(--shadow-lg);
}

.device__notch {
  position: absolute;
  top: 0.7rem;
  left: 50%;
  transform: translateX(-50%);
  width: 34%;
  height: 1.4rem;
  background: #0a0a0a;
  border-radius: 0 0 14px 14px;
  /* Sotto .device__screen (z-index 1): altrimenti la pillola finisce sopra il contenuto */
  z-index: 0;
  pointer-events: none;
}

.device__screen {
  position: relative;
  z-index: 1;
  border-radius: 1.65rem;
  overflow: hidden;
  aspect-ratio: 390 / 844;
  background: #1a1a1a;
  container-type: size;
  container-name: device-screen;
}

/* Escludi mock con immagine a altezza naturale + scroll (ristoranti, hotel) */
.device__screen img:not(.rst-hero-mock__img--natural) {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

/* Hero ristoranti: mock 8 slide + scroll sulle slide alte; asset per lingua in JS */
.rst-hero__figure-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}

.rst-hero-mock__arrow {
  position: absolute;
  top: 40%;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  margin: 0;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--surface);
  color: var(--ink);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.rst-hero-mock__arrow:hover {
  background: var(--accent-soft);
  color: var(--accent);
}

.rst-hero-mock__arrow:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.rst-hero-mock__arrow--prev {
  left: 0;
  transform: translate(calc(-100% + 0.2rem), -50%);
}

.rst-hero-mock__arrow--next {
  right: 0;
  transform: translate(calc(100% - 0.2rem), -50%);
}

.rst-hero-mock {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
  overflow: hidden;
}

.rst-hero-mock__viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: inherit;
}

.rst-hero-mock__track {
  display: flex;
  width: 800%;
  height: 100%;
  transform: translateX(0);
  transition: transform 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
  .rst-hero-mock__track {
    transition: none;
  }
}

.rst-hero-mock__slide {
  position: relative;
  flex: 0 0 calc(100% / 8);
  height: 100%;
  overflow: hidden;
}

.rst-hero-mock__slide--cover .rst-hero-mock__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.rst-hero-mock__slide--tall {
  display: flex;
  flex-direction: column;
  background: #1a1a1a;
}

.rst-hero-mock__scroller {
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.rst-hero-mock__img--natural {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto !important;
  object-fit: unset;
  object-position: unset;
}

.rst-hero-mock__scroll-down {
  position: absolute;
  bottom: 0.4rem;
  left: 50%;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
}

.rst-hero-mock__scroll-down:hover {
  background: rgba(0, 0, 0, 0.72);
}

.rst-hero-mock__scroll-down:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.rst-hero-mock__scroll-down[hidden] {
  display: none !important;
}

.rst-hero-mock__scroll-down.is-at-end {
  opacity: 0.35;
  pointer-events: none;
}

/* Hero hotel: mock multi-slide + scroll su slide alte (frecce .rst-hero-mock__arrow) */
.htl-hero__visual {
  overflow: visible;
}

.htl-hero__figure-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}

.htl-hero-mock {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
  overflow: hidden;
}

.htl-hero-mock__viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: inherit;
}

/* Home hero: intro video sopra le slide, poi carosello immagini */
.home-hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 3;
  border-radius: inherit;
  overflow: hidden;
  background: linear-gradient(155deg, #353540 0%, #1a1a22 42%, #26262f 100%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

[data-home-hero-root].home-hero--video-phase .home-hero-video-wrap {
  opacity: 1;
  visibility: visible;
}

.home-hero-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

[data-home-hero-root].home-hero--video-phase .rst-hero-mock__scroll-down {
  opacity: 0;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .home-hero-video-wrap {
    display: none !important;
  }
}

.htl-hero-mock__track {
  display: flex;
  width: 800%;
  height: 100%;
  transform: translateX(0);
  transition: transform 0.35s ease;
}

.htl-hero-mock__track--home {
  width: 600%;
}

.htl-hero-mock__track--home > .htl-hero-mock__slide {
  flex: 0 0 calc(100% / 6);
}

@media (prefers-reduced-motion: reduce) {
  .htl-hero-mock__track {
    transition: none;
  }
}

.htl-hero-mock__slide {
  position: relative;
  flex: 0 0 calc(100% / 8);
  height: 100%;
  overflow: hidden;
}

.htl-hero-mock__slide--cover .htl-hero-mock__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.htl-hero-mock__slide.rst-hero-mock__slide--tall {
  display: flex;
  flex-direction: column;
  background: #1a1a1a;
}

@media (max-width: 420px) {
  .rst-hero-mock__arrow {
    width: 1.75rem;
    height: 1.75rem;
    font-size: 1.15rem;
  }

  .rst-hero-mock__arrow--prev {
    transform: translate(calc(-100% + 0.15rem), -50%);
  }

  .rst-hero-mock__arrow--next {
    transform: translate(calc(100% - 0.15rem), -50%);
  }
}

/* Schermata telefono senza immagini (solo gradiente) */
.device__screen > .device__screen-placeholder {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(155deg, #353540 0%, #1a1a22 42%, #26262f 100%);
}

.rst-mock-slide-placeholder {
  width: 100%;
  min-height: 100%;
  flex: 1 1 auto;
  align-self: stretch;
  background: linear-gradient(160deg, #2a2824 0%, #141210 50%, #1f1c18 100%);
}

.device__fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  padding: 1.5rem;
  text-align: center;
  font-size: 0.8rem;
  color: #888;
  background: linear-gradient(180deg, #2a2a2a, #1a1a1a);
}

.device--sm {
  max-width: 200px;
}

.device-row {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  align-items: flex-end;
}

.device-row .device {
  margin-inline: 0;
}

/* Caption sotto mock telefono (ristoranti) */
.device-with-caption {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  max-width: 260px;
}

.device-with-caption:has(.device--sm) {
  max-width: 200px;
}

.device-caption {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  text-align: center;
  padding: 0 0.25rem;
}

.device-caption__text {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.35;
  color: var(--ink-muted);
  max-width: 14rem;
}

/* Frame telefono pagina ristoranti (mock vuoto = placeholder) */
.device__screen:has(.device__screen-placeholder) {
  background: #1a1a1a;
}

.device-with-caption:has(.device--rst-chrome) {
  overflow: visible;
  max-width: min(100%, 340px);
  padding-inline: clamp(1.85rem, 6vw, 2.65rem);
  box-sizing: content-box;
}

.device-with-caption:has(.device--sm.device--rst-chrome) {
  max-width: min(100%, 300px);
  padding-inline: clamp(1.6rem, 5vw, 2.35rem);
}

.device.device--rst-chrome {
  overflow: visible;
}

.device.device--rst-chrome > .rst-mock-carousel__arrow {
  position: absolute;
  top: 50%;
  z-index: 8;
  width: 1.52rem;
  height: 1.52rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  color: #1a1a1a;
  font-size: 1.02rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.22);
  transform: translateY(-50%);
}

.device.device--rst-chrome > .rst-mock-carousel__arrow--prev {
  left: 0;
  transform: translate(calc(-100% + 0.2rem), -50%);
}

.device.device--rst-chrome > .rst-mock-carousel__arrow--next {
  right: 0;
  left: auto;
  transform: translate(calc(100% - 0.2rem), -50%);
}

.device.device--rst-chrome > .rst-mock-carousel__arrow:disabled {
  opacity: 0.34;
  cursor: not-allowed;
}

.device.device--rst-chrome > .rst-mock-carousel__dots {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 0.42em;
  padding: 0.48rem 0 0;
  margin: 0;
  pointer-events: none;
  z-index: 1;
}

/* —— Carosello mock ristoranti: frecce + puntini (no scroll orizzontale) —— */
.rst-mock-carousel {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.rst-mock-carousel__viewport {
  container-type: inline-size;
  container-name: rst-mock-view;
  width: 100%;
  height: 100%;
  overflow: hidden;
  touch-action: manipulation;
}

/* Scroll verticale sul mock PNG IT: il viewport non deve rubare il pan verticale al dito */
.rst-mock-carousel:has(.rst-mock-carousel__slide--media-scroll) .rst-mock-carousel__viewport {
  touch-action: pan-x pan-y;
}

.rst-mock-carousel__track {
  display: flex;
  height: 100%;
  min-height: 0;
  width: max-content;
  transition: transform 0.22s ease;
}

.rst-mock-carousel__slide {
  flex-shrink: 0;
  height: 100%;
  min-height: 0;
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  font-size: clamp(11px, 4.25cqi, 16px);
  line-height: 1.4;
}

@supports not (font-size: 1cqi) {
  .rst-mock-carousel__slide {
    font-size: 12px;
  }
}

.device--sm .rst-mock-carousel__slide {
  font-size: clamp(10px, 5.5cqi, 14px);
}

@supports not (font-size: 1cqi) {
  .device--sm .rst-mock-carousel__slide {
    font-size: 11px;
  }
}

.rst-mock-carousel__slide .rst-p1-screen {
  font-size: 1em;
  min-height: 100%;
  box-sizing: border-box;
}

/* Slide con pannello (menu / ordine): scroll senza barra + freccia in basso */
.rst-mock-carousel__slide:has(.rst-mock-slide--scrollable) {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
}

.rst-mock-slide--scrollable {
  position: relative;
  flex: 1;
  min-height: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.rst-mock-slide__scroll {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.rst-mock-slide__scroll::-webkit-scrollbar {
  display: none;
}

.rst-mock-slide__scroll-down {
  position: absolute;
  left: 50%;
  bottom: 1.1rem;
  z-index: 5;
  width: 2rem;
  height: 2rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.94);
  color: #1a1a1a;
  font-size: 1.05rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.16);
  transform: translateX(-50%);
  animation: rst-mock-scroll-hint 1.75s ease-in-out infinite;
}

.rst-mock-slide__scroll-down:hover {
  background: #fff;
}

.rst-mock-slide__scroll-down:focus-visible {
  outline: 2px solid #9c2d1a;
  outline-offset: 2px;
}

.rst-mock-slide__scroll-down[hidden] {
  display: none !important;
}

.rst-mock-slide__scroll-down-icon {
  display: block;
  transform: translateY(0.04em);
}

@keyframes rst-mock-scroll-hint {
  0%,
  100% {
    transform: translateX(-50%) translateY(0);
  }

  50% {
    transform: translateX(-50%) translateY(0.22rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .rst-mock-slide__scroll-down {
    animation: none;
  }
}

/* Mock slide 2 — home “Gusto e Tradizione” (ristoranti) */
.rst-mock-p2 {
  box-sizing: border-box;
  min-height: 100%;
  background: #fbfbe2;
  color: #1b1d0e;
  font-family: var(--font-sans);
  text-align: left;
  font-size: 1em;
  line-height: 1.35;
}

.rst-mock-p2__sticky-head {
  position: sticky;
  top: 0;
  z-index: 4;
  padding-top: clamp(0.55rem, 5.5cqi, 0.95rem);
  margin-top: 0;
  background: #fbfbe2;
}

.rst-mock-p2__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.35em;
  padding: 0.35em 0.5em 0.4em;
  background: #fbfbe2;
}

.rst-mock-p2__top-ico {
  display: flex;
  color: #973100;
  flex-shrink: 0;
}

.rst-mock-p2__brand {
  margin: 0;
  flex: 1;
  text-align: center;
  font-family: var(--font-serif);
  font-size: 1.05em;
  font-weight: 700;
  font-style: italic;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.rst-mock-p2__avatar {
  display: block;
  width: 2em;
  height: 2em;
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(225, 191, 180, 0.45);
  background: #e4e4cc;
}

.rst-mock-p2__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  user-select: none;
}

.rst-mock-p2__avatar-ph {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, #c4b8a8 0%, #7d6b5c 55%, #4a3f36 100%);
}

.rst-mock-p2__hairline {
  height: 1px;
  background: #f5f5dc;
  margin: 0;
}

.rst-mock-p2__main {
  padding: 0 0.45em 0.35em;
}

.rst-mock-p2__hero-wrap {
  margin-top: 0.35em;
}

.rst-mock-p2__hero {
  position: relative;
  border-radius: 1.35em;
  overflow: hidden;
  box-shadow: 0 0.35em 1.2em rgba(0, 0, 0, 0.14);
  aspect-ratio: 4 / 5;
  max-height: 42cqi;
}

/* Maschera la parte alta delle foto stock (spesso watermark / testo incollato sull’asset) */
.rst-mock-p2__hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 48%;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(12, 10, 8, 0.78) 0%, rgba(12, 10, 8, 0.28) 55%, transparent 100%);
}

@supports not (aspect-ratio: 4 / 5) {
  .rst-mock-p2__hero {
    min-height: 11em;
  }
}

.rst-mock-p2__hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 38%;
  display: block;
  pointer-events: none;
  user-select: none;
  position: relative;
  z-index: 0;
}

.rst-mock-p2__hero-ph {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(165deg, #4a3028 0%, #2c1812 38%, #1a0f0c 72%, #3d2520 100%);
  pointer-events: none;
  user-select: none;
}

.rst-mock-p2__hero-grad {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0.65em 0.55em 0.7em;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.88) 0%, rgba(0, 0, 0, 0.35) 42%, transparent 68%);
}

.rst-mock-p2__hero-title {
  margin: 0 0 0.5em;
  font-family: var(--font-serif);
  font-size: clamp(1.05em, 4.8cqi, 1.38em);
  font-weight: 700;
  line-height: 1;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.14em;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}

.rst-mock-p2__hero-line {
  display: block;
  line-height: 1.18;
  max-width: 100%;
}

.rst-mock-p2__hero-accent {
  font-style: italic;
  color: #f0d56a;
  margin-top: 0.02em;
}

.rst-mock-p2__hero-ctas {
  display: flex;
  flex-direction: column;
  gap: 0.35em;
}

.rst-mock-p2__pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3em;
  padding: 0.42em 0.55em;
  border-radius: 999px;
  font-size: 0.64em;
  font-weight: 700;
  white-space: normal;
  text-align: center;
  line-height: 1.22;
  max-width: 100%;
}

.rst-mock-p2__pill-ico {
  flex-shrink: 0;
}

.rst-mock-p2__pill--pri {
  background: #973100;
  color: #fff;
  box-shadow: 0 0.2em 0.55em rgba(151, 49, 0, 0.28);
}

.rst-mock-p2__pill--sec {
  background: #735c00;
  color: #fff;
  border: 1px solid rgba(255, 224, 136, 0.35);
  box-shadow: 0 0.2em 0.55em rgba(115, 92, 0, 0.2);
}

.rst-mock-p2__chips {
  margin-top: 0.55em;
}

.rst-mock-p2__chips-row {
  display: flex;
  gap: 0.3em;
  overflow-x: auto;
  padding-bottom: 0.15em;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.rst-mock-p2__chips-row::-webkit-scrollbar {
  display: none;
}

.rst-mock-p2__chip {
  flex-shrink: 0;
  padding: 0.32em 0.55em;
  border-radius: 999px;
  font-size: 0.58em;
  font-weight: 600;
  border: 1px solid rgba(225, 191, 180, 0.25);
  background: #eaead1;
  color: #594139;
}

.rst-mock-p2__chip--on {
  background: #973100;
  color: #fff;
  font-weight: 700;
  border-color: transparent;
  box-shadow: 0 0.12em 0.35em rgba(151, 49, 0, 0.22);
}

.rst-mock-p2__bento {
  display: flex;
  flex-direction: column;
  gap: 0.4em;
  margin-top: 0.55em;
}

.rst-mock-p2__tile {
  position: relative;
  padding: 0.55em 0.55em 0.5em;
  border-radius: 1.1em;
  overflow: hidden;
  min-height: 4.6em;
}

.rst-mock-p2__tile--low {
  background: #f5f5dc;
}

.rst-mock-p2__tile--hi {
  background: #e4e4cc;
}

.rst-mock-p2__tile--gold {
  background: #cca72f;
  color: #4e3d00;
}

.rst-mock-p2__tile--gold .rst-mock-p2__tile-lbl {
  color: #574500;
}

.rst-mock-p2__tile--gold .rst-mock-p2__tile-val {
  color: #4e3d00;
}

.rst-mock-p2__tile-ico {
  display: block;
  margin-bottom: 0.25em;
}

.rst-mock-p2__tile-ico--pri {
  color: #973100;
}

.rst-mock-p2__tile-ico--sec {
  color: #50652a;
}

.rst-mock-p2__tile-lbl {
  margin: 0 0 0.12em;
  font-size: 0.52em;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #594139;
}

.rst-mock-p2__tile-val {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 0.95em;
  font-weight: 700;
  line-height: 1.2;
  color: #1b1d0e;
}

.rst-mock-p2__tile-val--lines {
  font-size: 0.82em;
}

.rst-mock-p2__tile-val--addr {
  font-size: 0.72em;
  line-height: 1.25;
}

.rst-mock-p2__spec {
  margin-top: 0.65em;
}

.rst-mock-p2__spec-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.35em;
  margin-bottom: 0.4em;
}

.rst-mock-p2__spec-h {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 0.95em;
  font-weight: 700;
  line-height: 1.15;
  color: #1b1d0e;
}

.rst-mock-p2__spec-link {
  display: inline-flex;
  align-items: center;
  gap: 0.12em;
  font-size: 0.52em;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #973100;
  white-space: nowrap;
}

.rst-mock-p2__spec-chev {
  flex-shrink: 0;
  opacity: 0.9;
}

.rst-mock-p2__dishes {
  display: flex;
  gap: 0.45em;
  overflow-x: auto;
  padding-bottom: 0.35em;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.rst-mock-p2__dishes::-webkit-scrollbar {
  display: none;
}

.rst-mock-p2__dish {
  flex: 0 0 58%;
  min-width: 9.5em;
  max-width: 12em;
}

.rst-mock-p2__dish-img-wrap {
  border-radius: 0.85em;
  overflow: hidden;
  margin-bottom: 0.3em;
  aspect-ratio: 1;
  box-shadow: 0 0.2em 0.55em rgba(0, 0, 0, 0.1);
}

.rst-mock-p2__dish-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  pointer-events: none;
  user-select: none;
}

.rst-mock-p2__dish-ph {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  background: linear-gradient(145deg, #e8e4d8 0%, #c9c2b0 45%, #a69b88 100%);
  pointer-events: none;
  user-select: none;
}

.rst-mock-p2__dish-name {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 0.78em;
  font-weight: 700;
  line-height: 1.15;
  color: #1b1d0e;
}

.rst-mock-p2__dish-desc {
  margin: 0.15em 0 0;
  font-size: 0.58em;
  color: #594139;
  line-height: 1.3;
}

.rst-mock-p2__dish-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.28em;
}

.rst-mock-p2__dish-price {
  font-family: var(--font-serif);
  font-size: 0.78em;
  font-weight: 700;
  color: #973100;
}

.rst-mock-p2__dish-add {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.65em;
  height: 1.65em;
  border-radius: 50%;
  background: #e4e4cc;
  color: #973100;
}

.rst-mock-p2__tabbar {
  position: sticky;
  bottom: 0;
  z-index: 3;
  display: flex;
  justify-content: space-around;
  align-items: flex-end;
  gap: 0.15em;
  margin-top: 0.5em;
  padding: 0.35em 0.15em 0.45em;
  background: rgba(251, 251, 226, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-top: 1px solid rgba(27, 29, 14, 0.06);
  border-radius: 0.85em 0.85em 0 0;
  box-shadow: 0 -0.25em 0.65em rgba(0, 0, 0, 0.05);
}

.rst-mock-p2__tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.12em;
  font-size: 0.45em;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #78716c;
  opacity: 0.72;
}

.rst-mock-p2__tab--on {
  color: #973100;
  opacity: 1;
  transform: scale(1.04);
}

.rst-mock-p2__tab-ico {
  display: block;
}

.rst-mock-p2__tab-bag {
  position: relative;
  display: block;
}

.rst-mock-p2__tab-badge {
  position: absolute;
  top: -0.15em;
  right: -0.35em;
  min-width: 0.95em;
  height: 0.95em;
  padding: 0 0.12em;
  border-radius: 999px;
  background: #973100;
  color: #fff;
  font-size: 0.65em;
  font-weight: 800;
  line-height: 0.95em;
  text-align: center;
}

.rst-mock-carousel__arrow {
  position: absolute;
  top: 50%;
  z-index: 6;
  width: 1.65rem;
  height: 1.65rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: #1a1a1a;
  font-size: 1.15rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
  transform: translateY(-50%);
}

.rst-mock-carousel__arrow--prev {
  left: 0.2rem;
}

.rst-mock-carousel__arrow--next {
  right: 0.2rem;
}

.rst-mock-carousel__arrow:disabled {
  opacity: 0.32;
  cursor: not-allowed;
}

.rst-mock-carousel__slide--media {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: #0a0a0a;
  padding: 0;
  overflow-y: hidden;
  touch-action: manipulation;
}

.rst-mock-screen-img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: top center;
  image-rendering: high-quality;
  /* Niente trascinamento / selezione immagine (evita “fantasma” copia-incolla) */
  -webkit-user-drag: none;
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
}

/* Slide PNG senza scroll: cover a tutto schermo (come prima); min-height 0 evita stretch strani da flex */
.rst-mock-carousel__slide--media:not(.rst-mock-carousel__slide--media-scroll) .rst-mock-screen-img {
  min-height: 0;
  align-self: stretch;
  object-fit: cover;
  object-position: top center;
}

/* Schermata intera da PNG (es. mock IT): dentro slide scrollabile, dopo .rst-mock-screen-img */
.rst-mock-carousel__slide--media.rst-mock-carousel__slide--media-scroll {
  display: block;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
  background: #fbfbe2;
  touch-action: pan-y;
  scrollbar-width: thin;
}

.rst-mock-carousel__slide--media.rst-mock-carousel__slide--media-scroll .rst-mock-screen-img.rst-mock-screen-img--fullmock {
  display: block;
  width: 100%;
  height: auto;
  min-height: 0;
  max-height: none;
  object-fit: unset;
  object-position: top center;
  background: #fbfbe2;
}

.rst-mock-carousel__dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.55rem;
  z-index: 4;
  display: flex;
  justify-content: center;
  gap: 0.45em;
  pointer-events: none;
}

.rst-mock-carousel__dots span {
  pointer-events: auto;
  width: 0.42em;
  height: 0.42em;
  min-width: 6px;
  min-height: 6px;
  border-radius: 50%;
  background: #1b1d0e;
  opacity: 0.3;
  cursor: pointer;
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.rst-mock-carousel__dots span.is-on {
  opacity: 1;
  transform: scale(1.08);
}

@media (prefers-reduced-motion: reduce) {
  .rst-mock-carousel__track {
    transition: none;
  }

  .rst-mock-carousel__dots span {
    transition: none;
  }
}

/* Slide 2–3 (menu / ordine) */
.rst-slide-panel {
  min-height: 100%;
  box-sizing: border-box;
  padding: 0.7rem 0.55rem 2.1rem;
  font-family: var(--font-sans);
  text-align: left;
  color: #2a211c;
  background: linear-gradient(180deg, #faf8f0 0%, #f0ebe0 100%);
}

.rst-slide-panel--order {
  display: flex;
  flex-direction: column;
  gap: 0.55em;
}

.rst-slide-panel__kicker {
  margin: 0;
  font-size: 0.72em;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #735c00;
}

.rst-slide-panel__title {
  margin: 0 0 0.45em;
  font-family: var(--font-serif);
  font-size: 1.35em;
  font-weight: 700;
  line-height: 1.15;
  color: #1b1d0e;
}

.rst-slide-panel__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}

.rst-slide-panel__menu li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.65em;
  padding: 0.45em 0;
  border-bottom: 1px solid rgba(27, 29, 14, 0.08);
  font-size: 0.88em;
  font-weight: 500;
}

.rst-slide-panel__price {
  flex-shrink: 0;
  font-weight: 700;
  color: #9c2d1a;
}

.rst-slide-panel__lead {
  margin: 0;
  font-size: 0.86em;
  line-height: 1.45;
  color: rgba(43, 36, 28, 0.85);
}

.rst-slide-panel__lines {
  display: flex;
  flex-direction: column;
  gap: 0.35em;
  font-size: 0.86em;
  margin: 0.25em 0;
}

.rst-slide-panel__line {
  display: flex;
  justify-content: space-between;
  gap: 0.75em;
  color: rgba(43, 36, 28, 0.9);
}

.rst-slide-panel__total {
  margin: 0.35em 0 0;
  font-size: 0.95em;
  font-weight: 600;
}

.rst-slide-panel__total strong {
  color: #9c2d1a;
  font-weight: 800;
}

.rst-slide-panel__btn {
  margin-top: auto;
  text-align: center;
}

.rst-p1-screen {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0.75rem 0.5rem 0.7rem;
  box-sizing: border-box;
  overflow: hidden;
  font-family: var(--font-sans);
  /* Base più grande: leggibilità nel mock (cqi = % larghezza schermo telefono) */
  font-size: clamp(11px, 4.25cqi, 16px);
  line-height: 1.4;
  color: #2a211c;
  background: linear-gradient(165deg, #faf8f0 0%, #f3efe4 52%, #e8e2d4 100%);
}

@supports not (font-size: 1cqi) {
  .rst-p1-screen {
    font-size: 12px;
  }
}

/* Mock piccoli: evita testo microscopico */
.device--sm .rst-p1-screen {
  font-size: clamp(10px, 5.5cqi, 14px);
}

@supports not (font-size: 1cqi) {
  .device--sm .rst-p1-screen {
    font-size: 11px;
  }
}

/* Home mock “shell” (layout tipo brand + CTA, dentro .rst-p1-screen) */
.rst-p1-screen > .rst-shell-p1 {
  flex: 1;
  min-height: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
}

.rst-shell-p1 {
  position: relative;
  z-index: 1;
  text-align: center;
}

.rst-shell-p1__ambience {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
  opacity: 0.11;
}

.rst-shell-p1__blob {
  position: absolute;
  width: 58%;
  height: 36%;
  border-radius: 50%;
  filter: blur(36px);
}

.rst-shell-p1__blob--tl {
  top: -10%;
  left: -10%;
  background: #c9a227;
}

.rst-shell-p1__blob--br {
  bottom: -10%;
  right: -10%;
  background: #9c2d1a;
}

.rst-shell-p1__deco-top {
  position: relative;
  z-index: 2;
  align-self: flex-end;
  display: flex;
  justify-content: flex-end;
  width: 100%;
  padding: 0.1rem 0.2rem 0 0;
  opacity: 0.2;
  color: #735c00;
}

.rst-shell-p1__deco-icon {
  display: block;
  width: 2em;
  height: 2em;
}

.rst-shell-p1__brand {
  position: relative;
  z-index: 2;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 0.15rem 0 0.4rem;
}

.rst-shell-p1__ring {
  width: 5.35em;
  height: 5.35em;
  border-radius: 50%;
  border: 1.5px solid rgba(141, 113, 103, 0.42);
  background: rgba(255, 255, 255, 0.55);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.55em;
}

.rst-shell-p1__ring svg {
  width: 3em;
  height: 3em;
  color: #9c2d1a;
}

.rst-shell-p1__titles {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.rst-shell-p1__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 1.38em;
  font-weight: 700;
  font-style: italic;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #1b1d0e;
}

.rst-shell-p1__rule {
  width: 2em;
  height: 2px;
  margin: 0.45em auto 0.35em;
  background: rgba(115, 92, 0, 0.5);
  border-radius: 1px;
}

.rst-shell-p1__kicker {
  margin: 0;
  font-size: 0.76em;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #594139;
  max-width: 95%;
}

.rst-shell-p1__lower {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  width: 100%;
  max-width: 22em;
  padding-bottom: 0.2rem;
}

.rst-shell-p1__lead {
  margin: 0 auto 0.55em;
  font-size: 1.02em;
  font-weight: 500;
  line-height: 1.42;
  color: rgba(43, 36, 28, 0.88);
  max-width: 24ch;
}

.rst-shell-p1__trust {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.4em;
  color: #9c2d1a;
  max-width: 100%;
  padding: 0 0.15rem 0.5rem;
}

.rst-shell-p1__trust svg {
  flex-shrink: 0;
  width: 1.2em;
  height: 1.2em;
  margin-top: 0.06em;
}

.rst-shell-p1__trust span {
  font-size: 0.8em;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.28;
  max-width: 28ch;
  text-align: center;
}

.rst-shell-p1__cta {
  display: flex;
  margin-left: auto;
  margin-right: auto;
}

.rst-shell-p1__est {
  position: absolute;
  left: 0.35rem;
  bottom: 1.45rem;
  z-index: 3;
  margin: 0;
  font-family: var(--font-serif);
  font-size: 0.7em;
  font-style: italic;
  color: rgba(27, 29, 14, 0.38);
  transform: rotate(-90deg);
  transform-origin: left bottom;
  white-space: nowrap;
  pointer-events: none;
}

.rst-p1-screen__blobs {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  opacity: 0.14;
}

.rst-p1-screen__blob {
  position: absolute;
  width: 55%;
  height: 32%;
  border-radius: 50%;
  filter: blur(32px);
}

.rst-p1-screen__blob--tl {
  top: -8%;
  left: -12%;
  background: #c9a227;
}

.rst-p1-screen__blob--br {
  bottom: -10%;
  right: -12%;
  background: #9c2d1a;
}

.rst-p1-screen__deco-tr {
  position: absolute;
  top: 0.35rem;
  right: 0.45rem;
  z-index: 1;
  opacity: 0.22;
  color: #735c00;
}

.rst-p1-screen__deco-tr svg {
  display: block;
  width: 2.25em;
  height: 2.25em;
}

.rst-p1-screen__body {
  position: relative;
  z-index: 1;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 0.25rem 0 0.5rem;
}

.rst-p1-screen__ring {
  width: 6.25em;
  height: 6.25em;
  border-radius: 50%;
  border: 1.5px solid rgba(141, 113, 103, 0.45);
  background: rgba(255, 255, 255, 0.55);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.65em;
}

.rst-p1-screen__ring svg {
  width: 3.35em;
  height: 3.35em;
  color: #9c2d1a;
}

.rst-p1-screen__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 2.05em;
  font-weight: 700;
  font-style: italic;
  letter-spacing: -0.02em;
  line-height: 1.08;
  color: #1b1d0e;
}

.rst-p1-screen__rule {
  width: 2em;
  height: 2px;
  margin: 0.5em auto 0.4em;
  background: rgba(115, 92, 0, 0.5);
  border-radius: 1px;
}

.rst-p1-screen__kicker {
  margin: 0 0 0.55em;
  font-size: 0.78em;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #594139;
  max-width: 95%;
}

.rst-p1-screen__lead {
  margin: 0 0 0.6em;
  font-size: 1.05em;
  font-weight: 500;
  line-height: 1.42;
  color: rgba(43, 36, 28, 0.88);
  max-width: 26ch;
}

.rst-p1-screen__trust {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.4em;
  color: #9c2d1a;
  max-width: 100%;
  padding: 0 0.15rem;
}

.rst-p1-screen__trust svg {
  flex-shrink: 0;
  width: 1.25em;
  height: 1.25em;
  margin-top: 0.08em;
}

.rst-p1-screen__trust span {
  font-size: 0.82em;
  font-weight: 700;
  letter-spacing: 0.035em;
  text-transform: uppercase;
  line-height: 1.28;
  max-width: 28ch;
  text-align: center;
}

.rst-p1-screen__footer {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 22em;
  margin-top: 0;
  padding-top: 0.5rem;
  flex-shrink: 0;
}

.rst-p1-screen__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35em;
  width: 100%;
  padding: 0.8em 1em;
  border-radius: 999px;
  font-size: 1.05em;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(180deg, #b83218 0%, #8f2814 100%);
  box-shadow: 0 0.35em 0.85em rgba(156, 45, 26, 0.28);
}

.rst-p1-screen__chev {
  font-size: 1.1em;
  line-height: 1;
  opacity: 0.95;
  transform: translateY(0.02em);
}

.rst-p1-screen__dots {
  display: flex;
  justify-content: center;
  gap: 0.45em;
  margin-top: 0.65em;
  opacity: 0.45;
}

.rst-p1-screen__dots span {
  width: 0.35em;
  height: 0.35em;
  border-radius: 50%;
  background: #1b1d0e;
  opacity: 0.35;
}

.rst-p1-screen__dots span.is-on {
  opacity: 1;
}

.rst-p1-screen__est {
  position: absolute;
  left: 0.5rem;
  bottom: 1.75rem;
  z-index: 1;
  margin: 0;
  font-family: var(--font-serif);
  font-size: 0.72em;
  font-style: italic;
  color: rgba(27, 29, 14, 0.4);
  transform: rotate(-90deg);
  transform-origin: left bottom;
  white-space: nowrap;
  pointer-events: none;
}

/* —— Lists —— */
.check-list {
  list-style: none;
}

.check-list li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: 0.65rem;
  color: var(--ink-muted);
  font-size: 0.95rem;
}

.check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45rem;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

.pain-list {
  list-style: none;
}

.pain-list li {
  padding: 1rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.95rem;
  color: var(--ink-muted);
}

.pain-list li strong {
  display: block;
  color: var(--ink);
  font-weight: 600;
  margin-bottom: 0.25rem;
}

/* —— Pricing —— */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  align-items: stretch;
}

.pricing-card {
  display: flex;
  flex-direction: column;
  padding: 1.75rem 1.5rem;
  text-align: left;
}

.pricing-card--featured {
  border-color: rgba(156, 45, 26, 0.25);
  box-shadow: 0 12px 40px rgba(156, 45, 26, 0.1);
}

.pricing-card__badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  margin-bottom: 0.75rem;
}

.pricing-card h3 {
  margin: 0 0 0.35rem;
}

.pricing-card__for {
  font-size: 0.875rem;
  color: var(--ink-muted);
  margin-bottom: 1rem;
}

.pricing-card__price {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
}

.pricing-card .check-list {
  flex-grow: 1;
  margin-bottom: 1.25rem;
}

/* —— CTA strip —— */
.cta-strip {
  background: var(--ink);
  color: #e8e8e6;
  padding: clamp(2.5rem, 5vw, 3.5rem) 0;
  text-align: center;
}

.cta-strip h2 {
  color: #fff;
  margin-bottom: 0.75rem;
}

.cta-strip p {
  color: #a3a3a0;
  max-width: 32rem;
  margin: 0 auto 1.5rem;
}

.cta-strip .btn-primary {
  background: #fff;
  color: var(--ink);
}

.cta-strip .btn-primary:hover {
  background: var(--bg);
  color: var(--ink);
}

/* —— Footer —— */
.site-footer {
  background: #0c0c0c;
  color: #9c9c98;
  padding: 3rem 0 2rem;
  font-size: 0.875rem;
}

.site-footer a {
  color: #c4c4c0;
  text-decoration: none;
}

.site-footer a:hover {
  color: #fff;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}

.footer-brand p {
  margin-top: 0.75rem;
  max-width: 22rem;
  line-height: 1.5;
}

.footer-col h4 {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 1rem;
}

.footer-col ul {
  list-style: none;
}

.footer-col li {
  margin-bottom: 0.5rem;
}

details.footer-about {
  margin-top: 1.35rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  max-width: 22rem;
}

.footer-about__summary {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 0.2rem 0;
  cursor: pointer;
  user-select: none;
}

.footer-about__summary::-webkit-details-marker {
  display: none;
}

.footer-about__summary:hover {
  color: #e8e8e4;
}

.footer-about__caret {
  flex-shrink: 0;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  margin-bottom: 0.2rem;
  opacity: 0.75;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

details.footer-about[open] .footer-about__caret {
  transform: rotate(-135deg);
  margin-bottom: 0;
  margin-top: 0.2rem;
}

.footer-about__panel {
  padding-top: 0.85rem;
}

.footer-about__p {
  margin: 0 0 0.65rem;
  line-height: 1.55;
  font-size: 0.8125rem;
  color: #9c9c98;
}

.footer-about__sign {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #c4c4c0;
}

@media (prefers-reduced-motion: reduce) {
  .footer-about__caret {
    transition: none;
  }
}

.footer-bottom {
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  font-size: 0.8rem;
}

/* —— Forms —— */
.form-grid {
  display: grid;
  gap: 1rem;
}

.form-row label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
  color: var(--ink);
}

.form-row input,
.form-row select,
.form-row textarea {
  width: 100%;
  padding: 0.65rem 0.85rem;
  font-family: inherit;
  font-size: 1rem;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background: var(--surface);
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.form-feedback {
  margin-top: 1rem;
  font-size: 0.9rem;
  font-weight: 500;
  min-height: 1.5rem;
}

.form-feedback.is-ok {
  color: #166534;
}

.form-feedback.is-err {
  color: var(--accent);
}

/* —— Vertical page hero variant —— */
.page-hero {
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  border-bottom: 1px solid var(--border);
}

.page-hero__grid {
  display: grid;
  grid-template-columns: 1fr minmax(200px, 34%);
  gap: 2.5rem;
  align-items: center;
}

.split-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 3rem);
  align-items: start;
}

/* —— Responsive —— */
@media (max-width: 960px) {
  .hero__grid,
  .page-hero__grid,
  .split-block {
    grid-template-columns: 1fr;
  }

  .hero__visual,
  .htl-hero__visual {
    order: -1;
  }

  .grid-3 {
    grid-template-columns: 1fr;
  }

  .grid-2 {
    grid-template-columns: 1fr;
  }

  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin-inline: auto;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .site-header {
    --header-h: calc((3.45rem + 0.18rem + 1.05rem + 0.2rem) * var(--header-scale));
    --header-mobile-logo-w: calc(3.35rem * var(--header-scale));
    --header-mobile-burger-w: calc(2.35rem * var(--header-scale));
  }

  .site-header .header-top.container {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    /* Un solo inset orizzontale: logo e hamburger equidistanti dai bordi */
    padding-left: max(0.35rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.35rem, env(safe-area-inset-right, 0px));
  }

  .header-top {
    flex-direction: column;
    align-items: stretch;
    column-gap: 0;
  }

  /* Riga 1: 1fr | wordmark | 1fr + translate sul wordmark → stesso spazio tra bordi logo↔testo e testo↔burger; poi rifinitura ottica con --header-optical-nudge */
  .header-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: 0.35rem;
    row-gap: calc(0.18rem * var(--header-scale));
    align-items: center;
    min-height: 0;
    flex: 0 0 auto;
    width: 100%;
    padding-inline: 0;
    padding-block: 0.08rem 0.12rem;
    box-sizing: border-box;
    overflow: visible;
  }

  .brand--mark {
    grid-row: 1;
    grid-column: 1;
    justify-self: start;
    align-self: center;
    min-width: 0;
  }

  .brand__mark--header {
    width: calc(3.35rem * var(--header-scale));
    height: calc(3.35rem * var(--header-scale));
    flex-shrink: 0;
    transform: none;
  }

  .brand--wordmark {
    grid-row: 1;
    grid-column: 2;
    justify-self: center;
    align-self: center;
    min-width: 0;
    max-width: min(56vw, 100%);
    text-align: center;
    /* Uguaglia (spazio rettangolo logo → testo) e (testo → rettangolo burger): (L−H)/2 + nudge */
    transform: translateX(
      calc(
        (var(--header-mobile-logo-w) - var(--header-mobile-burger-w)) / 2 + var(--header-optical-nudge)
      )
    );
  }

  .brand--wordmark .brand__text {
    display: block;
    text-align: center;
    width: 100%;
    min-width: 0;
    font-size: clamp(calc(0.68rem * var(--header-scale)), 2.64vw, calc(0.875rem * var(--header-scale)));
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.025em;
    overflow: visible;
    text-overflow: clip;
    white-space: nowrap;
  }

  .nav-toggle {
    grid-row: 1;
    grid-column: 3;
    justify-self: end;
    align-self: center;
    margin: 0;
    padding: 0;
    display: block;
    width: calc(2.35rem * var(--header-scale));
    height: calc(2.35rem * var(--header-scale));
    flex-shrink: 0;
    transform: translateX(-10px);
  }

  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
    transform: translateY(calc(6px * var(--header-scale))) rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
    transform: translateY(calc(-6px * var(--header-scale))) rotate(-45deg);
  }

  .header-mobile-pickers {
    grid-row: 2;
    grid-column: 1;
    justify-self: start;
    display: flex;
    width: max-content;
    max-width: none;
    margin: 0;
    padding: 0;
    padding-inline-start: calc(var(--header-mobile-picker-nudge) + 10px);
    gap: calc(0.85rem * var(--header-scale));
    justify-content: flex-start;
    flex-wrap: nowrap;
    align-items: center;
  }

  .header-top > .sol-strip {
    display: none;
  }

  .header-dd {
    flex-shrink: 0;
    margin: 0;
    margin-inline: 0;
    padding: 0;
  }

  .header-dd__summary {
    max-width: none;
    margin: 0;
    margin-inline: 0;
    padding: 0.05rem 0;
    padding-inline: 0;
    font-size: 0.8rem;
  }

  .nav .nav__sol-mobile {
    display: none !important;
  }

  .nav .lang-wrap {
    display: none !important;
  }

  /* Menu fuori da .header-inner: niente buchi nel flex; chiuso = impronta zero */
  .header-top > .nav {
    position: fixed;
    left: 0;
    right: 0;
    top: var(--header-h);
    flex-direction: column;
    align-items: stretch;
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.25s, opacity 0.25s, visibility 0.25s;
    flex: 0 0 0;
    width: 100%;
    height: 0;
    min-height: 0;
    max-height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
    border: none;
    box-shadow: none;
    background: transparent;
    backdrop-filter: none;
    z-index: 110;
  }

  .header-top > .nav.is-open {
    height: auto;
    max-height: min(70vh, 520px);
    overflow-y: auto;
    padding: 1rem 1.5rem 1.5rem;
    background: rgba(250, 250, 248, 0.98);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-md);
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }

  .nav__cta {
    margin-left: 0;
    margin-top: 0.5rem;
  }

  .footer-grid {
    grid-template-columns: 1fr;
  }
}

/* —— Landing ristoranti: contenuto completo (FAQ, WhatsApp, passi) —— */
.rst-hero {
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 5rem);
  border-bottom: 1px solid var(--border);
  overflow: visible;
}

.rst-hero__grid {
  display: grid;
  grid-template-columns: 1fr minmax(240px, 38%);
  gap: clamp(2rem, 5vw, 3.5rem);
  align-items: center;
}

.rst-hero__visual {
  overflow: visible;
}

/* Hero ristoranti: stessa colonna mock di Hotel/Palestre; caption sotto */
.rst-hero-hero-mock {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.rst-eyebrow {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 0.5rem;
}

.rst-kicker {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  font-weight: 600;
  font-style: italic;
  color: var(--accent);
  margin: 0 0 1rem;
  line-height: 1.35;
  max-width: 32ch;
}

.rst-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.75rem;
}

.rst-hero__note {
  margin-top: 1.25rem;
  font-size: 0.875rem;
  color: var(--ink-muted);
}

.rst-benefits-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  list-style: none;
}

.rst-benefits-grid h3 {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
}

.rst-benefits-grid p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-muted);
}

.rst-features-wrap {
  display: block;
  max-width: 48rem;
  margin-inline: auto;
  overflow: visible;
}

.rst-feature-cards {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.rst-feature-cards h3 {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
}

.rst-feature-cards p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--ink-muted);
}

.rst-steps {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.rst-step {
  position: relative;
  padding-top: 2.25rem;
}

.rst-step-num {
  position: absolute;
  top: 1.1rem;
  left: 1.35rem;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 700;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rst-step h3 {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
}

.rst-step p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--ink-muted);
}

.faq-list-rst {
  max-width: 42rem;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.faq-item-rst {
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--surface);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.faq-trigger-rst {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.15rem;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  text-align: left;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--ink);
}

.faq-trigger-rst:hover {
  background: var(--bg-elevated);
}

.faq-icon-rst {
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  transform: rotate(45deg);
  flex-shrink: 0;
  transition: transform 0.2s;
}

.faq-trigger-rst[aria-expanded="true"] .faq-icon-rst {
  transform: rotate(-135deg);
}

.faq-panel-rst {
  padding: 0 1.15rem 1rem;
}

.faq-panel-rst p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--ink-muted);
}

.faq-panel-rst[hidden] {
  display: none;
}

.btn-whatsapp {
  background: #128c7e;
  color: #fff;
  border-color: transparent;
  box-shadow: var(--shadow-sm);
}

.btn-whatsapp:hover {
  background: #0d6b60;
  color: #fff;
}

.rst-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 1.5rem;
  align-items: start;
}

.rst-contact-note {
  margin-top: 1rem;
  font-size: 0.8rem;
  color: var(--ink-muted);
}

.rst-contact-note code {
  font-size: 0.75rem;
  background: var(--bg);
  padding: 0.15rem 0.35rem;
  border-radius: 4px;
}

@media (max-width: 960px) {
  .rst-hero__grid {
    grid-template-columns: 1fr;
  }

  .rst-hero__visual {
    order: -1;
  }

  .rst-contact-grid {
    grid-template-columns: 1fr;
  }

  .rst-benefits-grid {
    grid-template-columns: 1fr;
  }

  .rst-steps {
    grid-template-columns: 1fr;
  }
}
