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

      * {
        margin: 0;
      }

      html {
        -webkit-text-size-adjust: 100%;
        text-size-adjust: 100%;
        scroll-behavior: smooth;
      }

      body {
        min-height: 100vh;
        line-height: 1.5;
        text-rendering: optimizeLegibility;
        -webkit-font-smoothing: antialiased;
      }

      main {
        display: block;
      }

      img,
      picture,
      video,
      canvas,
      svg {
        display: block;
        max-width: 100%;
        height: auto;
      }

      input,
      button,
      textarea,
      select {
        font: inherit;
        color: inherit;
      }

      p,
      h1,
      h2,
      h3,
      h4,
      h5,
      h6,
      li {
        overflow-wrap: break-word;
      }

      h1,
      h2,
      h3,
      h4,
      h5,
      h6 {
        line-height: 1.04;
        text-wrap: balance;
      }

      a {
        color: inherit;
        text-decoration-thickness: from-font;
        text-underline-offset: 0.14em;
      }

      ul[class],
      ol[class],
      ul[role="list"],
      ol[role="list"] {
        padding: 0;
        list-style: none;
      }

      table {
        border-collapse: collapse;
        border-spacing: 0;
      }

      textarea:not([rows]) {
        min-height: 10em;
      }

      :target {
        scroll-margin-block: 5rem;
      }

      :focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
      }

      [hidden] {
        display: none !important;
      }

      input,
      textarea,
      select {
        background-color: transparent;
        border: 1px solid currentColor;
      }

      button {
        cursor: pointer;
      }

      button:disabled,
      input:disabled,
      textarea:disabled,
      select:disabled {
        cursor: not-allowed;
      }

      :root {
        --color-bg: #fff5ec;
        --color-surface: #fff5ec;
        --color-surface-strong: #ffffff;
        --color-text: #171512;
        --color-text-soft: #5e564d;
        --color-border: rgba(23, 21, 18, 0.12);
        --color-border-strong: rgba(23, 21, 18, 0.2);
        --color-accent: #7b1f29;
        --color-accent-hover: #621821;
        --color-accent-contrast: #ffffff;
        --color-focus: #111111;
        --shadow-soft: 0 18px 50px rgba(17, 17, 17, 0.04);
        --font-family-base: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
        --font-family-heading: "Old Standard TT", "Palatino Linotype", "Book Antiqua", Georgia, serif;
        --font-weight-regular: 400;
        --font-weight-medium: 500;
        --font-weight-semibold: 600;
        --font-weight-bold: 700;
        --font-style-base: normal;
        --font-width-base: 100;
        --container-width: 1220px;
        --space-inline: clamp(1rem, 2.3vw + 0.25rem, 3.6rem);
        --space-block: clamp(0.9rem, 1vw + 0.6rem, 1.2rem);
        --section-space: clamp(2.2rem, 5vw, 5rem);
        --radius-soft: 1.15rem;
        --radius-pill: 9999px;
        --border-width: 1px;
        --accent-line-width: 2px;
        --transition-fast: 0.2s ease;
        --transition-medium: 0.32s ease;
        --text-measure: 68ch;
      }

      body {
        margin: 0;
        background:
          linear-gradient(180deg, rgba(255, 255, 255, 0.45) 0%, rgba(255, 255, 255, 0) 14rem),
          var(--color-bg);
        color: var(--color-text);
        font-family: var(--font-family-base);
        font-size: clamp(1rem, 0.98rem + 0.14vw, 1.05rem);
      }

      body,
      button,
      input,
      textarea,
      select {
        font-optical-sizing: auto;
        font-style: var(--font-style-base);
        font-variation-settings: "wdth" var(--font-width-base);
      }

      ::selection {
        background: color-mix(in srgb, var(--color-accent) 16%, white);
        color: var(--color-text);
      }

      .skip-link {
        position: absolute;
        top: 0;
        left: var(--space-inline);
        transform: translateY(-140%);
        background: var(--color-text);
        color: var(--color-accent-contrast);
        padding: 0.8rem 1rem;
        border-radius: 0 0 1rem 1rem;
        text-decoration: none;
        z-index: 100;
        transition: transform var(--transition-fast);
      }

      .skip-link:focus {
        transform: translateY(0);
      }

      .site-shell {
        width: min(100%, calc(var(--container-width) + (var(--space-inline) * 2)));
        margin-inline: auto;
        padding-inline: var(--space-inline);
      }

      header {
        width: 100%;
        background-color: transparent;
        padding-top: clamp(1rem, 1.8vw, 1.7rem);
      }

      .header-top {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: clamp(1rem, 2vw, 2.4rem);
        padding-block: 0.2rem 1.15rem;
      }

      .header-top > div:first-child {
        display: flex;    
        align-items: flex-start;
        min-width: 0;
        flex-direction: column;
      }

      .header-top > div:first-child p {
        color: var(--color-text-soft);
      }

      .header-top > div:first-child p:first-child {
        justify-self: start;
      }

      .header-top > div:first-child p:nth-child(2) {
        text-align: left;
        color: var(--color-text);
      }

      .header-top > div:first-child p:last-child {
        justify-self: end;
        text-align: left;
        font-size: 0.94rem;
        letter-spacing: 0.01em;
      }

      .header-top strong {
        font-family: var(--font-family-heading);
        font-size: clamp(1.05rem, 0.94rem + 0.45vw, 1.34rem);
        font-weight: var(--font-weight-semibold);
        letter-spacing: -0.02em;
      }

      .header-top > div:last-child {
        justify-self: end;
        display: flex;
        align-items: center;
      }

      .brand-logo-link {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        color: inherit;
      }

      #main-logo {
        display: block;
        width: clamp(4.4rem, 7vw, 5.9rem);
        height: auto;
        aspect-ratio: 1 / 1;
      }

      .top-link {
        display: inline-flex;
        align-items: center;
        min-height: 2.4rem;
        padding: 0.25rem 0;
        text-decoration: none;
        color: var(--color-text-soft);
        transition: color var(--transition-fast), opacity var(--transition-fast);
      }

      .top-link:hover {
        color: var(--color-accent);
      }

      .divisor {
        position: relative;
        width: 100%;
        height: 1px;
        background: color-mix(in srgb, var(--color-text) 14%, transparent);
      }

      .divisor::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: min(9rem, 18vw);
        height: 2px;
        background: var(--color-accent);
        transform: translateY(-0.5px);
      }

      header nav[aria-label="Principal"] {
        padding-block: 1rem 0.8rem;
      }

      .primary-nav-list {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.35rem 1.1rem;
        list-style: none;
        margin: 0;
        padding: 0;
      }

      .primary-nav-list li {
        margin: 0;
        padding: 0;
      }

      a {
        transition: color var(--transition-fast), opacity var(--transition-fast), background-color var(--transition-fast), transform var(--transition-fast);
      }

      header nav[aria-label="Principal"] a {
        position: relative;
        display: inline-flex;
        align-items: center;
        min-height: 2.35rem;
        padding: 0.35rem 0.05rem;
        border-radius: 0;
        text-decoration: none;
        white-space: nowrap;
        color: var(--color-text-soft);
      }

      header nav[aria-label="Principal"] a::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0.15rem;
        height: 1px;
        background: currentColor;
        opacity: 0.4;
        transform: scaleX(0);
        transform-origin: left;
        transition: transform var(--transition-medium), opacity var(--transition-fast), background-color var(--transition-fast);
      }

      header nav[aria-label="Principal"] a:hover {
        color: var(--color-accent);
      }

      header nav[aria-label="Principal"] a:hover::after {
        opacity: 1;
        transform: scaleX(1);
      }

      header nav[aria-label="Principal"] a[aria-current="page"] {
        color: var(--color-text);
        font-weight: var(--font-weight-semibold);
      }

      header nav[aria-label="Principal"] a[aria-current="page"]::after {
        height: 2px;
        background: var(--color-accent);
        opacity: 1;
        transform: scaleX(1);
      }

      header nav[aria-label="Principal"] a:focus-visible {
        outline: 2px solid color-mix(in srgb, var(--color-accent) 60%, black);
        outline-offset: 5px;
      }

      nav[aria-label="Breadcrumb"] {
        padding-block: 0.7rem 1.15rem;
        color: var(--color-text-soft);
        font-size: 0.84rem;
        letter-spacing: 0.08em;
        text-transform: uppercase;
      }

      nav[aria-label="Breadcrumb"] a {
        text-decoration: none;
      }

      nav[aria-label="Breadcrumb"] a:hover {
        color: var(--color-accent);
      }

      nav[aria-label="Breadcrumb"] span[aria-current="page"] {
        color: var(--color-text);
        font-weight: var(--font-weight-medium);
      }

      main {
        background-color: transparent;
      }

      main > section {
        padding-block: var(--section-space);
      }

      main > section + section {
        border-top: 1px solid var(--color-border);
      }

      main > section > * {
        max-width: var(--text-measure);
      }

      main > section > * + * {
        margin-top: clamp(1rem, 1vw + 0.7rem, 1.45rem);
      }

      main > section:first-child {
        padding-top: clamp(1.6rem, 4.2vw, 4.2rem);
        padding-bottom: clamp(2.2rem, 6vw, 5rem);
      }

      main h1,
      main h2,
      main h3 {
        font-family: var(--font-family-heading);
        font-weight: var(--font-weight-semibold);
        color: var(--color-text);
      }

      main h1 {
        font-size: clamp(2.4rem, 1.4rem + 4.7vw, 5.35rem);
        letter-spacing: -0.05em;
        line-height: 0.94;
        margin-bottom: clamp(2.4rem, 1.4rem + 4.7vw, 5.35rem);
      }

      main h2 {
        font-size: clamp(1.6rem, 1.15rem + 1.45vw, 2.35rem);
        letter-spacing: -0.03em;
      }

      main h3 {
        font-size: clamp(1.16rem, 1rem + 0.5vw, 1.36rem);
      }

      main p,
      main li {
        line-height: 1.8;
        color: var(--color-text-soft);
      }

      main strong {
        color: var(--color-text);
      }

      main p {
        text-wrap: pretty;
      }

      main ul {
        padding-left: 1.35rem;
      }

      main li::marker {
        color: color-mix(in srgb, var(--color-accent) 78%, black);
      }

      main li + li {
        margin-top: 0.85rem;
      }

      main a {
        color: var(--color-text);
        text-decoration-color: color-mix(in srgb, var(--color-accent) 42%, transparent);
      }

      main a:hover {
        color: var(--color-accent);
        text-decoration-color: currentColor;
      }

      .hero-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.8rem 0.95rem;
        padding-top: 0.45rem;
      }

      .hero-actions a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 2.95rem;
        padding: 0.72rem 1.08rem;
        border: 1px solid var(--color-border-strong);
        border-radius: var(--radius-pill);
        text-decoration: none;
        background: var(--color-surface-strong);
        box-shadow: 0 1px 0 rgba(17, 17, 17, 0.04);
      }

      .hero-actions a:first-child {
        background: var(--color-accent);
        border-color: var(--color-accent);
        color: var(--color-accent-contrast);
        text-decoration: none;
      }

      .hero-actions a:first-child:hover {
        background: var(--color-accent-hover);
        border-color: var(--color-accent-hover);
        color: var(--color-accent-contrast);
      }

      .hero-actions a:not(:first-child) {
        color: var(--color-text);
      }

      .hero-actions a:not(:first-child):hover {
        color: var(--color-accent);
        background: color-mix(in srgb, var(--color-accent) 4%, white);
      }

      .hero-actions a:hover {
        transform: translateY(-1px);
      }

      footer {
        margin-top: clamp(3rem, 7vw, 5.5rem);
        padding-bottom: 1.15rem;
        background-color: transparent;
      }

      footer::before {
        content: "";
        display: block;
        width: 100%;
        height: 1px;
        background: color-mix(in srgb, var(--color-text) 16%, transparent);
        margin-bottom: 1.35rem;
      }

      .footer-inner {
        display: grid;
        gap: 1rem;
      }

      .footer-tagline {
        line-height: 1.7;
        color: var(--color-text-soft);
      }

      .footer-tagline strong {
        font-family: var(--font-family-heading);
        font-weight: var(--font-weight-semibold);
        color: var(--color-text);
      }

      .footer-links {
        display: grid;
        gap: 0.65rem;
      }

      .footer-links ul {
        display: flex;
        flex-wrap: wrap;
        gap: 0.35rem 1rem;
        list-style: none;
        padding: 0;
        margin: 0;
      }

      .footer-links a {
        display: inline-flex;
        align-items: center;
        min-height: auto;
        padding: 0.1rem 0;
        border-radius: 0;
        text-decoration: none;
        background: transparent;
        color: var(--color-text-soft);
      }

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

      .contacto-directo {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.7rem;
        color: var(--color-text-soft);
        padding-top: 0.35rem;
      }

      .contacto-directo > span:first-child {
        font-weight: var(--font-weight-medium);
        color: var(--color-text);
      }

      .contacto-directo button,
      .contacto-revelado {
        appearance: none;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 2.7rem;
        padding: 0.62rem 0.98rem;
        border: 1px solid var(--color-border-strong);
        background: transparent;
        color: var(--color-text);
        text-decoration: none;
        border-radius: var(--radius-pill);
        line-height: 1.2;
        transition: color var(--transition-fast), background-color var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);
      }

      .contacto-directo button:hover,
      .contacto-revelado:hover {
        color: var(--color-accent);
        border-color: color-mix(in srgb, var(--color-accent) 42%, var(--color-border-strong));
        background-color: color-mix(in srgb, var(--color-accent) 5%, transparent);
        transform: translateY(-1px);
      }

      .contacto-directo button:focus-visible,
      .contacto-revelado:focus-visible {
        outline: 2px solid color-mix(in srgb, var(--color-accent) 60%, black);
        outline-offset: 3px;
      }

      .contacto-directo [aria-hidden="true"] {
        color: color-mix(in srgb, var(--color-text-soft) 40%, transparent);
      }

      footer noscript {
        display: block;
      }

      footer noscript p {
        color: var(--color-text-soft);
        line-height: 1.7;
      }

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

      @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;
          scroll-behavior: auto !important;
        }
      }

      @media (max-width: 880px) {
        :root {
          --container-width: 100%;
          --text-measure: 100%;
          --section-space: clamp(1.8rem, 6vw, 2.8rem);
        }

        .header-top {
          grid-template-columns: 1fr;
          gap: 0.85rem;
          text-align: center;
          padding-bottom: 1rem;
        }

        .header-top > div:first-child {
          grid-template-columns: 1fr;
          gap: 0.4rem;
        }

        .header-top > div:first-child p,
        .header-top > div:first-child p:first-child,
        .header-top > div:first-child p:last-child {
          justify-self: center;
          text-align: center;
          max-width: 100%;
        }
        .header-top > div:first-child {align-items: center;}

        .header-top > div:last-child {
          justify-self: center;
        }

        #main-logo {
          width: clamp(4.5rem, 22vw, 5.75rem);
        }

        .divisor::after {
          left: 50%;
          transform: translate(-50%, -0.5px);
          width: 6.5rem;
        }

        header nav[aria-label="Principal"] {
          overflow: hidden;
        }

        .primary-nav-list {
          flex-wrap: nowrap;
          overflow-x: auto;
          padding-bottom: 0.45rem;
          scrollbar-width: thin;
          -webkit-overflow-scrolling: touch;
          scroll-snap-type: x proximity;
        }

        .primary-nav-list li {
          flex: 0 0 auto;
          scroll-snap-align: start;
        }

        main > section:first-child {
          padding-top: clamp(1.3rem, 4vw, 2.2rem);
          padding-bottom: clamp(1.9rem, 6vw, 3rem);
        }

        main h1 {
          max-width: 100%;
        }
      }

      @media (max-width: 640px) {
        :root {
          --space-inline: 1rem;
        }

        body {
          font-size: 1rem;
        }

        header {
          padding-top: 0.6rem;
        }

        .header-top strong {
          font-size: 1.1rem;
        }

        nav[aria-label="Breadcrumb"] {
          padding-block: 0.6rem 0.9rem;
          font-size: 0.78rem;
          letter-spacing: 0.06em;
        }
        main h1 {
          font-size: clamp(2.1rem, 8vw, 3.05rem);
          line-height: 0.96;
        }

        main h2 {
          font-size: clamp(1.34rem, 4.8vw, 1.7rem);
        }

        .hero-actions {
          flex-direction: column;
          align-items: stretch;
        }

        .hero-actions a {
          width: 100%;
        }

        .footer-links ul,
        .contacto-directo {
          gap: 0.6rem;
        }

        .footer-links a,
        .contacto-directo button,
        .contacto-revelado {
          width: 100%;
          justify-content: center;
        }

        .contacto-directo > span:first-child {
          width: 100%;
        }

        .contacto-directo [aria-hidden="true"] {
          display: none;
        }
      }
