:root {
      --bg: oklch(99% 0.004 240);
      --surface: oklch(100% 0 0);
      --fg: oklch(18% 0.03 255);
      --muted: oklch(48% 0.02 255);
      --border: oklch(90% 0.006 250);
      --navy: oklch(22% 0.06 260);
      --navy-deep: oklch(16% 0.05 260);
      --accent: oklch(62% 0.19 35);
      --accent-soft: oklch(94% 0.04 75);
      --success: oklch(52% 0.14 145);
      --warn-bg: oklch(96% 0.04 75);
      --warn-fg: oklch(38% 0.08 55);
      --radius: 14px;
      --font-display: 'Cormorant Garamond', 'Iowan Old Style', Georgia, serif;
      --font-body: 'Source Sans 3', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
      --max: 1120px;
      --header-h: 72px;
    }

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

    html { scroll-behavior: smooth; }

    body {
      font-family: var(--font-body);
      font-size: 16px;
      line-height: 1.55;
      color: var(--fg);
      background: var(--bg);
      -webkit-font-smoothing: antialiased;
    }

    html[lang="es"] .ca-only { display: none !important; }
    html[lang="ca"] .es-only { display: none !important; }

    img, svg { display: block; max-width: 100%; }

    a { color: inherit; text-decoration: none; }

    .container {
      width: min(100% - 2rem, var(--max));
      margin-inline: auto;
    }

    /* Header */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 100;
      /* background: color-mix(in oklch, var(--surface) 92%, transparent); */
      background: #ffffff;
      backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--border);
    }

    .header-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      min-height: var(--header-h);
      flex-wrap: wrap;
      padding-block: 0.5rem;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 0.75rem;
    }

    .brand-mark {
      width: 40px;
      height: 40px;
      border-radius: 10px;
      background: var(--navy);
      color: #fff;
      display: grid;
      place-items: center;
    }

    .brand-mark svg { width: 22px; height: 22px; }

    .brand-text strong {
      display: block;
      font-family: var(--font-display);
      font-size: 1.125rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1.15;
      color: var(--navy-deep);
    }

    .brand-text span {
      font-size: 0.6875rem;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--muted);
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      flex-wrap: wrap;
    }

    .lang-switch {
      display: inline-flex;
      border: 1px solid var(--border);
      border-radius: 999px;
      overflow: hidden;
      background: var(--surface);
    }

    .lang-switch button {
      border: 0;
      background: transparent;
      padding: 0.4rem 0.85rem;
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      cursor: pointer;
      color: var(--muted);
      transition: background 0.15s, color 0.15s;
    }

    .lang-switch button[aria-pressed="true"] {
      background: var(--navy);
      color: #fff;
    }

    .phone-link {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 0.875rem;
      font-weight: 600;
      letter-spacing: 0.01em;
      color: var(--navy);
    }

    .phone-link svg { width: 16px; height: 16px; flex-shrink: 0; }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      padding: 0.75rem 1.25rem;
      border-radius: 999px;
      border: 0;
      font-family: var(--font-body);
      font-size: 0.9375rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      cursor: pointer;
      transition: transform 0.12s, box-shadow 0.15s, background 0.15s;
    }

    .btn:active { transform: translateY(1px); }

    .btn-primary {
      background: var(--accent);
      color: #fff;
      box-shadow: 0 4px 14px color-mix(in oklch, var(--accent) 35%, transparent);
    }

    .btn-primary:hover {
      box-shadow: 0 6px 20px color-mix(in oklch, var(--accent) 45%, transparent);
    }

    .btn-navy {
      background: var(--navy);
      color: #fff;
    }

    .btn-navy:hover { background: var(--navy-deep); }

    .btn-ghost {
      background: transparent;
      border: 1px solid var(--border);
      color: var(--navy);
    }

    /* Hero */
    .hero {
      position: relative;
      padding: clamp(2.5rem, 6vw, 4.5rem) 0 clamp(3rem, 7vw, 5rem);
      overflow: hidden;
    }

    .hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--navy) 4%, transparent) 1px, transparent 1px),
        linear-gradient(color-mix(in oklch, var(--navy) 4%, transparent) 1px, transparent 1px),
        radial-gradient(ellipse 70% 50% at 95% 5%, color-mix(in oklch, var(--navy) 6%, transparent), transparent 55%),
        linear-gradient(180deg, oklch(97% 0.01 250) 0%, var(--bg) 100%);
      background-size: 48px 48px, 48px 48px, auto, auto;
      pointer-events: none;
      mask-image: linear-gradient(180deg, #000 0%, transparent 92%);
    }

    .hero-grid {
      position: relative;
      display: grid;
      gap: 2rem;
      align-items: center;
    }

    @media (min-width: 900px) {
      .hero-grid { grid-template-columns: 1.1fr 0.9fr; }
    }

    .hero-kicker {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--navy);
      margin-bottom: 0.75rem;
    }

    .hero h1 {
      font-family: var(--font-display);
      font-size: clamp(2.25rem, 5vw, 3.5rem);
      font-weight: 700;
      line-height: 1.08;
      letter-spacing: -0.03em;
      color: var(--navy-deep);
      max-width: 22ch;
      margin-bottom: 1rem;
    }

    .hero-lead {
      font-size: clamp(1.05rem, 2vw, 1.2rem);
      color: var(--muted);
      max-width: 52ch;
      margin-bottom: 1.5rem;
    }

    .hero-cta-row {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      margin-bottom: 1.25rem;
    }

    .hero-trust {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      font-size: 0.8125rem;
      color: var(--muted);
    }

    .hero-trust span {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
    }

    .hero-trust svg { width: 14px; height: 14px; color: var(--success); }

    .hero-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: calc(var(--radius) + 4px);
      padding: 1.5rem;
      box-shadow: 0 20px 50px color-mix(in oklch, var(--navy) 8%, transparent);
    }

    .hero-card-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 1rem;
      padding-bottom: 1rem;
      border-bottom: 1px solid var(--border);
    }

    .hero-card-head strong {
      font-family: var(--font-display);
      font-size: 1.35rem;
      color: var(--navy-deep);
    }

    .price-tag {
      font-size: 2rem;
      font-weight: 600;
      font-variant-numeric: tabular-nums;
      color: var(--navy);
      letter-spacing: -0.02em;
    }

    .price-tag small {
      font-size: 0.875rem;
      color: var(--muted);
      font-weight: 500;
    }

    .hero-card ul {
      list-style: none;
      display: grid;
      gap: 0.65rem;
    }

    .hero-card li {
      display: flex;
      gap: 0.6rem;
      font-size: 0.9375rem;
    }

    .hero-card li svg {
      width: 18px;
      height: 18px;
      flex-shrink: 0;
      margin-top: 2px;
      color: var(--navy);
    }

    /* Sections */
    section { padding: clamp(3rem, 6vw, 4.5rem) 0; }

    .section-head {
      margin-bottom: 2rem;
      max-width: 58ch;
    }

    .section-head h2 {
      font-family: var(--font-display);
      font-size: clamp(1.75rem, 3.5vw, 2.35rem);
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--navy-deep);
      margin-bottom: 0.5rem;
    }

    .section-head p { color: var(--muted); max-width: 55ch; }

    /* Pillars */
    .pillars {
      background: var(--surface);
      border-block: 1px solid var(--border);
    }

    .pillar-grid {
      display: grid;
      gap: 1rem;
    }

    @media (min-width: 768px) {
      .pillar-grid { grid-template-columns: repeat(3, 1fr); }
    }

    .pillar-card {
      padding: 1.5rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--bg);
      transition: border-color 0.15s, box-shadow 0.15s;
    }

    .pillar-card:hover {
      border-color: color-mix(in oklch, var(--navy) 25%, var(--border));
      box-shadow: 0 8px 24px color-mix(in oklch, var(--navy) 6%, transparent);
    }

    .pillar-icon {
      width: 44px;
      height: 44px;
      border-radius: 12px;
      background: color-mix(in oklch, var(--navy) 10%, var(--surface));
      color: var(--navy);
      display: grid;
      place-items: center;
      margin-bottom: 1rem;
    }

    .pillar-icon svg { width: 22px; height: 22px; }

    .pillar-card h3 {
      font-size: 1.125rem;
      font-weight: 600;
      letter-spacing: -0.01em;
      margin-bottom: 0.5rem;
      color: var(--navy-deep);
    }

    .pillar-card p {
      font-size: 0.9375rem;
      color: var(--muted);
    }

    /* Alert */
    .alert-urgency {
      display: grid;
      gap: 1rem;
      padding: 1.25rem 1.5rem;
      border-radius: var(--radius);
      background: var(--warn-bg);
      border: 1px solid color-mix(in oklch, var(--warn-fg) 22%, var(--border));
    }

    @media (min-width: 768px) {
      .alert-urgency { grid-template-columns: auto 1fr auto; align-items: center; }
    }

    .alert-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 0.6875rem;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--warn-fg);
    }

    .alert-badge svg { width: 16px; height: 16px; }

    .alert-urgency p {
      font-size: 0.9375rem;
      color: var(--warn-fg);
      max-width: 65ch;
    }

    /* Promo */
    .promo-card {
      display: grid;
      gap: 1.5rem;
      padding: clamp(1.5rem, 4vw, 2.25rem);
      border-radius: calc(var(--radius) + 2px);
      background: var(--navy-deep);
      color: #fff;
      overflow: hidden;
      position: relative;
    }

    @media (min-width: 768px) {
      .promo-card { grid-template-columns: 1fr auto; align-items: center; }
    }

    .promo-card::after {
      content: '';
      position: absolute;
      right: -10%;
      top: -30%;
      width: 280px;
      height: 280px;
      border-radius: 50%;
      background: color-mix(in oklch, var(--accent) 25%, transparent);
      pointer-events: none;
    }

    .promo-card h2 {
      font-family: var(--font-display);
      font-size: clamp(1.6rem, 3vw, 2.1rem);
      font-weight: 700;
      letter-spacing: -0.02em;
      margin-bottom: 0.5rem;
      position: relative;
    }

    .promo-card p, .promo-card small {
      position: relative;
      color: color-mix(in oklch, #fff 78%, transparent);
      font-size: 0.9375rem;
      max-width: 58ch;
    }

    .promo-card small {
      display: block;
      margin-top: 0.75rem;
      font-size: 0.8125rem;
      opacity: 0.85;
    }

    .promo-price {
      position: relative;
      text-align: center;
      padding: 1rem 1.5rem;
      border-radius: var(--radius);
      background: color-mix(in oklch, #fff 10%, transparent);
      border: 1px solid color-mix(in oklch, #fff 18%, transparent);
    }

    .promo-price .was {
      font-size: 0.875rem;
      text-decoration: line-through;
      opacity: 0.6;
    }

    .promo-price .now {
      font-size: 2.25rem;
      font-weight: 600;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.02em;
    }

    .promo-price span {
      display: block;
      font-size: 0.75rem;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-top: 0.25rem;
      opacity: 0.8;
    }

    /* Pricing */
    .pricing-grid {
      display: grid;
      gap: 1rem;
    }

    @media (min-width: 768px) {
      .pricing-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (min-width: 1100px) {
      .pricing-grid { grid-template-columns: repeat(4, 1fr); }
    }

    .license-card {
      display: flex;
      flex-direction: column;
      padding: 1.5rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--surface);
      transition: border-color 0.15s, transform 0.12s;
    }

    .license-card:hover {
      border-color: var(--navy);
      transform: translateY(-2px);
    }

    .license-card.selected {
      border-color: var(--navy);
      box-shadow: 0 0 0 2px color-mix(in oklch, var(--navy) 20%, transparent);
    }

    .license-abbr {
      font-size: 0.6875rem;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--navy);
      margin-bottom: 0.35rem;
    }

    .license-card h3 {
      font-family: var(--font-display);
      font-size: 1.35rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--navy-deep);
      margin-bottom: 0.5rem;
      line-height: 1.2;
    }

    .license-card .desc {
      font-size: 0.875rem;
      color: var(--muted);
      flex: 1;
      margin-bottom: 1rem;
    }

    .license-price {
      font-size: 1.75rem;
      font-weight: 600;
      font-variant-numeric: tabular-nums;
      color: var(--navy);
      margin-bottom: 1rem;
    }

    .license-price .note {
      display: block;
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--muted);
      margin-top: 0.15rem;
    }

    /* Booking */
    .booking-section {
      background: color-mix(in oklch, var(--navy) 4%, var(--bg));
      border-block: 1px solid var(--border);
    }

    .booking-shell {
      display: grid;
      gap: 1.5rem;
      padding: 1.5rem;
      border-radius: calc(var(--radius) + 4px);
      background: var(--surface);
      border: 1px solid var(--border);
      box-shadow: 0 16px 40px color-mix(in oklch, var(--navy) 6%, transparent);
    }

    @media (min-width: 900px) {
      .booking-shell { grid-template-columns: 1fr 1fr; padding: 2rem; }
    }

    .calendar-widget header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 1rem;
    }

    .calendar-widget h3 {
      font-size: 1rem;
      font-weight: 600;
      color: var(--navy-deep);
    }

    .cal-nav {
      display: flex;
      gap: 0.35rem;
    }

    .cal-nav button {
      width: 36px;
      height: 36px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
      cursor: pointer;
      font-size: 1.1rem;
      color: var(--navy);
    }

    .cal-nav button:hover { background: var(--border); }

    .cal-weekdays, .cal-days {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 4px;
      text-align: center;
    }

    .cal-weekdays span {
      font-size: 0.6875rem;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--muted);
      padding: 0.35rem 0;
    }

    .cal-day {
      aspect-ratio: 1;
      border: 0;
      border-radius: 8px;
      background: transparent;
      font-size: 0.875rem;
      font-weight: 500;
      cursor: pointer;
      color: var(--fg);
      font-variant-numeric: tabular-nums;
    }

    .cal-day:hover:not(:disabled) { background: color-mix(in oklch, var(--navy) 8%, transparent); }

    .cal-day.other { color: var(--muted); opacity: 0.4; }
    .cal-day.past, .cal-day:disabled { opacity: 0.3; cursor: not-allowed; }
    .cal-day.today { box-shadow: inset 0 0 0 1.5px var(--navy); }

    .cal-day.tuesday:not(:disabled)::after {
      content: '−10%';
      display: block;
      font-size: 0.5rem;
      letter-spacing: 0.04em;
      color: var(--warn-fg);
      font-weight: 600;
    }

    .cal-day.selected {
      background: var(--navy);
      color: #fff;
    }

    .cal-day.selected::after { color: #fff; }

    .slots-label {
      font-size: 0.8125rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      color: var(--muted);
      margin: 1rem 0 0.5rem;
    }

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

    @media (min-width: 480px) {
      .time-slots { grid-template-columns: repeat(4, 1fr); }
    }

    @media (min-width: 640px) {
      .time-slots { grid-template-columns: repeat(5, 1fr); }
    }

    .time-slot {
      padding: 0.5rem 0.25rem;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
      font: inherit;
      font-size: 0.8125rem;
      font-weight: 500;
      color: var(--fg);
      cursor: pointer;
      font-variant-numeric: tabular-nums;
      -webkit-appearance: none;
      appearance: none;
      -webkit-tap-highlight-color: transparent;
    }

    .time-slot:hover { border-color: var(--navy); }

    .time-slot:focus {
      outline: 2px solid color-mix(in oklch, var(--navy) 35%, transparent);
      outline-offset: 0;
      border-color: var(--navy);
    }

    .time-slot:active:not(.selected) {
      background: color-mix(in oklch, var(--navy) 8%, var(--bg));
      border-color: var(--navy);
    }

    .time-slot.selected {
      background: var(--navy);
      color: #fff;
      border-color: var(--navy);
    }

    .time-slot.selected:focus {
      outline-color: var(--navy);
    }
    .time-slot:disabled { opacity: 0.35; cursor: not-allowed; }

    .booking-form { display: grid; gap: 0.85rem; accent-color: var(--navy); }

    .booking-form label {
      display: grid;
      gap: 0.35rem;
      font-size: 0.8125rem;
      font-weight: 600;
      color: var(--navy-deep);
    }

    .booking-form input:not(.booking-privacy-input),
    .booking-form select,
    .booking-form textarea {
      padding: 0.7rem 0.85rem;
      border: 1px solid var(--border);
      border-radius: 10px;
      font: inherit;
      background: var(--bg);
      color: var(--fg);
      width: 100%;
      min-height: 2.75rem;
      line-height: 1.4;
    }

    .booking-form select {
      -webkit-appearance: none;
      appearance: none;
      padding-right: 2.5rem;
      cursor: pointer;
      background-color: var(--bg);
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%231a2332' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 0.85rem center;
      background-size: 1rem;
    }

    .booking-form input:focus,
    .booking-form select:focus,
    .booking-form textarea:focus {
      outline: 2px solid color-mix(in oklch, var(--navy) 30%, transparent);
      border-color: var(--navy);
    }

    .booking-form select:focus {
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%231a2332' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    }

    .booking-note {
      font-size: 0.8125rem;
      color: var(--muted);
      padding: 0.75rem;
      border-radius: 10px;
      background: color-mix(in oklch, var(--navy) 5%, var(--bg));
      border: 1px solid var(--border);
    }

    .booking-privacy {
      position: relative;
      display: flex !important;
      align-items: flex-start;
      gap: 0.75rem;
      cursor: pointer;
      font-size: 0.8125rem;
      font-weight: 500;
      line-height: 1.45;
      color: var(--navy-deep);
      padding: 0.85rem 1rem;
      border-radius: 10px;
      border: 1px solid var(--border);
      background: color-mix(in oklch, var(--navy) 3%, var(--bg));
      transition: border-color 0.15s ease, background 0.15s ease;
    }

    .booking-privacy:hover {
      border-color: color-mix(in oklch, var(--navy) 25%, var(--border));
    }

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

    .booking-privacy-box {
      flex-shrink: 0;
      width: 1.125rem;
      height: 1.125rem;
      margin-top: 0.1rem;
      border: 2px solid color-mix(in oklch, var(--navy) 35%, var(--border));
      border-radius: 5px;
      background: var(--bg);
      display: grid;
      place-items: center;
      transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    }

    .booking-privacy-input:focus-visible + .booking-privacy-box {
      box-shadow: 0 0 0 3px color-mix(in oklch, var(--navy) 18%, transparent);
    }

    .booking-privacy-input:checked + .booking-privacy-box {
      background: var(--navy);
      border-color: var(--navy);
    }

    .booking-privacy-input:checked + .booking-privacy-box::after {
      content: "";
      width: 0.3rem;
      height: 0.55rem;
      border: solid #fff;
      border-width: 0 2px 2px 0;
      transform: rotate(45deg) translateY(-1px);
    }

    .booking-privacy-text a {
      color: var(--navy);
      text-decoration: underline;
      text-underline-offset: 2px;
    }

    .booking-privacy-text a:hover {
      color: var(--navy-deep);
    }

    .booking-summary {
      padding: 0.85rem 1rem;
      border-radius: 10px;
      background: var(--accent-soft);
      font-size: 0.875rem;
      display: none;
    }

    .booking-summary.visible { display: block; }

    .booking-confirm {
      display: none;
      padding: 1.25rem;
      border-radius: var(--radius);
      background: color-mix(in oklch, var(--success) 12%, var(--surface));
      border: 1px solid color-mix(in oklch, var(--success) 35%, var(--border));
      text-align: center;
    }

    .booking-confirm.visible { display: block; }

    .booking-confirm strong {
      display: block;
      font-size: 1.1rem;
      color: var(--navy-deep);
      margin-bottom: 0.35rem;
    }

    /* FAQ */
    .faq-list { display: grid; gap: 0.5rem; }

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

    .faq-item button {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      padding: 1rem 1.25rem;
      border: 0;
      background: transparent;
      text-align: left;
      font: inherit;
      font-weight: 600;
      color: var(--navy-deep);
      cursor: pointer;
    }

    .faq-item button svg {
      width: 18px;
      height: 18px;
      flex-shrink: 0;
      transition: transform 0.2s cubic-bezier(0.23, 1, 0.32, 1);
    }

    .faq-item.open button svg { transform: rotate(180deg); }

    .faq-answer {
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.2s cubic-bezier(0.23, 1, 0.32, 1);
    }

    .faq-item.open .faq-answer { grid-template-rows: 1fr; }

    .faq-answer-inner {
      overflow: hidden;
      padding: 0 1.25rem;
      font-size: 0.9375rem;
      color: var(--muted);
    }

    .faq-item.open .faq-answer-inner { padding-bottom: 1rem; }

    /* Footer */
    .site-footer {
      background: var(--navy-deep);
      color: color-mix(in oklch, #fff 80%, transparent);
      padding: 2.5rem 0 1.5rem;
      font-size: 0.875rem;
    }

    .footer-grid {
      display: grid;
      gap: 1.5rem;
      margin-bottom: 2rem;
    }

    @media (min-width: 768px) {
      .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; }
    }

    .site-footer h3 {
      font-family: var(--font-display);
      font-size: 1.25rem;
      color: #fff;
      margin-bottom: 0.5rem;
    }

    .footer-legal {
      font-size: 0.8125rem;
      line-height: 1.6;
      opacity: 0.85;
    }

    .footer-links {
      list-style: none;
      display: grid;
      gap: 0.4rem;
    }

    .footer-links a {
      color: color-mix(in oklch, #fff 75%, transparent);
      text-decoration: underline;
      text-underline-offset: 3px;
    }

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

    .footer-services .footer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 0.35rem 1.25rem;
    }

    .footer-services .footer-links li {
      flex: 1 1 min(100%, 12rem);
    }

    @media (min-width: 640px) {
      .footer-services .footer-links li {
        flex: 1 1 min(50%, 12rem);
      }
    }

    .footer-bottom {
      padding-top: 1.25rem;
      border-top: 1px solid color-mix(in oklch, #fff 12%, transparent);
      font-size: 0.75rem;
      opacity: 0.65;
      text-align: center;
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0,0,0,0);
      border: 0;
    }

    /* Planner — cuándo reservar */
    .planner-section {
      background: var(--surface);
      border-block: 1px solid var(--border);
    }

    .planner-shell {
      display: grid;
      gap: 1.5rem;
      padding: 1.5rem;
      border: 1px solid var(--border);
      border-radius: calc(var(--radius) + 2px);
      background: var(--bg);
    }

    @media (min-width: 768px) {
      .planner-shell { grid-template-columns: 1fr 1.1fr; align-items: start; padding: 2rem; }
    }

    .planner-form label {
      display: grid;
      gap: 0.35rem;
      font-size: 0.8125rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      color: var(--navy-deep);
    }

    .planner-form input[type="date"] {
      padding: 0.7rem 0.85rem;
      border: 1px solid var(--border);
      border-radius: 10px;
      font: inherit;
      background: var(--surface);
      color: var(--fg);
    }

    .planner-result {
      display: none;
      margin-top: 1rem;
      padding: 1rem 1.15rem;
      border-radius: var(--radius);
      background: color-mix(in oklch, var(--navy) 6%, var(--surface));
      border: 1px solid var(--border);
      font-size: 0.9375rem;
      color: var(--fg);
    }

    .planner-result.visible { display: block; }

    .planner-result strong { color: var(--navy-deep); }

    .planner-timeline {
      display: grid;
      gap: 0;
      position: relative;
      padding-left: 1.5rem;
    }

    .planner-timeline::before {
      content: '';
      position: absolute;
      left: 5px;
      top: 8px;
      bottom: 8px;
      width: 2px;
      background: var(--border);
    }

    .planner-step {
      position: relative;
      padding: 0.65rem 0 0.65rem 1rem;
    }

    .planner-step::before {
      content: '';
      position: absolute;
      left: -1.5rem;
      top: 1rem;
      width: 10px;
      height: 10px;
      border-radius: 50%;
      background: var(--surface);
      border: 2px solid var(--navy);
    }

    .planner-step.highlight::before {
      background: var(--accent);
      border-color: var(--accent);
    }

    .planner-step span {
      display: block;
      font-size: 0.6875rem;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--muted);
      margin-bottom: 0.2rem;
    }

    .planner-step p {
      font-size: 0.875rem;
      color: var(--muted);
    }

    /* Local trust band */
    .local-band {
      background: color-mix(in oklch, var(--navy) 5%, var(--bg));
      border-block: 1px solid var(--border);
    }

    .local-chips {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      margin-top: 1rem;
    }

    .local-chip {
      padding: 0.4rem 0.85rem;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: var(--surface);
      font-size: 0.8125rem;
      font-weight: 500;
      color: var(--navy);
      letter-spacing: 0.01em;
    }

    .local-meta {
      display: grid;
      gap: 1rem;
      margin-top: 1.25rem;
    }

    @media (min-width: 600px) {
      .local-meta { grid-template-columns: repeat(2, 1fr); }
    }

    .local-meta div {
      padding: 1rem;
      border-radius: var(--radius);
      background: var(--surface);
      border: 1px solid var(--border);
      font-size: 0.875rem;
      color: var(--muted);
    }

    .local-meta strong {
      display: block;
      font-size: 0.9375rem;
      color: var(--navy-deep);
      margin-bottom: 0.25rem;
    }

    /* Sticky mobile CTA */
    .sticky-cta {
      display: none;
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 90;
      padding: 0.65rem 1rem calc(0.65rem + env(safe-area-inset-bottom, 0px));
      background: color-mix(in oklch, var(--surface) 94%, transparent);
      backdrop-filter: blur(12px);
      border-top: 1px solid var(--border);
      box-shadow: 0 -8px 24px color-mix(in oklch, var(--navy) 8%, transparent);
    }

    @media (max-width: 767px) {
      .sticky-cta { display: grid; grid-template-columns: 1fr 1.2fr; gap: 0.5rem; }
      body { padding-bottom: 4.5rem; }
    }

    .sticky-cta .btn { padding: 0.7rem 0.85rem; font-size: 0.875rem; }

    @media (max-width: 767px) {
      .sticky-cta {
        transform: translateY(100%);
        transition: transform 0.22s cubic-bezier(0.23, 1, 0.32, 1);
      }
      .sticky-cta.is-visible { transform: translateY(0); }
    }

    /* Scroll reveal */
    .reveal {
      opacity: 0;
      transform: translateY(14px);
      transition: opacity 0.32s cubic-bezier(0.23, 1, 0.32, 1), transform 0.32s cubic-bezier(0.23, 1, 0.32, 1);
    }
    .reveal.is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    @keyframes planner-in {
      from { opacity: 0; transform: translateY(8px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .planner-result.visible { animation: planner-in 0.32s cubic-bezier(0.23, 1, 0.32, 1); }

    .planner-step.active::before {
      background: var(--accent);
      border-color: var(--accent);
      box-shadow: 0 0 0 4px color-mix(in oklch, var(--accent) 25%, transparent);
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      .reveal { opacity: 1; transform: none; transition: none; }
      .planner-result.visible { animation: none; }
      .sticky-cta { transform: none; transition: none; }
      .faq-item button svg { transition: none; }
      .faq-answer { transition: none; }
    }

    /* Trust strip */
    .trust-strip {
      border-block: 1px solid var(--border);
      background: var(--surface);
      padding: 1rem 0;
    }
    .trust-strip-inner {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      gap: 1rem 1.75rem;
    }
    .trust-item {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.8125rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      color: var(--navy);
    }
    .trust-item svg {
      width: 18px;
      height: 18px;
      flex-shrink: 0;
      color: var(--success);
    }

    .promo-actions {
      position: relative;
      margin-top: 0.85rem;
      width: 100%;
    }
    .promo-actions .btn { width: 100%; }

    /* Cookie bar */
    .cookie-bar {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 110;
      padding: 1rem;
      background: var(--navy-deep);
      color: color-mix(in oklch, #fff 85%, transparent);
      border-top: 1px solid color-mix(in oklch, #fff 12%, transparent);
      transform: translateY(100%);
      transition: transform 0.25s cubic-bezier(0.23, 1, 0.32, 1);
    }
    .cookie-bar.visible { transform: translateY(0); }
    .cookie-bar-inner {
      width: min(100% - 2rem, var(--max));
      margin-inline: auto;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: space-between;
      gap: 0.75rem;
      font-size: 0.8125rem;
    }
    .cookie-bar p { max-width: 52ch; line-height: 1.5; }
    .cookie-bar-actions { display: flex; gap: 0.5rem; flex-shrink: 0; }
    .cookie-bar .btn { padding: 0.55rem 1rem; font-size: 0.8125rem; }

    @media (max-width: 767px) {
      body.has-cookie .sticky-cta { display: none; }
      body.has-cookie { padding-bottom: 5.5rem; }
    }

    .form-error {
      display: none;
      padding: 0.65rem 0.85rem;
      border-radius: 8px;
      background: color-mix(in oklch, oklch(55% 0.2 25) 10%, var(--surface));
      border: 1px solid color-mix(in oklch, oklch(55% 0.2 25) 30%, var(--border));
      font-size: 0.8125rem;
      color: oklch(42% 0.12 25);
    }
    .form-error.visible { display: block; }

    .skip-link {
      position: absolute;
      left: -9999px;
      top: 0;
      z-index: 200;
      padding: 0.5rem 1rem;
      background: var(--navy);
      color: #fff;
      border-radius: 0 0 8px 0;
      font-weight: 600;
    }
    .skip-link:focus { left: 0; }

    /* Compare */
    .compare-grid {
      display: grid;
      gap: 1rem;
    }
    @media (min-width: 768px) {
      .compare-grid { grid-template-columns: 1fr 1fr; }
    }
    .compare-col {
      padding: 1.25rem 1.35rem;
      border-radius: var(--radius);
      border: 1px solid var(--border);
      background: var(--surface);
    }
    .compare-col.negative {
      background: color-mix(in oklch, oklch(55% 0.12 25) 4%, var(--bg));
      border-color: color-mix(in oklch, oklch(55% 0.12 25) 18%, var(--border));
    }
    .compare-col.positive {
      border-color: color-mix(in oklch, var(--navy) 25%, var(--border));
      box-shadow: 0 8px 28px color-mix(in oklch, var(--navy) 6%, transparent);
    }
    .compare-col h3 {
      font-family: var(--font-display);
      font-size: 1.2rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--navy-deep);
      margin-bottom: 0.75rem;
    }
    .compare-col ul {
      list-style: none;
      display: grid;
      gap: 0.55rem;
      font-size: 0.9375rem;
      color: var(--muted);
    }
    .compare-col li {
      display: flex;
      gap: 0.5rem;
      align-items: flex-start;
    }
    .compare-col li svg {
      width: 16px;
      height: 16px;
      flex-shrink: 0;
      margin-top: 3px;
    }
    .compare-col.negative li svg { color: oklch(48% 0.14 25); }
    .compare-col.positive li svg { color: var(--success); }

    /* Testimonials */
    .testimonial-strip {
      background: var(--navy-deep);
      color: color-mix(in oklch, #fff 82%, transparent);
      padding: 2rem 0;
    }
    .testimonial-grid {
      display: grid;
      gap: 1rem;
    }
    @media (min-width: 768px) {
      .testimonial-grid { grid-template-columns: repeat(3, 1fr); }
    }
    .testimonial-card {
      padding: 1.15rem 1.25rem;
      border-radius: var(--radius);
      background: color-mix(in oklch, #fff 6%, transparent);
      border: 1px solid color-mix(in oklch, #fff 12%, transparent);
      font-size: 0.875rem;
      line-height: 1.55;
    }
    .testimonial-card blockquote {
      font-style: normal;
      margin-bottom: 0.65rem;
    }
    .testimonial-card cite {
      display: block;
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      font-style: normal;
      color: color-mix(in oklch, #fff 55%, transparent);
    }

    /* Legal modals */
    .modal-backdrop {
      position: fixed;
      inset: 0;
      z-index: 150;
      background: color-mix(in oklch, var(--navy-deep) 55%, transparent);
      backdrop-filter: blur(4px);
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.2s cubic-bezier(0.23, 1, 0.32, 1), visibility 0.2s;
    }
    .modal-backdrop.open {
      opacity: 1;
      visibility: visible;
    }
    .legal-modal {
      position: fixed;
      inset: 1rem;
      z-index: 151;
      margin: auto;
      max-width: 640px;
      max-height: min(85vh, 720px);
      overflow: auto;
      background: var(--surface);
      border: none;
      border-radius: calc(var(--radius) + 2px);
      outline: none;
      box-shadow: 0 24px 60px color-mix(in oklch, var(--navy) 25%, transparent);
      padding: 1.5rem;
      opacity: 0;
      transform: translateY(12px) scale(0.98);
      visibility: hidden;
      transition: opacity 0.22s cubic-bezier(0.23, 1, 0.32, 1), transform 0.22s cubic-bezier(0.23, 1, 0.32, 1), visibility 0.22s;
    }
    .legal-modal.open {
      opacity: 1;
      transform: translateY(0) scale(1);
      visibility: visible;
    }
    .legal-modal header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 1rem;
      margin-bottom: 1rem;
      padding-bottom: 0.85rem;
      border-bottom: 1px solid var(--border);
    }
    .legal-modal h2 {
      font-family: var(--font-display);
      font-size: 1.35rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--navy-deep);
    }
    .modal-close {
      width: 36px;
      height: 36px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
      cursor: pointer;
      font-size: 1.25rem;
      line-height: 1;
      color: var(--navy);
      flex-shrink: 0;
    }
    .legal-modal .legal-body {
      font-size: 0.875rem;
      color: var(--muted);
      line-height: 1.65;
    }
    .legal-modal .legal-body h3 {
      font-size: 0.9375rem;
      font-weight: 600;
      color: var(--navy-deep);
      margin: 1rem 0 0.35rem;
    }
    .legal-modal .legal-body p { margin-bottom: 0.65rem; }

    .booking-confirm-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      justify-content: center;
      margin-top: 0.85rem;
    }
    .booking-confirm-actions .btn { font-size: 0.8125rem; padding: 0.6rem 1rem; }

    @media (prefers-reduced-motion: reduce) {
      .modal-backdrop, .legal-modal { transition: none; }
    }

    /* Legal pages */
    .legal-page {
      padding: clamp(2.5rem, 5vw, 3.5rem) 0 3rem;
    }

    .legal-doc {
      display: flex;
      flex-direction: column;
      gap: 2.25rem;
    }

    .legal-doc-head {
      padding-bottom: 1.5rem;
      border-bottom: 1px solid var(--border);
    }

    .legal-doc-head h1 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 2.75rem);
      font-weight: 700;
      letter-spacing: -0.03em;
      color: var(--navy-deep);
      margin: 0 0 0.5rem;
    }

    .legal-doc-head p {
      color: var(--muted);
      font-size: 1.05rem;
      margin: 0;
    }

    .legal-section {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      padding: 0;
    }

    .legal-section h2 {
      font-family: var(--font-display);
      font-size: 1.35rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--navy-deep);
      margin: 0;
    }

    .legal-section p,
    .legal-section li {
      font-size: 1rem;
      color: var(--muted);
      line-height: 1.6;
      margin: 0;
    }

    .legal-section a {
      color: var(--navy);
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .legal-section a:hover { color: var(--navy-deep); }

    .legal-list {
      list-style: disc;
      padding-left: 1.25rem;
      margin: 0;
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
    }

    .legal-dl {
      display: grid;
      gap: 1rem;
      margin: 0;
    }

    .legal-dl dt {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--navy);
      margin: 0;
    }

    .legal-dl dd {
      font-size: 1rem;
      color: var(--muted);
      line-height: 1.6;
      margin: 0;
    }

    .legal-dl a {
      color: var(--navy);
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .legal-table-wrap {
      overflow-x: auto;
      margin-top: 0.75rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
    }

    .legal-table {
      width: 100%;
      border-collapse: collapse;
      font-size: 0.875rem;
    }

    .legal-table th,
    .legal-table td {
      padding: 0.75rem 0.85rem;
      text-align: left;
      border-bottom: 1px solid var(--border);
      vertical-align: top;
    }

    .legal-table th {
      background: color-mix(in oklch, var(--navy) 5%, var(--bg));
      font-weight: 600;
      color: var(--navy-deep);
    }

    .legal-table tr:last-child td { border-bottom: 0; }

    .legal-table code {
      font-size: 0.8125rem;
      background: color-mix(in oklch, var(--navy) 6%, var(--bg));
      padding: 0.15rem 0.4rem;
      border-radius: 6px;
      color: var(--navy-deep);
    }

    .legal-page-footer {
      border-top: 1px solid var(--border);
      background: var(--surface);
      padding: 1.5rem 0 2rem;
      margin-top: 1rem;
    }

    .legal-page-nav {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem 1.25rem;
      margin-bottom: 0.85rem;
    }

    .legal-page-nav a {
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--navy);
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .legal-page-copy {
      font-size: 0.75rem;
      color: var(--muted);
    }

    /* Site nav */
    .site-nav {
      display: none;
      align-items: center;
      gap: 1rem;
    }
    @media (min-width: 900px) {
      .site-nav { display: flex; }
    }
    .site-nav a, .nav-dropdown summary {
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--navy);
      cursor: pointer;
      list-style: none;
    }
    .nav-dropdown summary::-webkit-details-marker { display: none; }
    .nav-dropdown { position: relative; }
    .nav-dropdown-menu {
      position: absolute;
      top: 100%;
      left: 0;
      min-width: 280px;
      margin: 0.5rem 0 0;
      padding: 0.5rem 0;
      list-style: none;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      z-index: 200;
    }
    .nav-dropdown:not([open]) .nav-dropdown-menu { display: none; }
    .nav-dropdown-menu a {
      display: block;
      padding: 0.5rem 1rem;
      font-weight: 500;
      text-decoration: none;
    }
    .nav-dropdown-menu a:hover { background: var(--bg); }

    /* Inner pages */
    .inner-hero { padding-block: 2.5rem 2rem; }
    .inner-page .reveal { opacity: 1; transform: none; }
    .inner-page .prose { max-width: 68ch; line-height: 1.65; }

    /* Service pages use the same container width as header/footer */
    .service-page .prose,
    .service-page .section-head,
    .service-page .section-head p,
    .service-page .hero h1,
    .service-page .hero-lead,
    .service-page .service-when,
    .service-page .service-faq-list { max-width: none; }

    /* Guide pages use the same container width as header/footer */
    .guide-page .prose,
    .guide-page .guide-dek { max-width: none; }
    .guides-page .guides-page-intro { max-width: none; }
    .inner-page .prose h2 {
      font-family: var(--font-display);
      font-size: clamp(1.35rem, 2.5vw, 1.75rem);
      font-weight: 700;
      color: var(--navy-deep);
      margin: 0 0 0.75rem;
    }
    .inner-page .prose ul,
    .inner-page .prose ol { margin: 1rem 0; padding-left: 1.25rem; }
    .service-breadcrumb { padding-top: 1rem; font-size: 0.875rem; color: var(--muted); }
    .service-breadcrumb ol { display: flex; flex-wrap: wrap; gap: 0.35rem 0.5rem; list-style: none; padding: 0; margin: 0; }
    .service-breadcrumb li:not(:last-child)::after { content: '/'; margin-left: 0.5rem; color: var(--border); }
    .service-breadcrumb a { color: var(--navy); text-decoration: underline; text-underline-offset: 2px; }
    .service-section { padding-block: clamp(2rem, 4vw, 3rem); }
    .service-section.pillars { background: var(--surface); border-block: 1px solid var(--border); }
    .service-intro { font-size: 1.0625rem; }
    .service-steps { display: grid; gap: 0.65rem; }
    .service-steps li { padding-left: 0.25rem; }
    .service-facts {
      display: grid;
      gap: 0.75rem;
      margin: 0 0 1.25rem;
      padding: 0;
    }
    @media (min-width: 640px) {
      .service-facts { grid-template-columns: repeat(2, 1fr); }
    }
    .service-facts > div {
      padding: 1rem 1.1rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--surface);
    }
    .service-facts dt {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--muted);
      margin-bottom: 0.25rem;
    }
    .service-facts dd { margin: 0; font-weight: 500; color: var(--navy-deep); }
    .service-when {
      max-width: 68ch;
      color: var(--muted);
      font-size: 0.9375rem;
    }
    .service-categories {
      display: grid;
      gap: 1rem;
    }
    @media (min-width: 640px) {
      .service-categories { grid-template-columns: repeat(3, 1fr); }
    }
    .service-category-card {
      padding: 1.25rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--bg);
    }
    .service-category-abbr {
      display: inline-block;
      font-size: 0.75rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 0.5rem;
    }
    .service-category-card h3 {
      font-size: 1.0625rem;
      font-weight: 600;
      color: var(--navy-deep);
      margin-bottom: 0.35rem;
    }
    .service-category-card p { font-size: 0.875rem; color: var(--muted); }
    .service-faq-list { display: grid; gap: 0.5rem; max-width: 72ch; }
    .service-faq-item {
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--surface);
      overflow: hidden;
    }
    .service-faq-item summary {
      padding: 1rem 1.1rem;
      font-weight: 600;
      color: var(--navy-deep);
      cursor: pointer;
      list-style: none;
    }
    .service-faq-item summary::-webkit-details-marker { display: none; }
    .service-faq-answer {
      padding: 0 1.1rem 1rem;
      color: var(--muted);
      font-size: 0.9375rem;
      border-top: 1px solid var(--border);
    }
    .service-faq-answer p { margin: 0.75rem 0 0; }
    .service-related-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 0.5rem;
    }
    @media (min-width: 640px) {
      .service-related-list { grid-template-columns: repeat(2, 1fr); }
    }
    .service-related-list a {
      display: block;
      padding: 0.75rem 1rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      font-weight: 600;
      color: var(--navy);
      background: var(--surface);
      transition: border-color 0.15s, background 0.15s;
    }
    .service-related-list a:hover {
      border-color: color-mix(in oklch, var(--navy) 25%, var(--border));
      background: var(--bg);
    }
    .service-cta-band {
      background: color-mix(in oklch, var(--navy) 6%, var(--bg));
      border-top: 1px solid var(--border);
      padding-block: clamp(2.5rem, 5vw, 3.5rem);
      text-align: center;
    }
    .service-cta-band h2 {
      font-family: var(--font-display);
      font-size: clamp(1.5rem, 3vw, 2rem);
      color: var(--navy-deep);
      margin-bottom: 0.5rem;
    }
    .service-cta-band p { color: var(--muted); margin-bottom: 1.25rem; }
    .service-cta-band .hero-cta-row { justify-content: center; }
    .guide-list { list-style: none; padding: 0; margin: 1.5rem 0; }
    .guide-list li { margin-bottom: 0.75rem; }
    .guide-list a {
      display: block;
      padding: 0.75rem 1rem;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      font-weight: 600;
      color: var(--navy);
      background: var(--surface);
      text-decoration: none;
      transition: border-color 0.15s, background 0.15s;
    }
    .guide-list a:hover {
      border-color: color-mix(in oklch, var(--navy) 25%, var(--border));
      background: var(--bg);
    }

    /* Guides index & article pages */
    .guides-page-head {
      padding-block: 1.25rem 0.25rem;
    }
    .guides-page-head h1 {
      font-family: var(--font-display);
      font-size: clamp(1.75rem, 3.5vw, 2.25rem);
      font-weight: 700;
      color: var(--navy-deep);
      margin-bottom: 0.5rem;
    }
    .guides-page-intro {
      color: var(--muted);
      max-width: 55ch;
      line-height: 1.6;
    }
    .guide-article-header {
      padding-block: 1.25rem 0.5rem;
    }
    .guide-article-header h1 {
      font-family: var(--font-display);
      font-size: clamp(1.75rem, 3.5vw, 2.35rem);
      font-weight: 700;
      line-height: 1.15;
      color: var(--navy-deep);
      max-width: none;
    }
    .guide-dek {
      font-size: 1.05rem;
      line-height: 1.6;
      color: var(--muted);
      margin-top: 0.75rem;
      max-width: 65ch;
    }
    .guides-section {
      padding-block: 1.25rem clamp(2rem, 4vw, 3rem);
    }
    .guide-related {
      background: var(--surface);
      border-block: 1px solid var(--border);
    }
    .guides-grid {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 1rem;
    }
    @media (min-width: 640px) {
      .guides-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (min-width: 960px) {
      .guides-grid:not(.guides-grid-compact) { grid-template-columns: repeat(3, 1fr); }
    }
    .guide-card {
      display: flex;
      flex-direction: column;
      height: 100%;
      padding: 1.25rem 1.3rem 1.1rem;
      border: 1px solid var(--border);
      border-left: 3px solid var(--accent);
      border-radius: var(--radius);
      background: var(--surface);
      color: var(--fg);
      text-decoration: none;
      cursor: pointer;
      transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    }
    .guide-card:hover {
      border-color: color-mix(in oklch, var(--navy) 22%, var(--border));
      border-left-color: var(--accent);
      background: var(--bg);
      box-shadow: 0 8px 24px color-mix(in oklch, var(--navy) 5%, transparent);
    }
    .guide-card:focus-visible {
      outline: 2px solid var(--navy);
      outline-offset: 2px;
    }
    .guide-card-date {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--muted);
      margin-bottom: 0.65rem;
    }
    .guide-card h3 {
      font-family: var(--font-display);
      font-size: 1.2rem;
      font-weight: 700;
      line-height: 1.25;
      color: var(--navy);
      text-decoration: underline;
      text-decoration-color: color-mix(in oklch, var(--navy) 30%, transparent);
      text-underline-offset: 3px;
      margin-bottom: 0.5rem;
    }
    .guide-card:hover h3 {
      text-decoration-color: var(--navy);
    }
    .guide-card-excerpt {
      flex: 1;
      font-size: 0.9rem;
      line-height: 1.55;
      color: var(--muted);
      margin-bottom: 1rem;
      display: -webkit-box;
      -webkit-line-clamp: 3;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .guide-card-action {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.5rem;
      margin-top: auto;
      padding-top: 0.85rem;
      border-top: 1px solid var(--border);
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--navy);
    }
    .guide-card-action svg {
      width: 1.1rem;
      height: 1.1rem;
      flex-shrink: 0;
      transition: transform 0.15s;
    }
    .guide-card:hover .guide-card-action svg {
      transform: translateX(3px);
    }
    .guide-meta {
      font-size: 0.875rem;
      color: var(--muted);
      margin-bottom: 0.75rem;
    }
    .guide-body-section {
      padding-block: 0 clamp(2.5rem, 5vw, 3.5rem);
    }
    .guide-body-section .prose p {
      font-size: 1.0625rem;
      margin-bottom: 1.5rem;
    }
    .guide-inline-cta {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      margin-top: 0.5rem;
    }
    /* WhatsApp floating button */
    .whatsapp-float {
      position: fixed;
      bottom: 1.25rem;
      right: 1.25rem;
      z-index: 95;
      display: grid;
      place-items: center;
      width: 3.5rem;
      height: 3.5rem;
      border-radius: 50%;
      background: #25d366;
      color: #fff;
      box-shadow: 0 4px 16px color-mix(in oklch, #25d366 40%, transparent);
      transition: transform 0.2s cubic-bezier(0.23, 1, 0.32, 1), box-shadow 0.2s;
    }
    .whatsapp-float:hover {
      transform: scale(1.06);
      box-shadow: 0 6px 24px color-mix(in oklch, #25d366 50%, transparent);
    }
    .whatsapp-float svg {
      width: 1.65rem;
      height: 1.65rem;
    }
    .whatsapp-float span {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }
    @media (max-width: 767px) {
      .whatsapp-float {
        bottom: calc(4.75rem + env(safe-area-inset-bottom, 0px));
      }
    }

    .datos-table { width: 100%; border-collapse: collapse; margin: 1rem 0 2rem; font-size: 0.9375rem; }
    .datos-table th, .datos-table td { border: 1px solid var(--border); padding: 0.6rem 0.75rem; text-align: left; }
    .datos-table th { background: var(--bg); width: 30%; }
    .license-card .license-info { margin-bottom: 0.5rem; }
    .license-card .btn { margin-top: auto; }