/* ==========================================================================
   Base & Variables OK
   ========================================================================== */

@font-face {
  font-family: "Default";
  src: url("https://cdn.bicgraphic.com/landing/assets/fonts/Default.ttf")
    format("truetype");
  font-weight: normal;
}

@font-face {
  font-family: "Default";
  src: url("https://cdn.bicgraphic.com/landing/assets/fonts/Default-Bold.ttf")
    format("truetype");
  font-weight: bold;
}

@font-face {
  font-family: "Handwritten";
  src: url("https://cdn.bicgraphic.com/landing/assets/fonts/Handwritten.ttf")
    format("truetype");
  font-weight: normal;
}

@font-face {
  font-family: "Handwritten";
  src: url("https://cdn.bicgraphic.com/landing/assets/fonts/Handwritten-Bold.ttf")
    format("truetype");
  font-weight: bold;
}

:root {
  --button-text-color: #ffffff;
  --gradient-start: #ffc94e;
  --gradient-mid: #ff8a4e;
  --gradient-end: #ff4e4e;
  --section-scale: 1;
  --localized-img-circle-bge: url("https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_02-circulo-bge.svg");
  --localized-img-joy-circle: url("https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_11-frase-circulo-joy.svg");
  --localized-img-simplicity-circle: url("https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_12-frase-circulo-simplicity.svg");
  --localized-img-become-green: url("https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_31-dibujo-distributor2-verde.png");
  --localized-img-mybrand-red: url("https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_32-dibujo-account-rojo.png");
}

/* @media (max-width: 1200px), (max-height: 900px) {
  :root {
    --section-scale: 0.96;
  }
}

@media (max-width: 1024px), (max-height: 800px) {
  :root {
    --section-scale: 0.92;
  }
}

@media (max-width: 900px), (max-height: 720px) {
  :root {
    --section-scale: 0.88;
  }
}

@media (max-width: 768px), (max-height: 650px) {
  :root {
    --section-scale: 0.84;
  }
} */

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

/* Ara pots usar aquestes fonts */
html,
body {
  height: 100%;
}

body.use-global-custom-cursor,
body.use-global-custom-cursor * {
  cursor: none !important;
}

.global-custom-cursor {
  position: fixed;
  left: 0;
  top: 0;
  width: 44px;
  height: 44px;
  pointer-events: none;
  z-index: 9998;
  opacity: 0;
  transform: translate(-9999px, -9999px);
}

.global-custom-cursor.is-hidden {
  opacity: 0 !important;
}

.global-custom-cursor img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body {
  font-family: "Default", sans-serif;
  background-color: #f0e9e4;
  overflow-x: hidden;
  top: 70px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

body.smooth-enabled {
  overflow: hidden;
}

#smooth-wrapper {
  position: relative;
  width: 100%;
}

#smooth-content {
  width: 100%;
  overflow: visible;
  padding-bottom: 60px;
}

body.smooth-enabled #smooth-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.snap-container {
  width: 100%;
  max-width: 1300px;
  margin: 70px auto 0;
}

.handwritten {
  font-family: "Handwritten", cursive;
}

.text-taronja {
  color: #fe7301;
}

h1,
h2 {
  position: relative;
  z-index: 10;
  text-align: center;
  padding: 0 20px;
}

h1 {
  font-size: 3rem;
  margin-bottom: 1rem;
}

h2 {
  font-size: clamp(30px, 6vh, 60px) !important;
  font-weight: bold !important;
  letter-spacing: -1.1px;
}

/* Extra tracking for key section titles (desktop/mobile), excluding BIC Graphic brings joy */
h2[data-i18n="cocreate-with"],
h2[data-i18n="who-are-we"],
h2[data-i18n="cocreate-with-us"],
h2[data-i18n="also-means-cocreate-with"],
h2[data-i18n="co-create-a-better-future"],
h2[data-i18n="latest-novelties"],
h2[data-i18n="feeling-inspired"],
h2[data-i18n="contact-us"] {
  letter-spacing: -0.2px !important;
}

p {
  max-width: 600px;
  text-align: center;
  color: #000;
  line-height: 1.6;
  z-index: 10;
}

@media (max-width: 768px) {
  h1 {
    font-size: 2rem;
  }
}

/* ==========================================================================
   Layout OK
   ========================================================================== */

header {
  display: flex;
  justify-content: center;
  background-color: #fff;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  padding: 0 20px;
  position: fixed;
  z-index: 1000;
  height: 70px;
  width: 100%;
}

header #header-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0 20px;
  max-width: 1300px;
}

header #logo {
  height: auto;
  max-height: 32px;
  width: auto;
  margin: 18px 20px;
}

#lang,
.header-center,
#buttons {
  display: flex;
  align-items: center;
}

#lang {
  justify-content: flex-start;
  gap: 8px;
}

.header-center {
  justify-content: center;
}

#buttons {
  justify-content: flex-end;
}

#lang .js-language-toggle-desktop {
  color: #000;
  background: none;
  border: none;
  font: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

#lang .js-language-toggle-desktop .flag-icon {
  width: 20px;
  height: auto;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15);
}

.language-dropdown-wrapper {
  position: relative;
}

.language-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  width: 250px;
  background: #fff;
  border: 1px solid #e7e7e7;
  border-radius: 12px;
  padding: 10px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  gap: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    visibility 0.2s ease;
  z-index: 2100;
}

.language-dropdown.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.language-dropdown__item {
  width: 100%;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  background: #fff;
  color: #111;
  padding: 9px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  cursor: pointer;
  text-align: left;
}

.language-dropdown__item:hover {
  background: #f7f7f7;
  border-color: #d9d9d9;
}

.language-dropdown__item .flag-icon {
  width: 22px;
  height: 16px;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.12);
  flex-shrink: 0;
}

/* SCROLL SNAP CONTAINER */
/* .snap-container {
  height: calc(100vh - 67px);
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
} */
/* Ara el scroll és del body, no d'aquest contenidor */
.snap-container {
  /* height: calc(100vh - 67px); */
  /* overflow-y: auto; */
}

section {
  height: auto;
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  margin: auto;
  padding: 0 20px;
}

footer {
  position: relative;
  z-index: 5;
  padding-bottom: 90px;
}

footer p {
  max-width: none;
}

.footer-copyright {
  position: relative;
  z-index: 6;
  margin-top: 16px;
  padding-bottom: 10px;
  color: #000;
}

/* Scale content on smaller screens (except hero + video-stories text) */
/* section:not(.hero-section):not(.video-stories-section) {
  transform: scale(var(--section-scale));
  transform-origin: top center;
} */

/* ==========================================================================
   Components: Buttons
   ========================================================================== */

.animated-gradient-button {
  padding: 9px 24px;
  border: none;
  border-radius: 9999px;
  cursor: pointer;
  outline: none;
  transition: all 0.3s ease;
  display: inline-block;
  color: var(--button-text-color);
  font-weight: bold;
  text-transform: uppercase;
  background: linear-gradient(
    90deg,
    var(--gradient-start),
    var(--gradient-mid),
    var(--gradient-end),
    var(--gradient-start)
  );
  background-size: 400% 100%;
  animation: moveGradient 4s linear infinite;
  text-decoration: none;
  line-height: 1;
}

.animated-gradient-button:hover {
  box-shadow: 0 0px 15px 0px rgba(255, 78, 78, 0.7);
}

.ecommerce-dropdown-wrapper {
  position: relative;
}

.ecommerce-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: min(860px, 92vw);
  background: #fff;
  border: 1px solid #e7e7e7;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    visibility 0.2s ease;
  z-index: 2000;
  max-height: 70vh;
  overflow: auto;
}

.ecommerce-dropdown.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ecommerce-dropdown-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  gap: 10px 18px;
}

.ecommerce-dropdown-list a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid #e6e6e6;
  border-radius: 6px;
  text-decoration: none;
  color: #111;
  font-size: 14px;
  font-weight: 500;
  background: #fff;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease;
}

.ecommerce-dropdown-list a:hover {
  background: #f7f7f7;
  border-color: #d9d9d9;
  transform: translateY(-1px);
}

.ecommerce-dropdown-list .flag-icon {
  width: 22px;
  height: 16px;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.12);
  flex-shrink: 0;
}

.flag-icon-cis {
  background-image: url("https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.5.0/flags/4x3/eu.svg");
}

.flag-icon-mea {
  background-image: url("https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.5.0/flags/4x3/un.svg");
}

@media (max-width: 1024px) {
  .ecommerce-dropdown-list {
    grid-template-columns: repeat(2, minmax(170px, 1fr));
  }
  .follow-us-trazado a img {
    width: 20px !important;
    height: 20px !important;
  }

  footer a {
    font-size: 14px;
  }

  footer > div {
    gap: 10px !important;
  }

  .logo-footer-desktop {
    max-width: 150px;
  }
}

body.lang-de footer img[src*="BGE_Landing_Flecha_Footer_BIC-web"] {
  position: absolute !important;
  bottom: 50px !important;
  min-width: 114px !important;
  left: -30px !important;
}

body.lang-it footer img[src*="it/BGE_Landing_Flecha_Footer_BIC-web"] {
  position: absolute !important;
  bottom: 50px !important;
  min-width: 100px !important;
  left: -20px !important;
}

@media (min-width: 769px) {
  body.lang-es
    footer
    img[src*="es/BGE_Landing_Flecha_Footer_BIC-web.png"]:not(
      .mobile-footer__bic-arrow
    ) {
    position: absolute !important;
    bottom: 50px !important;
    min-width: 130px !important;
    left: -20px !important;
  }
}

@media (min-width: 1181px) {
  body.lang-nl
    footer
    img[src*="nl/BGE_Landing_Flecha_Footer_BIC-web.png"]:not(
      .mobile-footer__bic-arrow
    ) {
    position: absolute !important;
    bottom: 50px !important;
    min-width: 140px !important;
    left: -10px !important;
  }
}

body.lang-en
  footer
  img[src*="en/BGE_Landing_Flecha_Footer_BIC-web.svg"]:not(
    .mobile-footer__bic-arrow
  ) {
  position: absolute !important;
  bottom: 50px !important;
  min-width: 140px !important;
  left: -30px !important;
}

@media (max-width: 640px) {
  .ecommerce-dropdown {
    left: 50%;
    right: auto;
    transform: translate(-50%, 10px);
  }

  .ecommerce-dropdown.is-open {
    transform: translate(-50%, 0);
  }

  .ecommerce-dropdown-list {
    grid-template-columns: 1fr;
  }
}

.border-button {
  padding: 8px 20px;
  border: none;
  border-radius: 9999px;
  cursor: pointer;
  outline: none;
  transition: all 0.3s ease;
  color: var(--gradient-mid);
  font-size: 1rem;
  font-weight: 500;
  text-transform: uppercase;
  background-size: 400% 100%;
  text-decoration: none;
  border: 1px solid var(--gradient-mid);
}

.border-button:hover {
  background-color: var(--gradient-mid);
  color: white;
}

@keyframes moveGradient {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

/* ==========================================================================
   Components: Media OK
   ========================================================================== */

.video-container {
  position: relative;
  width: 100%;
  margin-bottom: 100px;
  margin-top: 30px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 30px;
}

iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* ==========================================================================
   Section 1: Hero OK
   ========================================================================== */

.hero-section {
  background: #f0e9e4;
  --hero-gap-top: clamp(8px, 1.6vmin, 20px);
  --hero-gap-bottom: clamp(34px, 4.8vmin, 64px);
  --hero-arrow-size: clamp(40px, 8vmin, 96px);
  --hero-arrow-bottom: calc(var(--hero-gap-bottom) - (var(--hero-arrow-size) * 0.5));
  --hero-scroll-offset: clamp(34px, 4.6vmin, 48px);
  --hero-header-offset: clamp(40px, 5vmin, 58px);
  --hero-video-height-reduction: 50px;
  --hero-side-gutter: 0px;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: var(--hero-gap-top) 0 var(--hero-gap-bottom);
  box-sizing: border-box;
}

@media (min-width: 769px) {
  .hero-section {
    --hero-side-gutter: clamp(32px, 4vw, 72px);
  }
}

.scroll-hint {
  position: absolute;
  bottom: 30px;
  animation: bounce 2s infinite;
  opacity: 0.7;
  font-size: 0.9rem;
}

/* Hero video: keep ratio regardless of viewport (height/width) */
.hero-section .video-container {
  width: min(
    calc(100vw - var(--hero-side-gutter)),
    calc((100vh - var(--hero-header-offset) - var(--hero-gap-top) - var(--hero-gap-bottom) - var(--hero-video-height-reduction)) * 16 / 9)
  );
  max-height: calc(100vh - var(--hero-header-offset) - var(--hero-gap-top) - var(--hero-gap-bottom) - var(--hero-video-height-reduction));
  height: auto;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}

.hero-title {
  font-weight: 600 !important;
}

.hero-content {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 20;
  color: white;
  text-align: center;
}

.hero-section .hero-content {
  gap: clamp(6px, 1.4vmin, 16px);
  inset: 0;
  justify-content: center;
  padding: clamp(12px, 3vmin, 24px) clamp(12px, 4vw, 36px);
}

.hero-section .hero-content h2 {
  font-size: clamp(30px, 6vh, 60px) !important;
  line-height: 1.05;
  margin: 0;
}

.hero-section .hero-content h3 {
  font-size: clamp(18px, 2.6vmin, 27px) !important;
  line-height: 1.25;
  margin: 0;
}

.hero-subtitle {
  font-weight: bold;
  width: 100%;
  max-width: 500px;
}

.hero-section .hero-subtitle {
  position: absolute;
  left: 50%;
  bottom: calc(var(--hero-arrow-bottom) + var(--hero-scroll-offset) + clamp(34px, 5.2vmin, 62px));
  transform: translateX(-50%);
  text-align: center;
}

body.lang-de .hero-section .hero-subtitle {
  bottom: calc(var(--hero-arrow-bottom) + var(--hero-scroll-offset) + clamp(64px, 8.2vmin, 98px));
  max-width: 980px;
}

@media (min-width: 769px) and (max-width: 1180px) {
  body.lang-de .hero-main {
    top: 40%;
    gap: clamp(16px, 2.8vmin, 32px);
  }

  body.lang-de .hero-logo {
    margin-bottom: 18px;
  }

  body.lang-de .hero-section .hero-subtitle {
    bottom: calc(var(--hero-arrow-bottom) + var(--hero-scroll-offset) + clamp(58px, 7.2vmin, 88px));
  }
}

body.lang-nl .hero-section .hero-subtitle {
  max-width: 860px;
}

body.lang-fr .hero-section .hero-subtitle {
  max-width: 840px;
}

body.lang-it .hero-section .hero-subtitle {
  max-width: 680px;
}

@media (min-width: 769px) {
  body.lang-de .hero-section .hero-subtitle {
    white-space: nowrap;
  }

  body.lang-fr .hero-section .hero-subtitle .hero-subtitle-line1,
  body.lang-nl .hero-section .hero-subtitle .hero-subtitle-line1 {
    white-space: nowrap;
  }
}

.hero-scroll-text {
  margin-top: 20px;
}

/* Keep "scroll to discover" in place */
.hero-section .hero-scroll-text {
  position: absolute;
  left: 50%;
  bottom: calc(var(--hero-arrow-bottom) + var(--hero-scroll-offset));
  transform: translateX(-50%) rotate(-2deg);
  width: min(100%, 520px);
}

.hero-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(8px, 1.8vmin, 20px);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(100%, 700px);
}

.hero-logo {
  width: clamp(160px, 30%, 360px);
  height: auto;
  margin: 0;
}

.hero-section .hero-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Scale the bounce arrow with viewport size */
.hero-section > img {
  height: var(--hero-arrow-size);
  width: auto;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  bottom: var(--hero-arrow-bottom) !important;
}

.hero-scroll-arrow {
  position: absolute;
  z-index: 99;
  max-height: 96px;
  margin-top: 40px;
  animation: bounce 2s ease-in-out infinite;
}

/* Escalar el vídeo per amagar les lletres/logotips de les vores si cal */
.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%) scale(1.25);
  pointer-events: none;
  background-color: #000;
  overflow: hidden;
  transition: all 1.2s cubic-bezier(0.16, 1, 0.3, 1);
  border-radius: 20px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
}

.hero-video.is-fullscreen {
  width: 100vw;
  height: 100vh;
  border-radius: 0;
}

.hero-video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  cursor: default;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0.8) 10%,
    rgba(0, 0, 0, 0.5) 25%,
    rgba(0, 0, 0, 0.3) 100%
  );
}

/* @media (max-width: 768px) {
  .hero-video {
    width: 80%;
    height: 50%;
  }
} */

@keyframes bounce {
  0%,
  20%,
  50%,
  80%,
  100% {
    transform: translateY(0);
  }

  40% {
    transform: translateY(-10px);
  }

  60% {
    transform: translateY(-5px);
  }
}

/* ==========================================================================
   Section 2: Notebook (Bottom)
   ========================================================================== */

/* NOTEBOOK WRAPPER - conté el fons de línies continu */
.notebook-wrapper {
  position: relative;
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

/* Pseudo-element que conté el fons de línies i cobreix ambdues seccions */
.notebook-wrapper::before {
  content: "";
  position: absolute;
  top: 25vh; /* Comença més avall del top */
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1200px;
  bottom: 45vh; /* Acaba més abans del bottom */
  background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_05-lineas.svg);
  background-position: center top;
  background-repeat: repeat-y;
  background-size: 100% auto; /* Manté proporcions */
  pointer-events: none;
  z-index: 0;
}

.notebook-bottom-section {
  background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_05-lineas.svg);
  background-position: center top;
  background-repeat: repeat-y;
  background-size: 100% auto; /* Manté proporcions */
  background-color: #f0e9e4;
  pointer-events: none;
  position: relative;
  z-index: 1;
  height: auto;
  max-height: calc(100vh - 70px);
  margin-top: 80px;
  overflow: visible;
}

/* Evita la línia fina ocasional entre hero i notebook (subpíxel/seam) */
.notebook-bottom-section::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 0;
  width: 100%;
  height: 20px;
  background: #f0e9e4;
  pointer-events: none;
  z-index: 2;
}

.notebook-bottom-section .notebook-grid {
  position: relative;
  z-index: 1;
  overflow: visible;
}

/* Contenidor principal */
.notebook-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-template-rows: 14fr 1fr 12fr;
  height: 80vh;
  padding: 10px;
  top: -50px;
  position: relative;
}

.notebook-canvas {
  width: 26vh;
  max-width: 200px;
  height: auto;
  margin-top: 120px;
}

.notebook-logo {
  width: 60vh;
  max-width: 540px;
}

.notebook-bracket {
  margin-bottom: 50px;
}

.notebook-bracket--left {
  width: 80%;
}

.notebook-bracket--right {
  width: 90%;
  left: -20px;
  position: relative;
}

/* Estil base per als requadres */
.notebook-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: sans-serif;
  border-radius: 4px;
}

.notebook-cell--bottom-left,
.notebook-cell--bottom-right {
  flex-direction: column;
}

.notebook-note {
  font-size: 21px;
}

.notebook-note--spaced {
  margin-bottom: 20px;
}

.notebook-note--narrow {
  max-width: 220px;
}

.notebook-note--blue {
  color: #253888;
}

/* Posicionament específic */
.notebook-cell--left {
  grid-column: 1 / 2;
  grid-row: 1 / 4;
}

.notebook-cell--top {
  grid-column: 2 / 4;
  grid-row: 1 / 2;
}

.notebook-cell--top h2 {
  font-size: clamp(30px, 6vh, 60px);
  color: black;
  font-weight: bold;
}

.notebook-bottom-section .notebook-cell--top,
.notebook-bottom-section .notebook-cell--top h2,
.notebook-bottom-section .notebook-cell--top .scribble-we {
  overflow: visible;
}

.notebook-cell--middle {
  grid-column: 2 / 4;
  grid-row: 2 / 3;
}

.notebook-cell--bottom-left {
  grid-column: 2 / 3;
  grid-row: 3 / 4;
}

.notebook-cell--bottom-right {
  grid-column: 3 / 4;
  grid-row: 3 / 4;
}

.notebook-cell--right {
  grid-column: 4 / 5;
  grid-row: 1 / 4;
}

/* ==========================================================================
   Section 3: Notebook (Top)
   ========================================================================== */

.notebook-top-section {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  padding: 64px 20px 90px;
  overflow: visible;
  min-height: clamp(520px, 72vh, 860px);
}

.notebook-top-content {
  width: 100%;
  max-width: 1250px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 50px;
  position: relative;
  z-index: 1;
}

.notebook-top-text {
  max-width: 340px;
  text-align: left;
  line-height: 1.5;
  flex: 0 0 340px;
}

.notebook-top-visual {
  position: relative;
  width: min(65%, 830px);
  max-width: 830px;
  flex: 1 1 auto;
  margin-right: -40px;
  overflow: visible;
  --notebook-tilt: rotate(-8deg) scale(1.08) translateY(14px) translateX(80px);
  --notebook-text-size: clamp(12px, 2.1vw, 24px);
  --notebook-note-size: clamp(11px, 1.5vw, 18px);
}

.notebook-top-image {
  width: 100%;
  height: auto;
  display: block;
  position: relative;
  z-index: 1;
  transform: var(--notebook-tilt);
  transform-origin: center;
}

.notebook-trail {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
}

.notebook-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  transform: var(--notebook-tilt);
  transform-origin: center;
  color: #253888;
}

.notebook-overlay-main,
.notebook-overlay-note {
  position: absolute;
  margin: 0;
  line-height: 1.28;
  text-align: left;
  font-weight: 500;
}

.notebook-overlay-main {
  left: 10%;
  top: 20%;
  width: 38%;
  font-size: 16px;
  text-align: center;
  /* font-size: 1vw; */
}

@media (max-width: 977px) {
  .notebook-overlay-main {
    font-size: 13px;
  }
}

.notebook-overlay-note {
  left: 59%;
  top: 13%;
  width: 26%;
  font-size: var(--notebook-note-size);
  line-height: 1.25;
  position: absolute;
}

.notebook-overlay-title {
  display: inline-block;
  font-size: 1.3em;
  letter-spacing: 0.04em;
}

.notebook-overlay-strong {
  display: inline-block;
  font-size: 1.08em;
  letter-spacing: 0.02em;
  font-size: 1.8vw;
  margin-top: 10px;
  margin-bottom: 30px;
}

.notebook-highlight {
  position: relative;
  display: inline-block;
  padding: 0 0.2em;
  z-index: 0;
  font-size: 1.8vw;
  margin-top: 30px;
}

.notebook-highlight::before {
  content: "";
  position: absolute;
  left: -0.9em;
  right: -0.9em;
  height: 0.9em;
  bottom: -0.3em;
  background: url("https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Highlight_Orange.png")
    no-repeat;
  background-size: 80% 100%;
  background-position: center;
  transform: rotate(-1deg);
  z-index: 1;
  opacity: 0.88;
}

.notebook-underline {
  position: relative;
  display: inline-block;
  padding-bottom: 0.08em;
}

.notebook-underline::after {
  content: "";
  position: absolute;
  left: -0.02em;
  right: -0.02em;
  height: 0.12em;
  bottom: 0.03em;
  background: #0f833a;
  border-radius: 999px;
  transform: rotate(-1deg);
  opacity: 0.9;
}

.notebook-note-text {
  display: inline-block;
  transform: rotate(-12deg);
  left: -10%;
  position: absolute;
}

.notebook-note-pen {
  width: clamp(54px, 9vw, 120px);
  height: auto;
  display: inline-block;
  vertical-align: top;
  margin-left: 0.35em;
  margin-top: 0.02em;
  transform: rotate(22deg);
  top: 0;
  right: -10%;
  position: absolute;
}

.notebook-trail line {
  stroke: #3f51b5;
  stroke-width: 2;
  stroke-linecap: round;
}

.notebook-deco {
  position: absolute;
  pointer-events: none;
}

.notebook-highlighter {
  left: -35%;
  bottom: 30%;
  width: clamp(340px, 32vw, 520px);
  transform: rotate(-33deg);
  z-index: 4;
}

.notebook-paperplane {
  left: -6%;
  bottom: -11%;
  width: clamp(120px, 25vw, 80px);
  transform: rotate(-6deg);
  z-index: 2;
}

.notebook-arrow-down {
  left: 55%;
  bottom: 0;
  width: clamp(55px, 6vw, 110px);
  transform: translate(-50%, 35%) rotate(6deg);
  z-index: 2;
}

@media (max-width: 900px) {
  .notebook-top-content {
    flex-direction: column;
    align-items: flex-start;
  }

  .notebook-top-image {
    width: 100%;
  }

  .notebook-top-visual {
    width: min(90%, 680px);
    max-width: 680px;
    align-self: center;
    margin-right: 0;
  }

  .notebook-top-text {
    flex: none;
    max-width: 520px;
  }

  .notebook-overlay-main {
    left: 18%;
    top: 17%;
    width: 25%;
  }

  .notebook-overlay-note {
    left: 56.5%;
    top: 16%;
    width: 32%;
  }
  .notebook-highlighter {
    left: -25%;
    bottom: 30%;
    width: clamp(340px, 32vw, 520px);
    transform: rotate(-33deg);
    z-index: 4;
  }
}

@media (max-width: 901px) {
  body.lang-de .notebook-top-section .notebook-overlay-main {
    width: 33%;
    left: 11%;
    top: 20%;
  }

  body.lang-it .notebook-top-section .notebook-overlay-main {
    top: 16.2% !important;
    left: 13.6% !important;
  }
}

@media (max-height: 820px) and (min-width: 900px) {
  .notebook-top-section {
    padding: 46px 20px 70px;
    min-height: 64vh;
  }

  .notebook-top-content {
    gap: 40px;
  }

  .notebook-top-visual {
    width: min(66%, 820px);
    max-width: 820px;
    margin-right: -30px;
  }

  .notebook-top-image {
    transform: var(--notebook-tilt);
  }

  .notebook-highlighter {
    bottom: clamp(110px, 16vh, 180px);
    width: clamp(210px, 28vw, 460px);
  }

  .notebook-paperplane {
    bottom: clamp(22px, 5vh, 60px);
  }

  .notebook-arrow-down {
    transform: translate(-50%, -10%) rotate(5deg);
  }
}

@media (max-height: 680px) and (min-width: 900px) {
  .notebook-top-section {
    padding: 34px 16px 50px;
    min-height: 58vh;
  }

  .notebook-top-text {
    font-size: 24px;
    max-width: 320px;
    flex: 0 0 320px;
  }

  .notebook-top-visual {
    width: min(64%, 760px);
    max-width: 760px;
    margin-right: -20px;
  }

  .notebook-top-image {
    transform: var(--notebook-tilt);
  }

  .notebook-highlighter {
    bottom: clamp(170px, 14vh, 150px);
    width: clamp(190px, 26vw, 420px);
  }

  .notebook-paperplane {
    width: clamp(36px, 6.5vw, 70px);
  }

  .notebook-arrow-down {
    width: clamp(48px, 5.5vw, 90px);
  }
}

@media (max-width: 1600px) and (min-width: 901px) {
  .notebook-top-visual {
    width: min(60%, 760px);
    max-width: 760px;
    margin-right: -18px;
    --notebook-tilt: rotate(-8deg) scale(1.03) translateY(12px) translateX(48px);
  }

  .notebook-highlighter {
    left: -44%;
  }

  .notebook-paperplane {
    left: -14%;
  }
}

@media (max-width: 1440px) and (min-width: 901px) {
  .notebook-top-visual {
    width: min(57%, 700px);
    max-width: 700px;
    margin-right: -8px;
    --notebook-tilt: rotate(-8deg) scale(0.99) translateY(10px) translateX(34px);
  }

  .notebook-highlighter {
    left: -50%;
  }

  .notebook-paperplane {
    left: -20%;
  }
}

@media (max-width: 1360px) and (min-width: 901px) {
  .notebook-top-visual {
    width: min(54%, 650px);
    max-width: 650px;
    margin-right: 0;
    --notebook-tilt: rotate(-8deg) scale(0.96) translateY(8px) translateX(24px);
  }

  .notebook-highlighter {
    left: -56%;
  }

  .notebook-paperplane {
    left: -24%;
  }
}

@media (max-width: 1290px) and (min-width: 901px) {
  .notebook-top-visual {
    width: min(51%, 610px);
    max-width: 610px;
    margin-right: 2px;
    --notebook-tilt: rotate(-8deg) scale(0.94) translateY(7px) translateX(16px);
  }

  .notebook-highlighter {
    left: -62%;
  }

  .notebook-paperplane {
    left: -28%;
  }
}

@media (max-width: 1060px) and (min-width: 901px) {
  .notebook-highlighter {
    left: -48%;
  }

  .notebook-paperplane {
    left: -16%;
  }
}

/* https://cdn.bicgraphic.com/landing/assets/imgs/en/BGE_Landing_02-circulo-bge.svg */
/* preserveAspectRatio="none" */
.scribble {
  position: relative;
  display: inline-block;
  white-space: nowrap;
}

.scribble::after {
  content: "";
  position: absolute;
  left: -12px;
  right: -40px;
  top: 30%;
  transform: translateY(-50%);
  height: 140%;
  background-image: var(--localized-img-circle-bge);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  z-index: 1;
  pointer-events: none;
}

/* Cercle animat per "we" */
.scribble-we {
  position: relative;
  display: inline-block;
  white-space: nowrap;
}

.circle-we-svg {
  position: absolute;
  left: -13px;
  top: 50%;
  transform: translateY(-50%);
  width: calc(100% + 30px);
  height: 200%;
  z-index: -1;
  pointer-events: none;
  overflow: visible;
}

.circle-we-path {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
}

.circle-we-filled {
  position: absolute;
  left: -3px;
  top: -30%;
  transform: translateY(-50%);
  width: 110px;
  max-width: none;
  z-index: -1;
  pointer-events: none;
  opacity: 0;
}

body.lang-fr .notebook-bottom-section .circle-we-filled {
  left: 24px;
  top: -40%;
}

body.lang-fr .notebook-bottom-section .notebook-cell--top,
body.lang-fr .notebook-bottom-section .notebook-cell--top h2,
body.lang-fr .mobile-who-section__content-col,
body.lang-fr .mobile-who-section__content-col h2 {
  overflow: visible !important;
}

body.lang-fr .notebook-bottom-section .notebook-cell--top h2,
body.lang-fr .mobile-who-section__content-col h2 {
  padding-top: 60px;
  margin-top: -60px;
}

body.lang-fr .notebook-bottom-section .circle-we-svg,
body.lang-fr .mobile-who-section .circle-we-svg {
  position: absolute;
  left: -13px;
  top: 50%;
  transform: translateY(-50%);
  width: calc(100% + 30px);
  height: 155%;
  z-index: -1;
  pointer-events: none;
  overflow: visible;
}

body.lang-it .notebook-bottom-section .circle-we-svg {
  left: -8px;
  width: calc(100% + 20px);
  height: 165px;
  transform: translateY(-50%) scaleY(0.82);
  transform-origin: center center;
}

body.lang-it .mobile-who-section .circle-we-svg {
  left: -10px;
  width: calc(100% + 22px);
  height: 165px;
  transform: translateY(-50%) scaleY(0.82);
  transform-origin: center center;
}

body.lang-it .notebook-bottom-section .circle-we-filled {
  left: 30px;
  top: -52%;
}

body.lang-it .mobile-who-section .circle-we-filled {
  left: 22px;
  top: -52%;
}

body.lang-es .notebook-bottom-section .circle-we-svg,
body.lang-es .mobile-who-section .circle-we-svg {
  transform: translateY(-50%) scaleY(0.78);
  transform-origin: center center;
}

body.lang-es .notebook-bottom-section .circle-we-filled {
  left: 46px;
  top: -48%;
}

body.lang-es .mobile-who-section .circle-we-filled {
  left: 38px;
  top: -48%;
}

body.lang-fr .mobile-who-section .circle-we-filled {
  left: 16px;
  top: -40%;
}

body.lang-fr .mobile-who-section__content-col h2 {
  font-size: clamp(30px, 4.2vh, 44px) !important;
  padding-left: 18px;
  padding-right: 8px;
  box-sizing: border-box;
}

body.lang-fr .notebook-top-section .notebook-overlay-main {
  top: 17%;
}

body.lang-it .notebook-top-section .notebook-overlay-main {
  top: 16.2%;
  left: 8.6%;
}

body.lang-es .notebook-top-section .notebook-overlay-main {
  top: 16.9%;
  left: 8.7%;
}

body.lang-nl .notebook-top-section .notebook-overlay-main {
  top: 15.9%;
  left: 8.1%;
  font-size: 14px;
  line-height: 1.2;
}

body.lang-nl .notebook-top-section .notebook-overlay-main .notebook-overlay-strong {
  font-size: 1.62vw;
  margin-top: 8px;
  margin-bottom: 22px;
}

body.lang-nl .notebook-top-section .notebook-overlay-main .notebook-highlight {
  font-size: 1.62vw;
  margin-top: 22px;
}

body.lang-de .notebook-top-section .notebook-overlay-main {
  top: 15.5%;
  font-size: 14px;
  line-height: 1.18;
}

body.lang-de .notebook-top-section .notebook-overlay-main .notebook-overlay-strong {
  font-size: 1.55vw;
  margin-top: 8px;
  margin-bottom: 18px;
}

body.lang-de .notebook-top-section .notebook-overlay-main .notebook-highlight {
  font-size: 1.55vw;
  margin-top: 20px;
}

@media (min-width: 769px) {
  body.lang-nl h2[data-i18n="co-create-a-better-future"] {
    line-height: 0.98;
  }

  body.lang-es .notebook-cell--bottom-left [data-i18n="iconic-products"] {
    max-width: 260px !important;
  }

  body.lang-de .notebook-cell--bottom-left [data-i18n="iconic-products"] {
    max-width: 280px !important;
  }

  body.lang-fr .notebook-cell--bottom-left [data-i18n="iconic-products"],
  body.lang-fr .notebook-cell--bottom-left [data-i18n="for-everyone"] {
    max-width: none !important;
  }

  body.lang-it .notebook-cell--bottom-left [data-i18n="iconic-products"] {
    max-width: 290px !important;
    white-space: nowrap;
  }

  body.lang-nl .notebook-cell--bottom-left [data-i18n="iconic-products"] {
    max-width: 255px !important;
  }
}

@media (max-width: 1242px) and (min-width: 769px) {
  body.lang-fr
    .notebook-bottom-section
    .notebook-cell--top
    h2[data-i18n="who-are-we"] {
    font-size: clamp(30px, 3.8vw, 48px) !important;
    white-space: nowrap;
  }

  body.lang-fr h2[data-i18n="cocreate-with-us"],
  body.lang-fr h2[data-i18n="also-means-cocreate-with"],
  body.lang-fr h2[data-i18n="co-create-a-better-future"],
  body.lang-fr h2[data-i18n="latest-novelties"],
  body.lang-fr h2[data-i18n="feeling-inspired"],
  body.lang-fr h2[data-i18n="contact-us"] {
    font-size: clamp(30px, 3.8vw, 48px) !important;
  }
}

@media (max-width: 1140px) and (min-width: 769px) {
  body.lang-es
    .notebook-bottom-section
    .notebook-cell--top
    h2[data-i18n="who-are-we"] {
    font-size: clamp(30px, 3.5vw, 46px) !important;
    white-space: nowrap;
  }

  body.lang-es h2[data-i18n="cocreate-with-us"],
  body.lang-es h2[data-i18n="also-means-cocreate-with"],
  body.lang-es h2[data-i18n="co-create-a-better-future"],
  body.lang-es h2[data-i18n="latest-novelties"],
  body.lang-es h2[data-i18n="feeling-inspired"],
  body.lang-es h2[data-i18n="contact-us"] {
    font-size: clamp(30px, 3.5vw, 46px) !important;
  }
}

@media (max-width: 900px) and (min-width: 769px) {
  body.lang-nl
    .notebook-bottom-section
    .notebook-cell--top
    h2[data-i18n="who-are-we"],
  body.lang-nl h2[data-i18n="cocreate-with-us"],
  body.lang-nl h2[data-i18n="also-means-cocreate-with"],
  body.lang-nl h2[data-i18n="co-create-a-better-future"],
  body.lang-nl h2[data-i18n="latest-novelties"],
  body.lang-nl h2[data-i18n="feeling-inspired"],
  body.lang-nl h2[data-i18n="contact-us"] {
    font-size: clamp(34px, 5vw, 46px) !important;
  }

  body.lang-nl .notebook-top-section .notebook-overlay-main {
    top: 20.9%;
    left: 10.1%;
    font-size: 14px;
    line-height: 1.2;
  }

  .notebook-overlay-main {
    left: 18%;
    top: 17%;
    width: 32%;
  }
}

@media (max-width: 1030px) and (min-width: 769px) {
  body.lang-it .notebook-grid {
    grid-template-columns: 0.62fr 1fr 1fr 0.62fr;
  }

  body.lang-it .notebook-cell--middle img {
    width: min(58vw, 470px) !important;
    max-width: 470px !important;
  }

  body.lang-it .notebook-cell--bottom-left [data-i18n="iconic-products"],
  body.lang-it
    .notebook-cell--bottom-right
    [data-i18n="creative-printing-solutions"] {
    font-size: clamp(18px, 2vw, 21px) !important;
    line-height: 1.08;
    white-space: nowrap !important;
  }

  body.lang-it .notebook-cell--bottom-left [data-i18n="for-everyone"],
  body.lang-it .notebook-cell--bottom-right [data-i18n="for-professionals"] {
    white-space: nowrap !important;
  }
}

/* ==========================================================================
   Section 4: Cards OK
   ========================================================================== */

.cards-section {
  height: 100vh;
  --cards-subtitle-gap: 0.18em;
  --cards-subtitle-shift-y: 0.22em;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: visible;
}

.cards-think-arrow {
  position: absolute;
  left: clamp(-18%, -4vw, -1%);
  bottom: clamp(-90px, -6vh, -30px);
  width: clamp(95px, 9vw, 150px);
  z-index: 8;
  pointer-events: none;
}

.cards-hover-discover {
  position: absolute;
  right: clamp(-5%, 1vw, 2%);
  top: 22%;
  transform: translateY(-50%);
  width: clamp(95px, 10vw, 165px);
  z-index: 8;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
}

@media (max-width: 1480px) and (min-width: 769px) {
  .cards-think-arrow {
    left: clamp(-8%, -1.5vw, 6%);
    bottom: clamp(-120px, -8vh, -50px);
  }
}

@media (max-width: 1350px) and (min-width: 769px) {
  .cards-think-arrow {
    left: clamp(-2%, 1.2vw, 10%);
    bottom: clamp(-150px, -10vh, -80px);
  }
}

@media (max-width: 1280px) and (min-width: 769px) {
  .cards-think-arrow {
    left: clamp(2%, 2.8vw, 13%);
    bottom: clamp(-178px, -12vh, -102px);
  }
}

@media (max-height: 750px) {
  .cards-section {
    padding-bottom: 8vh;
  }

  .cards-container {
    height: 68vh;
  }
}

/* Co-create with us underline animat */
.cocreate-with-us-wrapper {
  position: relative;
  display: inline-block;
}

.cocreate-with-us-underline {
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: auto;
  pointer-events: none;
}

.cards-section .cocreate-with-us-underline {
  bottom: 2px;
}

.cards-section h2[data-i18n="cocreate-with-us"] {
  line-height: 1.12;
  margin: 0;
}

.cards-section h2[data-i18n="also-means-cocreate-with"] {
  line-height: 1.12;
  margin: 0;
  margin-top: var(--cards-subtitle-gap);
  position: relative;
  top: var(--cards-subtitle-shift-y);
}

.cards-section h2[data-i18n="also-means-cocreate-with"] .co-create-last-line {
  line-height: inherit;
}

body.lang-de .cards-section h2[data-i18n="also-means-cocreate-with"] {
  top: 0;
}

@media (min-width: 769px) {
  body.lang-de .cards-section .cocreate-with-us-wrapper {
    position: relative;
    top: 0.24em;
  }

  body.lang-de .cards-section h2[data-i18n="also-means-cocreate-with"] {
    position: relative;
    top: 0.24em;
    margin-top: 0;
  }
}

.cocreate-with-us-path {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
}

@media (max-width: 768px) {
  .cards-section {
    min-height: auto;
    padding: 60px 0 80px;
    height: auto;
  }

  .cards-hover-discover {
    display: none;
  }
}

.cards-container {
  position: relative;
  width: 100%;
  height: 73vh;
  max-height: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 768px) {
  .cards-container {
    height: auto;
    padding: 20px 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    gap: 20px;
    padding-left: calc(50vw - 140px);
    padding-right: calc(50vw - 140px);
  }

  .cards-container::-webkit-scrollbar {
    display: none;
  }
}

.card {
  perspective: 1000px;
  width: min(40vh, 30vw, 350px);
  height: min(65vh, 49vw, 500px);
  max-width: 350px;
  max-height: 500px;
  min-height: 300px;
  min-width: 200px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

/* Desktop: position absolute */
@media (min-width: 769px) {
  .card {
    position: absolute;
  }
}

/* Mobile: relative para el slider */
@media (max-width: 768px) {
  .card {
    position: relative;
    flex-shrink: 0;
    scroll-snap-align: center;
  }
}

.card-1 {
  z-index: 3;
}

.card-2 {
  z-index: 2;
}

.card-3 {
  z-index: 1;
}

.card-inner {
  position: relative;
  width: 100%;
  height: 100%;
}

.card-front,
.card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.6s ease;
}

.card-front {
  opacity: 1;
  z-index: 2;
}

.card-back {
  opacity: 0;
  z-index: 1;
}

.card:hover .card-front {
  opacity: 0;
}

.card:hover .card-back {
  opacity: 1;
}

.card-front img,
.card-back img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.card-icon {
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 30px;
  font-size: 2.5rem;
}

.card-title {
  font-size: 1.8rem;
  font-weight: bold;
  color: white;
  margin-bottom: 15px;
  text-transform: uppercase;
}

.card-description {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.6;
}

.end-spacer {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: #333;
}

@media (max-width: 768px) {
  .end-spacer {
    font-size: 1.2rem;
    padding: 0 20px;
    text-align: center;
  }
}

/* Indicador de scroll en mòbil */
.scroll-indicator {
  display: none;
  text-align: center;
  margin-top: 20px;
  color: #999;
  font-size: 0.9rem;
}

@media (max-width: 768px) {
  .scroll-indicator {
    display: block;
  }
}

.co-trazado {
  position: relative;
}

.co-trazado:before {
  content: "";
  position: absolute;
  left: -85px;
  right: 0px;
  top: -25%;
  transform: translateY(127%);
  height: 20%;
  background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_07-comillas1-cocreate-with-us.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  z-index: 1;
  pointer-events: none;
}

.us-trazado {
  position: relative;
}

.us-trazado:after {
  content: "";
  position: absolute;
  left: 0px;
  right: -75px;
  top: -25%;
  transform: translateY(127%);
  height: 20%;
  background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_09-comillas2-cocreate-with-us.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  z-index: 1;
  pointer-events: none;
}

body.lang-fr h2[data-i18n="cocreate-with-us"] .co-trazado::before {
  left: -140px;
  right: 20px;
}

body.lang-fr h2[data-i18n="cocreate-with-us"] .us-trazado::after {
  left: 20px;
  right: -110px;
}

@media (max-width: 1170px) and (min-width: 769px) {
  body.lang-fr h2[data-i18n="cocreate-with-us"] .co-trazado::before {
    left: -86px;
    right: 24px;
  }

  body.lang-fr h2[data-i18n="cocreate-with-us"] .us-trazado::after {
    left: 24px;
    right: -78px;
  }
}

body.lang-de h2[data-i18n="cocreate-with-us"] .co-trazado::before {
  left: -24px;
  right: auto;
  top: -18px;
  transform: none;
  width: 17px;
  height: 17px;
  background-size: contain;
}

body.lang-de h2[data-i18n="cocreate-with-us"] .us-trazado::after {
  left: auto;
  right: -22px;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-it h2[data-i18n="cocreate-with-us"] .co-trazado::before {
  left: -22px;
  right: auto;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-it h2[data-i18n="cocreate-with-us"] .us-trazado::after {
  left: auto;
  right: -20px;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-es h2[data-i18n="cocreate-with-us"] .co-trazado::before {
  left: -24px;
  right: auto;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-es h2[data-i18n="cocreate-with-us"] .us-trazado::after {
  left: auto;
  right: -22px;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-nl h2[data-i18n="cocreate-with-us"] .co-trazado::before {
  left: -24px;
  right: auto;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

body.lang-nl h2[data-i18n="cocreate-with-us"] .us-trazado::after {
  left: auto;
  right: -22px;
  top: -18px;
  transform: none;
  width: 18px;
  height: 18px;
  background-size: contain;
}

/* ==========================================================================
   Section 5: Video Stories OK
   ========================================================================== */

.video-stories-section {
  position: relative;
  height: 120vh;
  overflow: visible;
  --because-base-w: 1440px;
  --because-base-h: 900px;
  --because-scale: 1;
  --because-scale: min(
    1,
    calc(100vw / var(--because-base-w)),
    calc(100vh / var(--because-base-h))
  );
}

.video-stories-text {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 0;
  z-index: 1;
  overflow: visible;
}

.video-stories-section h3 {
  padding: 0 20px;
  text-align: center;
  margin: 0;
  transform: translateY(calc(-18vh * var(--because-scale)));
  position: relative;
  z-index: 1;
}

.because-graphic {
  position: absolute;
  top: 50%;
  left: 50%;
  width: var(--because-base-w);
  height: var(--because-base-h);
  transform: translate(-50%, -50%) scale(var(--because-scale));
  transform-origin: center;
  pointer-events: none;
  z-index: 0;
}

.because-graphic__item {
  position: absolute;
  height: auto;
  width: auto;
  max-width: none;
}

.because-graphic__item--1 {
  width: 280px;
  left: 18%;
  top: 15%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--2 {
  width: 200px;
  left: 35%;
  top: 5%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--3 {
  width: 200px;
  left: 50%;
  top: 5%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--4 {
  width: 360px;
  left: 84%;
  top: 10%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--5 {
  height: 420px;
  left: 85%;
  top: 52%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--6 {
  height: 300px;
  left: 75%;
  top: 58%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--7 {
  height: 240px;
  left: 50%;
  top: 64%;
  transform: translate(-50%, -50%);
}

.because-graphic__item--8 {
  height: 420px;
  left: 22%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.video-stories-title {
  font-size: 27px;
  color: #253888;
}

.video-stories-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: calc(100vh - 70px);
  margin-left: calc(-50vw + 50%);
  z-index: 2;
  border-radius: 30px !important;
  overflow: hidden;
}

.video-stories-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 30px;
}

/* Desktop restringit (alçada o amplada): mantenim la proporció del vídeo sense retallar */
.video-stories-section.video-stories-section--fit-video {
  height: calc(100vh - 70px);
}

.video-stories-section.video-stories-section--fit-video .video-stories-text {
  height: calc(100vh - 70px);
}

@supports (height: 100dvh) {
  .video-stories-section.video-stories-section--fit-video {
    height: calc(100dvh - 70px);
  }

  .video-stories-section.video-stories-section--fit-video .video-stories-text {
    height: calc(100dvh - 70px);
  }
}

.video-stories-section.video-stories-section--fit-video .video-stories-video {
  top: 0;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: calc(100vh - 70px);
  margin-left: calc(-50vw + 50%);
  max-width: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  border-radius: 30px !important;
  overflow: hidden;
}

@supports (height: 100dvh) {
  .video-stories-section.video-stories-section--fit-video .video-stories-video {
    height: calc(100dvh - 70px);
  }
}

.video-stories-section.video-stories-section--fit-video .video-stories-video video {
  position: relative;
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center bottom;
  border-radius: 30px;
}

/* Text reveal animation - because-text */
.because-text {
  overflow: hidden;
  font-weight: 400;
}

body.lang-de .because-text {
  font-size: clamp(22px, 2.1vw, 25px) !important;
  line-height: 1.08;
}

.because-line {
  display: block;
  overflow: hidden;
}

.because-line-inner {
  display: block;
  transform: translateY(100%);
}

/* ==========================================================================
   Section 6: Boli / Joy OK
   ========================================================================== */

.boli-section {
  align-items: flex-start;
  justify-content: center;
  height: calc(100vh - 70px);
  overflow-x: visible;
  overflow-y: visible;
  margin-top: 0;
  padding-top: 0;
}

.boli-section::before {
  content: "";
  position: absolute;
  right: 7%;
  top: -5%;
  width: clamp(380px, 48vmin, 760px);
  height: clamp(500px, 70vmin, 940px);
  background-image: url("https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Doodle_Business.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transform: translateY(20px) scale(0.98);
  transition:
    opacity 0.45s ease,
    transform 0.55s ease;
}

.boli-section.is-revealed::before {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (max-width: 1190px) and (min-width: 769px) {
  .boli-section.is-revealed::before {
    top: -4%;
    width: clamp(240px, 34vmin, 500px);
    height: clamp(330px, 50vmin, 650px);
  }
}

@media (max-height: 800px) {
  .boli-section {
    padding-top: 4vh;
  }

  .boli-section .boli-pw {
    width: min(140px, 20vh);
  }
}

.boli-title {
  font-size: clamp(40px, 8vh, 80px);
  margin-left: 20px;
}

.boli-section .boli-pw {
  position: absolute;
  width: min(160px, 22vh);
  rotate: 30deg;
  left: 0;
  top: 0;
  transform-origin: 50% 96%;
  z-index: 10;
}

.bic-graphic-brings-joy {
  position: relative;
  z-index: 1;
}

.bic-graphic-brings-joy::before {
  content: "";
  position: absolute;
  display: block;
  width: 300px;
  height: 100px;
  top: -130px;
  left: -11%;
  background-image: url("https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_10-frase-asterisco.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  pointer-events: none;
  z-index: 1;
}

@keyframes rotateInfinite {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.joy-trazado,
.simplicity-trazado,
.professional-world-trazado {
  position: relative;
  display: inline-block;
  white-space: nowrap;
}

.joy-trazado::after {
  content: "";
  position: absolute;
  left: -23px;
  right: -25px;
  top: 44%;
  transform: translateY(-50%);
  height: 100%;
  background-image: var(--localized-img-joy-circle);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  z-index: 1;
  pointer-events: none;
}

.simplicity-trazado::after {
  content: "";
  position: absolute;
  left: -0.28em;
  right: -0.48em;
  top: 50%;
  transform: translateY(-50%) scaleX(1.34);
  transform-origin: center;
  height: 1.15em;
  background-image: var(--localized-img-simplicity-circle);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 185% 100%;
  z-index: 1;
  pointer-events: none;
}

.underline-wrapper {
  position: relative;
  display: inline-block;
}

.underline-svg {
  position: absolute;
  left: 0;
  bottom: -15px;
  width: 100%;
  height: 15px;
  pointer-events: none;
  overflow: visible;
}

.wavy-path {
  stroke: #ce0c17;
  stroke-width: 3;
  fill: none;
  stroke-linecap: round;
}

.wavy-path.visible {
}

.tracat-container {
  width: 0%;
  transition: width 0.1s linear;
}

#boli {
  transition:
    left 0.1s linear,
    transform 0.1s linear;
  transform-origin: bottom center;
}

/* ==========================================================================
   Section 7: Hover Inspire OK
   ========================================================================== */

.inspire-gallery {
  position: relative;
  cursor: pointer;
  width: 100%;
  margin-bottom: 30px;
  margin-top: 30px;
  height: auto;
  aspect-ratio: 1500 / 844;
  background: #d8d0ca;
  overflow: hidden;
  border-radius: 30px;
  position: relative;
}

.inspire-media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  opacity: 0;
  z-index: 1;
}

.inspire-media.is-active {
  opacity: 1;
  z-index: 2;
}

.hover-inspire-section {
  height: 100%;
  position: relative;
  overflow: visible;
}

.inspire-pagination {
  position: relative;
  bottom: auto !important;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 10px;
  margin-bottom: 6px;
}

.get-inspired-arrow {
  position: absolute;
  right: -2%;
  bottom: clamp(30px, -18vh, -90px);
  width: clamp(105px, 16vmin, 175px);
  height: auto;
  pointer-events: none;
  z-index: 3;
  opacity: 0;
}

@media (max-width: 1370px) and (min-width: 769px) {
  .get-inspired-arrow {
    right: 5%;
  }
}

@media (max-width: 1150px) and (min-width: 769px) {
  .get-inspired-arrow {
    width: clamp(80px, 11vmin, 130px);
    bottom: clamp(28px, -3vh, -16px);
  }
}

/* Custom cursor para hover-inspire-section */
.hover-inspire-section .inspire-gallery {
  cursor: none !important;
}

.custom-cursor {
  position: fixed;
  width: 150px;
  height: 150px;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  left: 0;
  top: 0;
}

.custom-cursor img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* ==========================================================================
   Section 8: Your Brand OK
   ========================================================================== */

.your-brand-section {
  padding-top: clamp(40px, 33vh, 270px);
  padding-bottom: clamp(40px, 10vh, 140px);
  position: relative;
  overflow: visible;
}

.brand-grid {
  display: grid;
  grid-template-columns: 5fr 15fr;
  /* height: 60vh; */
  height: 100%;
  width: 100%;
  position: relative;
  z-index: 2;
  /* top: -100px; */
  box-sizing: border-box;
  /* margin-top: 80px; */
}

/* Configuració comuna per a les columnes */
.brand-column {
  display: grid;
  height: 100%;
}

/* Columna 1: Superior 0.8 / Inferior 0.2 */
.brand-column:first-child {
  grid-template-rows: 6fr 4fr;
}

/* Columna 2: Superior 0.2 / Inferior 0.8 */
.brand-column:last-child {
  grid-template-rows: 2fr 8fr;
}

/* Estils de les caixes */
.brand-grid .brand-cell {
  display: flex;
  width: 100%;
}

.brand-cell--left-top {
  align-items: center;
  justify-content: center;
  padding-left: clamp(20px, 6vw, 80px);
}

.brand-text {
  position: absolute;
  left: 12%;
  top: 60%;
  transform: translate(-50%, -50%);
  text-align: left;
  z-index: 2;
  max-width: min(320px, 32vw);
}

.brand-cell--left-top p {
  text-align: left;
}

.brand-cell--left-bottom {
  align-items: flex-end;
  justify-content: flex-start;
}

.brand-cell--right-top {
  align-items: flex-start;
  justify-content: flex-end;
}

.brand-heading {
  font-size: 28px;
}

.brand-grid .video-container {
  margin: 0;
  aspect-ratio: unset;
  width: 100%;
  height: auto;
}

.brand-video-wrap {
  position: relative;
  width: 100%;
  overflow: visible;
}

.brand-cell--right-bottom {
  position: relative;
}

.brand-bulb-bling-wrap {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  z-index: 3;
  transform: translate(calc(-90% - 6px), calc(-60% - 6px));
}

.brand-bulb {
  position: absolute;
  left: calc(50% - 50vw - 40px);
  top: calc(12% + 50px);
  width: clamp(400px, 28vmin, 400px);
  height: auto;
  pointer-events: none;
  z-index: 2;
  transform: translateY(-50%);
}

.brand-bulb-path {
  fill: none;
  stroke: #ce0d17;
  stroke-width: 4px;
  stroke-miterlimit: 10;
}

.brand-bling {
  position: absolute;
  right: clamp(-56px, -3.8vw, -22px);
  bottom: clamp(-62px, -5.3vh, -30px);
  width: clamp(110px, 13vmin, 170px);
  height: auto;
  pointer-events: none;
  z-index: 4;
  transform: none;
}

.brand-bulb-bling {
  width: clamp(70px, 10vmin, 120px);
  height: auto;
}

.brand-leaf {
  position: absolute;
  left: 10%;
  top: 92%;
  width: clamp(120px, 18vmin, 220px);
  height: auto;
  pointer-events: none;
  z-index: 1;
  transform: translate(-50%, -50%);
}

@media (min-width: 769px) {
  .your-brand-section {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: 0;
    padding-right: 0;
  }

  .brand-grid {
    width: min(100%, 1620px);
    margin: 0 auto;
    padding: 0 clamp(18px, 3vw, 52px);
    grid-template-columns: 4fr 16fr;
  }

  .brand-grid .video-container {
    width: 100%;
    border-radius: clamp(24px, 2vw, 34px);
    overflow: hidden;
  }

  .brand-video-wrap {
    width: min(100%, 1180px);
  }

  .brand-grid .video-container video {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
  }

  .brand-text {
    left: clamp(6px, 1vw, 22px);
    transform: translateY(-50%);
  }

  .brand-bulb-bling-wrap {
    transform: translate(calc(-98% - 8px), calc(-58% - 6px));
  }

  .brand-leaf {
    left: 8%;
  }
}

@media (min-width: 769px) and (max-width: 1600px) {
  .brand-grid {
    width: min(100%, 1440px);
    padding-left: clamp(12px, 2.2vw, 30px);
    padding-right: clamp(24px, 3.2vw, 60px);
  }

  .brand-video-wrap {
    width: min(100%, 1060px);
  }

  .brand-text {
    left: clamp(4px, 1.2vw, 20px);
    transform: translateY(-50%);
    max-width: min(260px, 23vw);
  }
}

@media (max-width: 1390px) and (min-width: 769px) {
  .brand-bulb {
    top: calc(12% + 8px);
  }

  .brand-leaf {
    top: 108%;
  }
}

@media (min-width: 769px) and (max-width: 1280px) {
  .brand-grid {
    width: min(100%, 1240px);
    grid-template-columns: 3.6fr 16.4fr;
    padding-left: clamp(6px, 1.2vw, 18px);
    padding-right: clamp(36px, 4.8vw, 78px);
  }

  .brand-video-wrap {
    width: min(100%, 1040px);
  }

  .brand-text {
    left: clamp(0px, 0.6vw, 10px);
    max-width: min(200px, 18vw);
    font-size: clamp(20px, 1.6vw, 26px) !important;
  }
}

/* ==========================================================================
   Section 9: Diapos OK
   ========================================================================== */

.diapos-section {
  min-height: calc(100vh - 70px);
  height: calc(100vh - 70px);
  padding: clamp(12px, 2vh, 28px) 0;
  position: relative;
  overflow: visible !important;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  --diapos-max-height: 60vh;
}

.diapos-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 2vh, 16px);
  padding-top: clamp(16px, 4vh, 48px);
  overflow: visible !important;
  width: 100%;
  height: 100%;
}

.diapos-subtitle {
  font-size: 26px;
  color: #0f833a;
}

.diapos-section h2 {
  font-size: clamp(24px, 4.8vh, 50px) !important;
}

.diapos-section .handwritten {
  font-size: clamp(18px, 2.6vh, 24px) !important;
}

/* Elements decoratius animats amb GSAP */
.diapos-hoja {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  height: auto;
}

.diapos-hoja-1 {
  top: 0;
  right: 40px;
  width: clamp(110px, 12vmin, 200px);
}

.diapos-hoja-2 {
  bottom: 0;
  left: 70px;
  width: clamp(110px, 12vmin, 200px);
}

@media (max-height: 800px) {
  .diapos-hoja-1,
  .diapos-hoja-2 {
    width: clamp(90px, 10vmin, 170px);
  }
}

@media (max-height: 700px) {
  .diapos-hoja-1,
  .diapos-hoja-2 {
    width: clamp(80px, 9vmin, 150px);
  }
}

.diapos-horitzontals {
  position: relative;
  width: 100%;
  max-width: 1000px;
  aspect-ratio: 4/3;
  max-height: var(--diapos-max-height);
  margin-top: clamp(12px, 4vh, 48px);
}

/* Wrapper per cada diapo + boli */
.diapo-wrapper {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 800px;
}

.diapo-wrapper-1 {
  z-index: 4;
}

.diapo-wrapper-2 {
  z-index: 3;
  top: 10px;
  transform: translateX(calc(-50% + 10px));
}

.diapo-wrapper-3 {
  z-index: 2;
  top: 20px;
  transform: translateX(calc(-50% + 20px));
}

.diapo-wrapper-4 {
  z-index: 1;
  top: 30px;
  transform: translateX(calc(-50% + 30px));
}

.diapo {
  width: 100%;
  display: block;
}

/* Bolis a sobre de les diapos */
.boli-diapo {
  position: absolute;
  width: clamp(60px, 18%, 180px);
  height: auto;
  z-index: 10;
  filter: drop-shadow(16px 11px 5px rgba(0, 0, 0, 0.5));
}

@media (max-height: 800px) {
  .diapos-horitzontals {
    max-width: min(1000px, calc(var(--diapos-max-height) * 4 / 3));
  }
}

.boli-1 {
  top: -63%;
  left: 18%;
}

.boli-2 {
  top: -50%;
  left: 13%;
}

.boli-3 {
  top: -65%;
  left: 18%;
}

.boli-4 {
  top: -115%;
  left: 40%;
}

/* ==========================================================================
   Section 10: Sustainability OK
   ========================================================================== */

.sustainability-section {
  position: relative;
  height: 100%;
  margin-bottom: clamp(40px, 10vh, 140px);
}

@media (min-height: 800px) {
  .sustainability-section {
    min-height: calc(100vh - 70px);
    height: calc(100vh - 70px);
  }
}

.sustainability-section > .flex {
  gap: clamp(16px, 4vh, 40px);
  justify-content: center !important;
  align-items: center;
  text-align: center;
}

.sustainability-header {
  display: flex;
  flex-direction: row;
  align-items: center;
  width: 100%;
  justify-content: flex-end;
  gap: 40px;
}

.sustainability-cta {
  position: relative;
}

.sustainability-section .animated-gradient-button {
  position: relative;
}

.sustainability-button {
  display: block;
  width: 100%;
  font-size: clamp(20px, 3.4vh, 30px);
  padding: 9px 24px;
  text-align: center;
}

/* SVG fletxes animades amb GSAP */
.sustainability-arrow {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
}

.sustainability-arrow-1 {
  width: clamp(110px, 18vh, 150px);
  top: clamp(-90px, -10vh, -50px);
  left: clamp(-90px, -10vh, -50px);
}

.sustainability-arrow-2 {
  width: clamp(110px, 18vh, 150px);
  bottom: clamp(-90px, -10vh, -50px);
  right: clamp(-90px, -10vh, -50px);
}

.sustainability-arrow path {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
}

.mans-planeta-img {
  max-width: clamp(200px, 30vh, 350px);
  height: auto;
  width: 100%;
}

.sustainability-certs {
  display: block;
  width: min(800px, 90vw);
  height: auto;
  max-height: none;
  aspect-ratio: auto;
  object-fit: contain;
}

/* ==========================================================================
   Section 11: Novelties
   ========================================================================== */

.novelties-section {
  height: 100%;
  margin-top: clamp(48px, 8vh, 140px);
  margin-bottom: clamp(48px, 8vh, 140px);
  overflow: visible;
}

.arrow-down-deco {
  position: absolute;
  left: clamp(4%, 7vw, 9%);
  bottom: clamp(14px, 3vh, 46px);
  width: clamp(120px, 18vmin, 210px);
  height: auto;
  pointer-events: none;
  z-index: 4;
  opacity: 0;
}

.latest-novelties-wrapper {
  position: relative;
  display: inline-block;
}

.latest-novelties {
  position: relative;
  display: inline-block;
}

.latest-novelties-underline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -10px;
  width: 100%;
  height: auto;
  pointer-events: none;
  z-index: 1;
}

.latest-novelties-path {
  stroke-dasharray: 3000;
  stroke-dashoffset: 3000;
}

.novelties-section {
  position: relative;
  gap: 80px;
}

.novelties-deco {
  position: absolute;
  z-index: 5;
  pointer-events: none;
}

/* Esquerra: ulls (a dalt) */
.novelties-ojos {
  left: -13%;
  top: 55%;
  width: 100px;
}

/* Esquerra: fletxes (a baix) */
.novelties-flechas-left {
  left: -14%;
  top: 68%;
  width: 150px;
}

/* Dreta: fletxes (a dalt) */
.novelties-flechas-right {
  right: -26%;
  top: -16%;
  width: clamp(420px, 30vmin, 320px);
}

/* Dreta: wow (a baix de les fletxes) */
.novelties-wow {
  right: -14%;
  top: 30%;
  width: 110px;
}

/* Mida del contenidor */
.swiper {
  width: 100%;
  max-width: 1260px;
  border-radius: 20px;
  overflow: visible;
}

.swiper-slide {
  border-radius: 20px;
}

.swiper-slide video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
}

.swiper.mySwiper {
  cursor: grab;
  overflow: hidden;
}

/* --- ESTIL DELS BULLETS TARONGES --- */

/* Bullet inactiu */
.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #888;
  opacity: 1;
  transition: all 0.3s ease;
}

/* Bullet actiu (Taronja) */
.swiper-pagination-bullet-active {
  width: 12px;
  height: 12px;
  background: #f19321 !important;
}

/* Posició de la paginació */
.novelties-section .swiper-pagination {
  position: relative;
  bottom: auto !important;
}

.swiper-pagination-bullets {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

/* Botons de navegació personalitzats del Swiper */
.swiper-container-wrapper {
  position: relative;
  width: min(92vw, 1260px);
  max-width: 1260px;
  margin: 0 auto;
}

@media (min-width: 769px) and (max-width: 1450px) {
  .novelties-section .swiper-container-wrapper {
    width: min(1140px, calc(100% - clamp(120px, 14vw, 180px)));
    max-width: 1140px;
  }

  .novelties-section .swiper {
    max-width: 1140px;
  }

  .novelties-ojos {
    left: clamp(10px, 1.8vw, 24px);
    width: clamp(56px, 5vw, 72px);
  }

  .novelties-flechas-left {
    left: clamp(10px, 1.6vw, 22px);
    width: clamp(74px, 6.4vw, 96px);
  }

  .novelties-flechas-right {
    right: clamp(10px, 2vw, 24px);
    top: -14%;
    width: clamp(190px, 16vmin, 260px);
  }

  .novelties-wow {
    right: clamp(14px, 2.4vw, 30px);
    width: clamp(64px, 5.6vw, 82px);
  }
}

@media (min-width: 1451px) and (max-width: 1700px) {
  .novelties-section .swiper-container-wrapper {
    width: min(88vw, 1180px);
    max-width: 1180px;
  }

  .novelties-section .swiper {
    max-width: 1180px;
  }

  .novelties-ojos {
    left: -9%;
    width: 82px;
  }

  .novelties-flechas-left {
    left: -10%;
    width: 110px;
  }

  .novelties-flechas-right {
    right: -16%;
    top: -12%;
    width: clamp(260px, 20vmin, 320px);
  }

  .novelties-wow {
    right: -9%;
    width: 88px;
  }
}

@media (min-width: 1450px) and (max-width: 1560px) {
  .novelties-ojos {
    left: -6.8%;
  }

  .novelties-flechas-left {
    left: -7.6%;
  }

  .novelties-flechas-right {
    right: -12.2%;
  }

  .novelties-wow {
    right: -5.2%;
  }
}

@media (min-width: 1450px) and (max-width: 1485px) {
  .novelties-ojos {
    left: -5.8%;
  }

  .novelties-flechas-left {
    left: -6.6%;
  }

  .novelties-flechas-right {
    right: -10.8%;
  }

  .novelties-wow {
    right: -4%;
  }
}

@media (min-width: 1380px) and (max-width: 1450px) {
  .novelties-ojos {
    left: clamp(14px, 2.2vw, 30px);
  }

  .novelties-flechas-left {
    left: clamp(14px, 2vw, 28px);
  }

  .novelties-flechas-right {
    right: clamp(14px, 2.4vw, 30px);
  }

  .novelties-wow {
    right: clamp(18px, 2.8vw, 34px);
  }
}

.swiper-nav-prev,
.swiper-nav-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: auto;
  cursor: pointer;
  transition: opacity 0.3s ease;
  z-index: 10;
}

.swiper-nav-prev {
  left: 20px;
}

.swiper-nav-next {
  right: 20px;
}

.swiper-nav-prev:hover,
.swiper-nav-next:hover {
  opacity: 0.6;
}

/* ==========================================================================
   Section 12: Contact OK
   ========================================================================== */

.contact-section {
  height: 100%;
  position: relative;
  overflow: visible;
  margin-top: clamp(60px, 12vh, 200px);
}

.contact-title {
  margin-top: -16px;
}

.contact-spacer {
  display: block;
  height: 100px;
}

.follow-us-trazado {
  position: relative;
  overflow: visible;
}

.follow-us-trazado img:not(.follow-us-arrow) {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

.follow-us-arrow {
  position: absolute;
  left: 0%;
  bottom: calc(100% + 10px);
  width: min(200px, 140%);
  height: auto;
  transform: translateX(-50%);
  pointer-events: none;
}

body.lang-de .follow-us-arrow {
  width: min(165px, 118%);
}

/* Feeling inspired underline animat */
.feeling-inspired-wrapper {
  position: relative;
  display: inline-block;
}

.feeling-inspired-underline {
  position: absolute;
  bottom: 5px;
  right: 16px;
  width: 53%;
  height: auto;
  pointer-events: none;
}

body.lang-fr .feeling-inspired-underline,
body.lang-fr .mobile-feeling-inspired-underline {
  width: 46%;
}

body.lang-nl .feeling-inspired-underline {
  left: 0;
  right: auto;
  width: 58%;
}

.between-sections-balloons {
  position: relative;
  height: 0;
  overflow: visible;
  pointer-events: none;
  z-index: 3;
}

.contact-balloons {
  position: absolute;
  right: 8%;
  top: calc(clamp(-140px, -16vh, -80px) - 50px);
  width: clamp(320px, 20vmin, 360px);
  height: auto;
  pointer-events: none;
  z-index: 3;
  opacity: 0;
}

@media (max-height: 800px) {
  .contact-balloons {
    width: clamp(220px, 16vmin, 280px);
  }
}

@media (max-height: 700px) {
  .contact-balloons {
    width: clamp(180px, 14vmin, 240px);
  }
}

.feeling-inspired-path {
  stroke-dasharray: 2000;
  stroke-dashoffset: 2000;
}

.contact-cards-wrapper {
  display: flex;
  gap: 80px;
  width: 100%;
  margin-top: 30px;
}

.fletxa-hover-targetes-contacte {
  opacity: 0;
  width: auto;
  height: 25px;
  position: absolute;
  top: 28px;
  right: 45px;
  aspect-ratio: unset !important;
  transition: all 0.3s ease;
}

.contact-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: end;
  text-align: center;
  border-radius: 28px;
  font-family: sans-serif;
  font-weight: bold;
  overflow: hidden;
  position: relative;
  transition: all 0.3s ease;
}

.contact-card:hover {
  box-shadow: 0px 10px 30px -22px rgb(0, 0, 0);
  transform: translateY(-10px);
}

.contact-card:hover .fletxa-hover-targetes-contacte {
  opacity: 1;
  right: 30px;
  transition: all 0.3s ease;
}

/* Colors (els que ja tenies) */
.contact-card:nth-child(1) {
  background-color: rgb(19, 163, 183);
}

.contact-card:nth-child(2) {
  background-color: rgb(202, 184, 69);
}

.contact-card:nth-child(3) {
  background-color: rgb(242, 147, 153);
}

/* Imatges dins de la targeta */
.contact-card img:not(.fletxa-hover-targetes-contacte) {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 18px 18px 0 0;
  aspect-ratio: 1 / 1;
}

.contact-card video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 1 / 1;
  border-radius: 18px 18px 0 0;
}

.contact-card h3 {
  margin-bottom: 30px;
  font-size: 26px;
  line-height: 1.2;
  padding: 0 30px;
  text-align: left;
  margin-top: 50px;
}

body.lang-de .contact-card h3 {
  font-size: clamp(23px, 1.72vw, 26px);
  line-height: 1.18;
  padding: 0 30px;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .contact-cards-wrapper {
    gap: 28px;
  }

  .contact-card h3 {
    font-size: 20px;
    padding: 0 20px;
    margin-top: 34px;
    margin-bottom: 20px;
  }

  body.lang-de .contact-card h3 {
    font-size: 19px;
    line-height: 1.14;
  }

  body.lang-es .distributor-account-trazado::after {
    left: -7px;
    right: -200px;
    top: 15px;
    height: 117%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
  }

  body.lang-nl .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 10px;
    transform: translateY(-50%);
    height: 147%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  .my-brand-trazado:after {
    left: -8px !important;
    right: -272px !important;
    top: 34px !important;
  }

  body.lang-en .my-brand-trazado:after {
    left: -8px !important;
    right: -200px !important;
    top: 30px !important;
    height: 273% !important;
    width: 195px !important;
  }

  body.lang-de .my-brand-trazado:after {
    top: 20px !important;
    height: 200% !important;
  }
  .become-trazado:after {
    left: -7px !important;
    right: -200px !important;
    top: 23px !important;
    height: 230% !important;
  }

  body.lang-es .my-brand-trazado::after {
    left: -8px !important;
    right: -196px !important;
    top: 36px !important;
    height: 333%;
    width: 154px;
    background-image: var(--localized-img-mybrand-red);
  }

  body.lang-nl .my-brand-trazado::after {
    content: "";
    position: absolute;
    left: -8px !important;
    right: -272px !important;
    top: 39px !important;
    transform: translateY(-50%);
    height: 393%;
    width: 165px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-de .become-trazado:after {
    left: -16px !important;
    height: 127% !important;
    top: 13px !important;
  }

  .novelties-section .swiper-container-wrapper {
    width: min(1020px, calc(100% - clamp(96px, 13vw, 150px)));
    max-width: 1020px;
  }
  .novelties-section .swiper {
    max-width: 1020px;
  }
  .novelties-ojos {
    left: clamp(8px, 1.8vw, 24px) !important;
    top: 55% !important;
    width: 52px !important;
  }
  .novelties-flechas-left {
    left: clamp(8px, 1.5vw, 20px) !important;
    top: 68% !important;
    width: 60px !important;
  }
  .novelties-flechas-right {
    right: clamp(10px, 2vw, 24px) !important;
    top: -10% !important;
    width: clamp(140px, 12vmin, 180px) !important;
  }
  .novelties-wow {
    right: clamp(12px, 2.2vw, 28px) !important;
    top: 31% !important;
    width: 52px !important;
  }
  .arrow-down-deco {
    left: clamp(4%, 7vw, 9%) !important;
    bottom: clamp(8px, 2vh, 30px) !important;
    width: clamp(120px, 18vmin, 210px) !important;
  }
}

@media (max-width: 1390px) and (min-width: 769px) {
  .arrow-down-deco {
    bottom: -18px !important;
  }
}

.distributor-account-trazado::after {
  content: "";
  position: absolute;
  left: -7px;
  right: -200px;
  top: 20px;
  transform: translateY(-50%);
  height: 147%;
  background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
  pointer-events: none;
}

.distributor-account-trazado,
.become-trazado,
.my-brand-trazado {
  position: relative;
}

body.lang-de .contact-card:nth-child(1) .distributor-account-trazado {
  white-space: nowrap;
}

body.lang-de .distributor-account-trazado::after {
  top: 14px;
  left: -1px;
  right: -169px;
  height: 162%;
}

body.lang-de .become-trazado::after {
  top: 13px;
  left: -16px;
  right: -200px;
  height: 120%;
}

body.lang-de .my-brand-trazado::after {
  left: -9px;
  right: -272px;
  top: 35px;
  width: 221px;
  height: 249%;
}

.become-trazado:after {
  content: "";
  position: absolute;
  left: -7px;
  right: -200px;
  top: 38px;
  transform: translateY(-50%);
  height: 300%;
  background-image: var(--localized-img-become-green);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
  pointer-events: none;
}

.my-brand-trazado:after {
  content: "";
  position: absolute;
  left: -10px;
  right: -200px;
  top: 44px;
  transform: translateY(-50%);
  height: 393%;
  width: 245px;
  background-image: var(--localized-img-mybrand-red);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
  pointer-events: none;
}

@media (min-width: 1181px) {
  body.lang-en .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -10px;
    right: -200px;
    top: 56px;
    transform: translateY(-50%);
    height: 393%;
    width: 135px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }
}

@media (min-width: 1181px) {
  body.lang-es .distributor-account-trazado::after {
    left: -7px;
    right: -200px;
    top: 20px;
    height: 117%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
  }

  body.lang-es .become-trazado::after {
    left: -7px;
    right: -200px;
    top: 28px;
    height: 220%;
    background-image: var(--localized-img-become-green);
  }

  body.lang-es .my-brand-trazado::after {
    left: -10px;
    right: -200px;
    top: 55px;
    height: 393%;
    width: 156px;
    background-image: var(--localized-img-mybrand-red);
  }

  body.lang-nl .become-trazado::after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 28px;
    transform: translateY(-50%);
    height: 210%;
    background-image: var(--localized-img-become-green);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-nl .my-brand-trazado::after {
    content: "";
    position: absolute;
    left: -10px;
    right: -200px;
    top: 49px;
    transform: translateY(-50%);
    height: 363%;
    width: 210px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }
}

body.lang-fr .my-brand-trazado:after {
  left: -16px;
}

/* Mobil 768px */

@media (max-width: 768px) {
  .contact-cards-wrapper {
    flex-direction: column;
    gap: 40px;
    max-width: 400px;
  }

  .contact-card {
    width: 100%;
  }

  .fletxa-hover-targetes-contacte {
    top: 50px;
    right: 30px;
  }
}

/* ==========================================================================
   Mobile Duplicate Layout (.mobile)
   ========================================================================== */

.mobile {
  display: none;
}

@media (min-width: 769px) {
  .mobile {
    display: none !important;
  }
}

@media (max-width: 768px) {
  body {
    overflow-x: hidden;
  }

  .desktop {
    display: none !important;
  }

  body {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    top: 0;
    background: #f0e9e4;
  }

  .mobile {
    display: block;
  }

  .mobile-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 3000;
    background: #fff;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
    padding: 14px 14px 12px;
    overflow-x: clip;
    height: 80px;
  }

  .mobile-header__inner {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: end;
    gap: 10px;
  }

  body.lang-de .mobile-header__inner {
    grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
  }

  body.lang-it .mobile-header__inner {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  }

  body.lang-es .mobile-header__inner {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  }

  body.lang-nl .mobile-header__inner {
    grid-template-columns: minmax(0, 0.79fr) minmax(0, 1.21fr);
  }

  .mobile-header__logo {
    width: clamp(118px, 36vw, 190px);
    max-width: 100%;
    min-width: 0;
    height: auto;
    justify-self: start;
  }

  .mobile-header__right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    min-width: 0;
    width: 100%;
  }

  .mobile-header__language {
    border: 0;
    background: transparent;
    color: #1d1d1d;
    font-size: clamp(12px, 3.2vw, 16px);
    line-height: 1;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    white-space: nowrap;
  }

  .mobile-header__language .flag-icon {
    width: 22px;
    height: 16px;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15);
  }

  .mobile-language-dropdown-wrapper {
    position: relative;
  }

  .language-dropdown--mobile {
    position: fixed;
    top: 92px;
    right: 14px;
    left: auto;
    width: min(92vw, 320px);
    z-index: 3600;
    transform: translateY(10px);
  }

  .language-dropdown--mobile.is-open {
    transform: translateY(0);
  }

  .language-dropdown--mobile .language-dropdown__item {
    font-size: 16px;
    padding: 10px 12px;
  }

  .mobile-header__ecommerce {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 186px;
    min-width: 0;
    font-size: clamp(10px, 2.8vw, 14px);
    padding: 9px 12px;
    line-height: 1.05;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
  }

  body.lang-de .mobile-header__ecommerce {
    max-width: 100%;
    font-size: clamp(9px, 2.45vw, 12px);
    padding: 8px 10px;
  }

  body.lang-it .mobile-header__ecommerce {
    max-width: 100%;
    font-size: clamp(9px, 2.45vw, 12px);
    padding: 8px 10px;
  }

  body.lang-es .mobile-header__ecommerce {
    max-width: 100%;
    font-size: clamp(9px, 2.45vw, 12px);
    padding: 8px 10px;
    line-height: 1.1;
  }

  body.lang-nl .mobile-header__ecommerce {
    width: auto;
    max-width: 210px;
    font-size: clamp(9.2px, 2.35vw, 12px);
    padding: 8px 31px;
    line-height: 1.1;
    letter-spacing: 0;
  }

  @media (max-width: 390px) {
    body.lang-de .mobile-header__ecommerce {
      font-size: 8.5px;
      padding: 7px 8px;
    }

    body.lang-it .mobile-header__ecommerce {
      font-size: 8.5px;
      padding: 7px 8px;
    }

    body.lang-es .mobile-header__ecommerce {
      font-size: 8.5px;
      padding: 7px 8px;
    }

    body.lang-nl .mobile-header__ecommerce {
      font-size: 8.4px;
      padding: 7px 9px;
    }
  }

  .mobile-ecommerce-dropdown-wrapper {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: flex-end;
  }

  .mobile-ecommerce-dropdown {
    position: fixed;
    top: 92px;
    left: 50%;
    right: auto;
    width: min(92vw, 420px);
    max-height: none;
    overflow: visible;
    padding: 12px;
    transform: translate(-50%, 10px);
    z-index: 3500;
  }

  .mobile-ecommerce-dropdown.is-open {
    transform: translate(-50%, 0);
  }

  .mobile-ecommerce-dropdown .ecommerce-dropdown-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 10px;
  }

  .mobile-ecommerce-dropdown .ecommerce-dropdown-list a {
    font-size: 15px;
    line-height: 1.2;
    padding: 10px 12px;
    min-height: 48px;
    gap: 9px;
    border-radius: 10px;
  }

  .mobile-ecommerce-dropdown .ecommerce-dropdown-list .flag-icon {
    width: 22px;
    height: 16px;
  }

  @media (max-height: 740px) {
    .mobile-ecommerce-dropdown {
      max-height: none;
      overflow: visible;
      padding: 8px;
    }

    .mobile-ecommerce-dropdown .ecommerce-dropdown-list {
      gap: 4px 6px;
    }

    .mobile-ecommerce-dropdown .ecommerce-dropdown-list a {
      min-height: 32px;
      font-size: 12px;
      line-height: 1.1;
      padding: 5px 7px;
      gap: 6px;
      border-radius: 8px;
    }

    .mobile-ecommerce-dropdown .ecommerce-dropdown-list .flag-icon {
      width: 16px;
      height: 12px;
    }
  }

  .mobile-layout {
    max-width: 640px;
    margin: 0 auto;
    padding: 100px 20px 0;
  }

  .mobile-section {
    width: 100%;
    margin: 0 auto 70px;
    padding: 0;
    overflow: visible;
  }

  .mobile.mobile-section {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: visible !important;
  }

  .mobile-hero-section {
    display: block;
    margin-bottom: 28px;
  }

  @supports (height: 100dvh) {
    .mobile-hero-section {
      height: auto;
      min-height: 0;
    }
  }

  .mobile-hero-card {
    position: relative;
    border-radius: 34px;
    overflow: hidden;
    background: #121212;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25);
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 9 / 16;
    max-height: none;
    min-height: 0;
    justify-self: stretch;
  }

  .mobile-hero-card video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.15);
  }

  .mobile-hero-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      to top,
      rgba(12, 12, 12, 0.95) 2%,
      rgba(15, 15, 15, 0.6) 34%,
      rgba(15, 15, 15, 0.2) 62%,
      rgba(15, 15, 15, 0.24) 100%
    );
  }

  .mobile-hero-card__content {
    position: absolute;
    inset: 0;
    z-index: 2;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    text-align: center;
    padding: 114px 28px 120px;
    height: 100%;
  }

  .mobile-hero-card__content h2 {
    margin: 0;
    padding: 0;
    font-size: clamp(34px, 7.2vw, 56px) !important;
    line-height: 1.02;
    letter-spacing: -0.2px;
  }

  .mobile-hero-card__content img {
    width: min(76%, 380px);
    height: auto;
    margin-top: 6px;
  }

  .mobile-hero-card__content h3 {
    margin: auto 0 14px;
    max-width: 500px;
    font-size: clamp(13px, 3.3vw, 34px);
    line-height: 1.15;
    font-weight: 700;
  }

  body.lang-de .mobile-hero-card__content h3 {
    font-size: clamp(14px, 3.6vw, 20px);
    line-height: 1.14;
    white-space: nowrap;
  }

  .mobile-hero-card__scroll {
    margin: 0;
    color: #ff7000;
    font-size: clamp(19px, 2.2vw, 50px);
    line-height: 1;
    font-weight: 700;
    transform: rotate(-2deg);
  }

  .mobile-hero-arrow {
    display: block;
    position: relative;
    z-index: 10;
    width: clamp(30px, 8vw, 48px);
    margin: 0 auto;
    margin-top: calc(clamp(30px, 8vw, 48px) * -1.5);
    animation: bounce 2s ease-in-out infinite;
  }

  .mobile-who-section {
    position: relative;
    padding: 18px 12px 24px;
    margin-bottom: 0;
    background-image: url("https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_05-lineas.svg");
    background-repeat: repeat-y;
    background-position: center;
    background-size: 120% auto;
  }

  .mobile-who-section__grid {
    display: grid;
    grid-template-columns: clamp(55px, 16vw, 110px) 1fr;
    gap: 0 8px;
    align-items: start;
    margin-bottom: 16px;
  }

  .mobile-who-section__pen-col {
    grid-row: 1 / 2;
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }

  .mobile-who-section__pen-col canvas {
    width: 100%;
    height: auto;
    margin-top: 20px;
  }

  .mobile-who-section__content-col {
    grid-row: 1 / 2;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-start;
    padding-top: 20px;
  }

  .mobile-who-section__annotation {
    display: inline-block;
    font-size: clamp(14px, 3.8vw, 22px);
    color: #333;
    margin-bottom: 4px;
    padding: 2px 8px;
    border: 2px solid #2f4089;
    border-radius: 50%;
    transform: rotate(-3deg);
    align-self: flex-end;
    margin-right: 8px;
  }

  .mobile-who-section__content-col h2 {
    margin: 0;
    padding: 0;
    text-align: left;
    font-size: clamp(34px, 4.8vh, 50px) !important;
    line-height: 1.02;
    width: 100%;
    transform: translateY(84px);
  }

  body.lang-es .mobile-who-section__content-col h2 {
    font-size: clamp(26px, 3.9vh, 38px) !important;
    line-height: 1;
    white-space: nowrap;
  }

  body.lang-fr .mobile-who-section__content-col h2 {
    font-size: clamp(22px, 6.4vw, 32px) !important;
    line-height: 1;
    white-space: nowrap;
    transform: translateY(68px);
    padding-left: 10px;
    padding-right: 0;
    overflow: visible;
  }

  body.lang-fr .mobile-who-section .circle-we-svg {
    left: -10px;
    width: calc(100% + 22px);
    height: 165%;
  }

  body.lang-fr .mobile-who-section .circle-we-filled {
    left: 12px;
    top: -42%;
  }

  body.lang-it .mobile-who-section .circle-we-filled {
    top: -84%;
  }

  body.lang-es .mobile-who-section .circle-we-svg {
    width: calc(100% + 22px);
    left: -12px;
    transform: translateY(-50%) scaleY(0.78) scaleX(1.5);
    transform-origin: center center;
  }

  body.lang-es .mobile-who-section .circle-we-filled {
    width: 130px;
    left: 8px;
    top: -68%;
  }

  .mobile-who-section .circle-we-svg {
    width: calc(100% + 22px);
    height: 170%;
    left: -12px;
  }

  .mobile-who-section__logo {
    width: min(72%, 400px);
    display: block;
    margin: 0 auto 24px;
  }

  .mobile-who-section__columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 0 12px;
    align-items: start;
    margin-bottom: 8px;
  }

  .mobile-who-section__column {
    text-align: center;
    padding: 0;
  }

  .mobile-who-section__column img {
    width: min(100%, 210px);
    margin: 0 auto 16px;
  }

  .mobile-who-section__column p {
    max-width: 105px;
    margin: 0 auto;
    font-size: clamp(13px, 3.2vw, 18px);
    line-height: 1.08;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .mobile-who-section__blue {
    color: #273d97;
    margin-top: 18px !important;
    font-size: clamp(14px, 3.7vw, 21px) !important;
    max-width: 140px !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
  }

  .mobile-who-section__blue--everyone {
    max-width: 100px !important;
  }

  body.lang-fr .mobile-who-section__columns {
    gap: 12px;
    padding: 0 8px;
  }

  body.lang-fr .mobile-who-section__column p {
    max-width: 148px;
    overflow-wrap: normal;
    word-break: normal;
  }

  body.lang-fr .mobile-who-section__blue {
    max-width: 170px !important;
  }

  body.lang-fr .mobile-who-section__blue--everyone {
    max-width: 130px !important;
  }

  body.lang-es .mobile-who-section__column p {
    max-width: 130px;
  }

  body.lang-en .mobile-who-section__column p {
    max-width: 150px;
    overflow-wrap: normal;
    word-break: normal;
  }

  body.lang-nl .mobile-who-section__column p {
    max-width: 155px;
    overflow-wrap: normal;
    word-break: normal;
  }

  body.lang-es .mobile-who-section__blue {
    max-width: 150px !important;
  }

  body.lang-en .mobile-who-section__blue {
    max-width: 175px !important;
  }

  body.lang-nl .mobile-who-section__blue {
    max-width: 190px !important;
  }

  body.lang-es .mobile-who-section__blue--everyone {
    max-width: 118px !important;
  }

  body.lang-en .mobile-who-section__blue--everyone {
    max-width: 145px !important;
  }

  body.lang-nl .mobile-who-section__blue--everyone {
    max-width: 145px !important;
  }

  body.lang-de .mobile-who-section__column p {
    max-width: 150px;
    font-size: clamp(12px, 2.8vw, 17px);
    line-height: 1.04;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: auto;
  }

  body.lang-de .mobile-who-section__blue {
    font-size: clamp(13px, 3.2vw, 19px) !important;
    max-width: none !important;
    white-space: nowrap;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  body.lang-de .mobile-who-section__blue[data-i18n="for-professionals"] {
    max-width: none !important;
    white-space: nowrap;
    overflow-wrap: normal !important;
    word-break: normal !important;
    display: inline-block;
  }

  .mobile-notebook-section {
    background-image: none;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 120% auto;
    padding: 12px 0 24px;
    margin-top: 0;
    margin-bottom: 0;
    overflow-x: clip;
    margin-left: -20px;
    margin-right: -20px;
    padding-left: 20px;
    padding-right: 20px;
    width: calc(100% + 40px);
    max-width: 100vw;
  }

  .mobile-notebook-section__intro {
    margin: 0 auto 28px;
    max-width: 540px;
    text-align: center;
    font-size: clamp(18px, 4.6vw, 34px);
    line-height: 1.28;
    top: 20px;
    position: absolute;
    transform: translate(50%, 0);
  }

  .mobile-notebook-section__intro strong {
    font-weight: 700;
  }

  .mobile-notebook-section__visual {
    position: relative;
    width: 100%;
    margin-top: 240px;
    padding-bottom: 48px;
    min-height: 520px;
  }

  .mobile-notebook-section__overlay-group {
    overflow: visible;
    position: absolute;
    right: calc(-480px + 50vw);
    margin-top: -14%;
  }

  .mobile-notebook-section__image {
    width: 600px;
    display: block;
    transform: rotate(-8deg);
    max-width: unset;
    margin-left: 50px;
  }

  .mobile-notebook-section__highlighter {
    position: absolute;
    bottom: 310px;
    left: -86px;
    width: 66%;
    transform: rotate(299deg);
    z-index: 2;
  }

  .mobile-notebook-section__overlay {
    position: absolute;
    left: 2%;
    top: 21%;
    width: 60%;
    margin: 0;
    font-size: clamp(14px, 2.7vw, 18px);
    line-height: 1.2;
    text-align: left;
    color: #253888 !important;
    z-index: 3;
    transform: rotate(352deg);
    text-align: center;
  }

  .mobile-notebook-section__overlay .notebook-overlay-title {
    font-size: 1.28em;
  }

  .mobile-notebook-section__overlay .notebook-overlay-strong {
    font-size: 1.2em;
    margin: 4px 0 28px;
  }

  .mobile-notebook-section__overlay .notebook-highlight {
    margin-top: 30px;
  }

  body.lang-de .mobile-notebook-section__overlay {
    top: 28%;
    font-size: clamp(12px, 2.35vw, 16px);
    line-height: 1.16;
  }

  body.lang-de .mobile-notebook-section__overlay .notebook-overlay-title {
    font-size: 1.16em;
  }

  body.lang-de .mobile-notebook-section__overlay .notebook-overlay-strong {
    font-size: 1.08em;
    margin: 2px 0 18px;
  }

  body.lang-de .mobile-notebook-section__overlay .notebook-highlight {
    margin-top: 18px;
  }

  body.lang-it .mobile-notebook-section__overlay {
    left: 2.5%;
    top: 19%;
  }

  .mobile-notebook-section__paperplane {
    position: absolute;
    right: 81%;
    bottom: 0;
    width: clamp(80px, 22vw, 140px);
    transform: rotate(15deg);
    z-index: 4;
  }

  .mobile-notebook-section__arrow-down {
    display: block;
    width: clamp(56px, 11vw, 88px);
    margin: 6px auto 0;
    transform: rotate(12deg);
  }

  .mobile-cards-section {
    text-align: center;
    margin-top: 18px;
    overflow-x: clip !important;
    overflow-y: visible !important;
    margin-left: -20px;
    margin-right: -20px;
    padding-left: 20px;
    padding-right: 20px;
    width: calc(100% + 40px);
  }

  .mobile-cards-section__title {
    position: relative;
    display: inline-block;
  }

  .mobile-cards-section__title h2 {
    margin: 0;
    padding: 0;
    font-size: clamp(31px, 4.4vh, 46px) !important;
    line-height: 1.02;
  }

  .mobile-cards-section__title svg {
    position: absolute;
    width: 100%;
    left: 0;
    bottom: -6px;
  }

  .mobile-cards-section > h2:last-of-type {
    margin: 0 0 26px;
    font-size: clamp(31px, 4.4vh, 46px) !important;
    line-height: 1.16;
    padding: 0;
  }

  .mobile-cards-section > h2:last-of-type .co-create-last-line {
    display: block;
    white-space: nowrap;
    line-height: inherit;
  }

  body.lang-de .mobile-cards-section__title h2,
  body.lang-de .mobile-cards-section > h2:last-of-type {
    font-size: clamp(28px, 3.9vh, 41px) !important;
    line-height: 1.1;
  }

  body.lang-nl .mobile-cards-section__title h2,
  body.lang-nl .mobile-cards-section > h2:last-of-type {
    font-size: clamp(26px, 3.5vh, 38px) !important;
    line-height: 1.07;
  }

  body.lang-nl .mobile-cards-section__title svg {
    bottom: -2px;
  }

  .mobile-cards-click-discover {
    display: block;
    width: clamp(74px, 20vw, 118px);
    margin: 0 auto 10px;
    pointer-events: none;
    transform-origin: 70% 100%;
  }

  .mobile-cards-section__stack {
    display: none;
  }

  .mobile-cards-section__scroll-wrapper {
    width: calc(100% + 40px);
    margin-left: -20px;
    overflow: hidden;
    padding: 20px 0;
    position: relative;
    touch-action: pan-y;
  }

  .mobile-cards-section__cards-container {
    position: relative;
    width: 70vw;
    max-width: 300px;
    margin: 0 auto;
    aspect-ratio: 0.65 / 1;
  }

  .mobile-card {
    perspective: 1000px;
    position: absolute;
    width: 70vw;
    max-width: 300px;
    aspect-ratio: 0.65 / 1;
    border-radius: 20px;
  }

  .mobile-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
  }

  .mobile-card-front,
  .mobile-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s ease;
  }

  .mobile-card-front {
    opacity: 1;
    z-index: 2;
  }

  .mobile-card-back {
    opacity: 0;
    z-index: 1;
  }

  .mobile-card.flipped .mobile-card-front {
    opacity: 0;
  }

  .mobile-card.flipped .mobile-card-back {
    opacity: 1;
  }

  .mobile-card-front img,
  .mobile-card-back img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .mobile-card-1 {
    z-index: 3;
  }

  .mobile-card-2 {
    z-index: 2;
  }

  .mobile-card-3 {
    z-index: 1;
  }

  .mobile-because-section {
    position: relative;
    text-align: center;
    padding-top: 20px;
  }

  .mobile-because-section__think {
    width: clamp(120px, 22vw, 180px);
    position: absolute;
    left: 10px;
    top: -50px;
    z-index: 2;
  }

  /* ── Top graphic: laptop, YEAH, music notes, cassette ── */
  .mobile-because-section__graphic-top {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 0.82;
    margin-top: 50px;
  }

  .mobile-because-section__graphic-top img {
    position: absolute;
    max-width: none;
    height: auto;
  }

  /* 1 – Laptop */
  .mobile-because-graphic--1 {
    width: 38%;
    left: 0;
    bottom: 5%;
    top: auto;
  }

  /* 2 – YEAH speech bubble */
  .mobile-because-graphic--2 {
    width: 22%;
    left: 20%;
    top: 48%;
  }

  /* 3 – Music notes */
  .mobile-because-graphic--3 {
    width: 26%;
    left: 38%;
    top: 54%;
  }

  /* 4 – Cassette tape */
  .mobile-because-graphic--4 {
    width: 52%;
    right: -5%;
    top: 10%;
    left: auto;
  }

  /* ── Bottom graphic: products, cross-hatch, cursor, dots ── */
  .mobile-because-section__graphic-bottom {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 0.5;
    margin-bottom: 20px;
  }

  .mobile-because-section__graphic-bottom img {
    position: absolute;
    max-width: none;
    height: auto;
  }

  /* 8 – Products / pens (left) */
  .mobile-because-graphic--8 {
    width: 28%;
    left: 0;
    bottom: 0;
    top: auto;
  }

  /* 6 – Red cross-hatch (center) */
  .mobile-because-graphic--6 {
    width: 20%;
    left: 58%;
    bottom: 44%;
    top: auto;
  }

  /* 7 – Cursor / arrow stars (center-right) */
  .mobile-because-graphic--7 {
    width: 22%;
    left: 30%;
    bottom: 25%;
    top: auto;
  }

  /* 5 – Large coloured dots (right) */
  .mobile-because-graphic--5 {
    width: 30%;
    right: 0;
    top: 0;
    left: auto;
  }

  .mobile-because-section__text {
    margin: 10px auto 18px;
    max-width: 560px;
    color: #253888;
    font-size: clamp(14px, 3.8vw, 28px);
    line-height: 1.06;
    font-weight: 700;
    position: relative;
    z-index: 1;
  }

  body.lang-fr .mobile-because-section__text {
    font-size: clamp(16px, 4vw, 24px);
    line-height: 1.04;
  }

  body.lang-de .mobile-because-section__text {
    font-size: clamp(15px, 3.8vw, 22px);
    line-height: 1.04;
  }

  body.lang-it .mobile-because-section__text {
    font-size: clamp(14px, 3.5vw, 20px);
    line-height: 1.04;
  }

  .mobile-because-section__video {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.16);
  }

  .mobile-because-section__video video {
    width: 100%;
    display: block;
    aspect-ratio: 16 / 9;
    object-fit: cover;
  }

  .mobile-joy-section {
    position: relative;
    padding-top: 140px;
    padding-bottom: 120px;
    height: auto;
    max-height: none;
    overflow: visible;
    margin-left: -20px;
    margin-right: -20px;
    padding-left: 20px;
    padding-right: 20px;
    width: calc(100% + 40px);
  }

  .mobile-joy-section__business {
    position: absolute;
    right: 10px;
    top: -75px;
    width: clamp(140px, 40vw, 260px);
    opacity: 0;
    transform: translateY(20px) scale(0.98);
  }

  .mobile-joy-section__title {
    margin: 0;
    padding: 0;
    text-align: left;
    font-size: clamp(30px, 7.1vw, 48px) !important;
    line-height: 1.05;
    letter-spacing: -0.2px;
    max-width: 68%;
    opacity: 0;
    transform: translateY(30px);
  }

  body.lang-it .mobile-joy-section__title {
    font-size: clamp(25px, 6.2vw, 39px) !important;
    line-height: 1.04;
    max-width: 72%;
  }

  .mobile-boli-pw {
    position: absolute;
    width: clamp(55px, 12vw, 90px);
    right: 4px;
    top: 220px;
    rotate: 30deg;
    transform-origin: 50% 96%;
    z-index: 10;
    pointer-events: none;
  }

  .mobile-pw-wrapper {
    position: relative;
    display: inline-block;
  }

  .mobile-underline-svg {
    position: absolute;
    left: 0;
    bottom: -8px;
    width: 100%;
    height: 10px;
    pointer-events: none;
    overflow: visible;
  }

  .mobile-wavy-path {
    stroke: #ce0c17;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
  }

  .mobile-joy-section__arrow {
    width: clamp(82px, 14vw, 126px);
    position: absolute;
    right: clamp(26px, 7vw, 42px);
    bottom: -60px;
    opacity: 0;
    transform: translateY(20px);
  }

  .mobile-inspire-section {
    position: relative;
    padding-top: 6px;
    text-align: center;
    height: auto;
    max-height: none;
    overflow: visible;
  }

  .mobile-inspire-section__card {
    position: relative;
    border-radius: 30px;
    background: #d8d0ca;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.16);
    cursor: pointer;
    aspect-ratio: 4 / 5;
  }

  .mobile-inspire-pagination {
    margin-top: 14px;
    margin-bottom: 6px;
  }

  .mobile-inspire-img {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    z-index: 1;
  }

  .mobile-inspire-img.is-active {
    opacity: 1;
    z-index: 2;
  }

  .mobile-inspire-section__cursor {
    position: absolute;
    top: clamp(10px, 2.8vw, 16px);
    left: clamp(10px, 2.8vw, 16px);
    width: clamp(96px, 26vw, 148px);
    height: auto;
    z-index: 4;
    pointer-events: none;
  }

  .mobile-inspire-section__pen {
    position: absolute;
    left: 50%;
    top: 48%;
    transform: translate(-50%, -50%) rotate(4deg);
    width: min(18%, 96px);
  }

  .mobile-inspire-section__bulb {
    width: 90%;
    max-width: 420px;
    margin: 20px 0 8px -45px;
    display: block;
    opacity: 0;
    visibility: hidden;
  }

  .mobile-inspire-section__text {
    margin: 0;
    font-size: clamp(18px, 4.2vw, 28px) !important;
    line-height: 1.1;
    letter-spacing: 0.4px;
  }

  .mobile-better-section {
    position: relative;
    text-align: center;
    overflow: visible;
    margin-top: 18px;
    margin-left: -20px;
    margin-right: -20px;
    padding-left: 20px;
    padding-right: 20px;
    width: calc(100% + 40px);
  }

  .mobile-better-section__video {
    position: relative;
    border-radius: 30px;
    overflow: visible;
    margin-bottom: 34px;
  }

  .mobile-better-section__video video {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 30px;
    position: relative;
    z-index: 1;
  }

  .mobile-better-video-bling {
    position: absolute;
    pointer-events: none;
    z-index: 2;
    height: auto;
  }

  .mobile-better-video-bling--1 {
    width: clamp(58px, 14vw, 90px);
    top: clamp(-44px, -9vw, -26px);
    left: clamp(-40px, -9vw, -24px);
  }

  .mobile-better-video-bling--2 {
    width: clamp(66px, 17vw, 112px);
    right: clamp(-18px, -3.5vw, -6px);
    bottom: clamp(-34px, -7vw, -18px);
  }

  .mobile-better-section h2 {
    margin: 0;
    padding: 0;
    font-size: clamp(34px, 4.8vh, 50px) !important;
    line-height: 1.04;
  }

  .mobile-better-section h2 .co-create-better-future-line2 {
    display: block;
  }

  .mobile-better-section__subtitle {
    margin: 14px auto 24px;
    color: #0f833a;
    font-size: clamp(16px, 3.5vw, 36px);
    line-height: 1.05;
    font-weight: 700;
    max-width: none;
  }

  .mobile-better-swiper {
    position: relative;
    width: calc(100% + 40px);
    margin: 0 0 0 -20px;
    padding: 132px 0 84px;
    height: auto;
    overflow: hidden !important;
  }

  .mobile-better-swiper-deco {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    height: auto;
  }

  .mobile-better-swiper-deco--1 {
    top: clamp(0px, calc(92px - 17vw), 32px);
    right: clamp(8px, 3vw, 24px);
    width: clamp(72px, 18vw, 120px);
  }

  .mobile-better-swiper-deco--2 {
    left: clamp(8px, 2.8vw, 20px);
    bottom: clamp(0px, calc(44px - 8vw), 20px);
    width: clamp(70px, 17vw, 114px);
  }

  .mobile-better-swiper .swiper-wrapper,
  .mobile-better-swiper .mobile-better-pagination {
    position: relative;
    z-index: 1;
  }

  .mobile-better-swiper .swiper-wrapper {
    align-items: flex-start;
    height: auto;
  }

  .mobile-better-swiper .swiper-slide,
  .mobile-better-slide {
    height: auto;
    overflow-y: visible;
  }

  .mobile-better-slide {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-left: 0;
  }

  .mobile-better-slide__card {
    position: relative;
    overflow: visible;
    width: 84%;
    margin: 0 auto;
  }

  .mobile-better-slide__img {
    width: 100%;

    display: block;
  }

  .mobile-better-slide__boli {
    position: absolute;
    width: 12%;
    height: auto;
    z-index: 10;
    filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.25));
    pointer-events: none;
  }

  .mobile-better-slide__boli--1 {
    top: -26%;
    left: 22%;
    transform: rotate(75deg);
  }

  .mobile-better-slide__boli--2 {
    top: -21%;
    left: 18%;
    transform: rotate(40deg);
  }

  .mobile-better-slide__boli--3 {
    top: -30%;
    left: 22%;
    transform: rotate(75deg);
  }

  .mobile-better-slide__boli--4 {
    top: -71%;
    left: 44%;
    transform: rotate(90deg);
  }

  .mobile-better-slide__text {
    text-align: left;
    width: 84%;
    margin: 0 auto;
    padding: 0;
  }

  .mobile-better-slide__text p {
    max-width: none;
    text-align: left;
    font-size: clamp(14px, 3.6vw, 22px);
    line-height: 1.3;
    margin: 0 0 8px;
  }

  .mobile-better-slide__text ul {
    margin: 0;
    padding-left: 0;
    list-style: none;
  }

  .mobile-better-slide__text li {
    font-size: clamp(14px, 3.6vw, 22px);
    line-height: 1.35;
    margin-bottom: 4px;
  }

  .mobile-better-slide__text li::before {
    content: "·";
    margin-right: 4px;
    font-weight: 700;
  }

  .mobile-better-pagination {
    margin-top: 16px;
  }

  .mobile-better-pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: #ccc;
    opacity: 1;
  }

  .mobile-better-pagination .swiper-pagination-bullet-active {
    background: #0f833a;
  }

  .mobile-better-section__cta {
    position: relative;
    width: 100%;
    max-width: 560px;
    margin: 96px auto 0;
  }

  .mobile-cta-arrow {
    position: absolute;
    width: clamp(80px, 22vw, 140px);
    opacity: 0;
    z-index: 5;
  }

  .mobile-cta-arrow-1 {
    top: -3%;
    left: 3%;
  }

  .mobile-cta-arrow-2 {
    bottom: 0%;
    right: 6%;
  }

  .mobile-better-section__cta img {
    width: 100%;
    display: block;
    opacity: 0.95;
  }

  .mobile-better-section__cta .animated-gradient-button {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    min-width: 326px;
    font-size: clamp(18px, 4.5vw, 28px);
    font-weight: 700;
    padding: 9px 24px;
  }

  .mobile-certs-section {
    padding-top: 8px;
  }

  .mobile-certs-section img {
    width: 100%;
    display: block;
  }

  .mobile-novelties-section {
    text-align: center;
    padding-top: 160px;
    padding-bottom: 40px;
    position: relative;
    overflow: visible;
    margin-bottom: 10px;
  }

  .mobile-novelties-deco {
    position: absolute !important;
    pointer-events: none;
    z-index: 2;
    display: block !important;
  }

  .mobile-novelties-deco--arrow-down {
    width: clamp(80px, 22vw, 140px);
    top: -6%;
    left: 8%;
  }

  .mobile-novelties-deco--ojos {
    width: clamp(60px, 16vw, 100px);
    top: 40%;
    left: 25%;
  }

  .mobile-novelties-deco--flechas {
    width: clamp(60px, 17vw, 120px);
    top: 39%;
    left: 0%;
    transform: rotate(79deg);
  }

  .mobile-novelties-deco--star {
    width: clamp(150px, 60vw, 180px);
    bottom: -105px;
    right: 2%;
  }

  .mobile-novelties-deco--wow {
    width: clamp(60px, 16vw, 80px);
    bottom: -3%;
    right: -4%;
  }

  .mobile-latest-novelties-wrapper {
    position: relative;
    display: inline-block;
  }

  .mobile-novelties-section h2 {
    margin: 0;
    padding: 0;
    font-size: clamp(34px, 3.8vh, 50px) !important;
    line-height: 1.02;
    position: relative;
    display: inline-block;
  }

  .mobile-latest-novelties-underline {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    width: 100%;
    height: auto;
    pointer-events: none;
    z-index: 1;
  }

  .mobile-latest-novelties-path {
    stroke-dasharray: 3000;
    stroke-dashoffset: 3000;
  }

  .mobile-swiper {
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    margin-top: 140px;
  }

  .mobile-swiper .swiper-slide video {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
  }

  .mobile-swiper-pagination {
    position: static !important;
    margin-top: 16px;
  }

  .mobile-novelties-section__balloons {
    width: clamp(208px, 20vw, 150px);
    margin: 0 auto;
  }

  .mobile-feeling-inspired-wrapper {
    position: relative;
    display: inline-block;
    width: fit-content;
    align-self: center;
    margin: 0 auto;
  }

  .mobile-feeling-inspired-underline {
    position: absolute;
    bottom: -2px;
    right: 8px;
    width: 53%;
    height: auto;
    pointer-events: none;
    z-index: 1;
  }

  body.lang-de .mobile-feeling-inspired-underline {
    left: 0;
    right: 0;
    width: 100%;
    bottom: -1px;
  }

  body.lang-nl .mobile-feeling-inspired-underline {
    left: 0;
    right: auto;
    width: 58%;
  }

  .mobile-feeling-inspired-path {
    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;
  }

  .mobile-novelties-section__feeling {
    margin: 0;
    padding: 0;
    font-size: clamp(28px, 8vw, 74px) !important;
    line-height: 1.02;
  }

  .mobile-novelties-section__contact {
    margin: -8px 0 0;
    padding: 0;
    font-size: clamp(28px, 8vw, 74px) !important;
    line-height: 1.02;
  }

  body.lang-de .mobile-cards-section__title h2,
  body.lang-de .mobile-cards-section > h2:last-of-type,
  body.lang-de .mobile-better-section h2,
  body.lang-de .mobile-novelties-section__feeling,
  body.lang-de .mobile-novelties-section__contact {
    font-size: clamp(26px, 7.1vw, 38px) !important;
    line-height: 1.06;
  }

  body.lang-fr .mobile-cards-section__title h2,
  body.lang-fr .mobile-cards-section > h2:last-of-type,
  body.lang-fr .mobile-better-section h2,
  body.lang-fr .mobile-novelties-section h2 {
    font-size: clamp(28px, 7.2vw, 40px) !important;
    line-height: 1.06;
  }

  body.lang-fr .mobile-cards-section__title h2,
  body.lang-fr .mobile-cards-section > h2:last-of-type {
    font-size: clamp(26px, 6.6vw, 37px) !important;
  }

  body.lang-fr .mobile-novelties-section__feeling,
  body.lang-fr .mobile-novelties-section__contact {
    font-size: clamp(26px, 8vw, 42px) !important;
    line-height: 1.04;
  }

  body.lang-fr .mobile-better-section__subtitle {
    font-size: clamp(17px, 3.9vw, 28px);
    line-height: 1.42;
  }

  body.lang-fr .mobile-cards-section__title svg {
    bottom: -1px;
  }

  body.lang-fr
    .mobile-cards-section
    h2[data-i18n="cocreate-with-us"]
    .co-trazado::before {
    left: -70px;
    right: 14px;
  }

  body.lang-fr
    .mobile-cards-section
    h2[data-i18n="cocreate-with-us"]
    .us-trazado::after {
    left: 14px;
    right: -62px;
  }

  .mobile-contact-section {
    display: flex;
    flex-direction: column;
    gap: 26px;
    margin-bottom: 14px;
  }

  .mobile-contact-card {
    display: block;
    position: relative;
    border-radius: 30px;
    overflow: hidden;
    text-decoration: none;
    color: #000;
  }

  .mobile-contact-card__arrow {
    position: absolute;
    top: 18px;
    right: 18px;
    font-size: 22px;
    font-weight: 400;
    color: #000;
    line-height: 1;
    z-index: 2;
    pointer-events: none;
  }

  .mobile-contact-card h3 {
    margin: 0;
    padding: 64px 50px 32px 20px;
    text-align: left;
    font-size: clamp(22px, 5.8vw, 34px);
    line-height: 1.1;
    font-weight: 700;
    position: relative;
    overflow: hidden;
  }

  .mobile-contact-card video,
  .mobile-contact-card img {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
  }

  .mobile-contact-card--cyan {
    background: #13a3b7;
  }

  .mobile-contact-card--yellow {
    background: #cab845;
  }

  .mobile-contact-card--pink {
    background: #f29399;
    margin-bottom: 0;
  }

  .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -3px;
    right: -200px;
    top: 9px;
    transform: translateY(-50%);
    height: 133%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-de .distributor-account-trazado::after {
    top: 10px;
    left: -1px;
    right: -169px;
    height: 179%;
  }

  body.lang-nl .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -3px;
    right: -200px;
    top: 9px;
    transform: translateY(-50%);
    height: 161%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-it .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -3px;
    right: -200px;
    top: 9px;
    transform: translateY(-50%);
    height: 161%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-fr .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -3px;
    right: -200px;
    top: 9px;
    transform: translateY(-50%);
    height: 159%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-en .distributor-account-trazado::after {
    content: "";
    position: absolute;
    left: -3px;
    right: -200px;
    top: 9px;
    transform: translateY(-50%);
    height: 153%;
    background-image: url(https://cdn.bicgraphic.com/landing/assets/imgs/BGE_Landing_30-dibujo-distributor1-azul.png);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  .become-trazado:after {
    content: "";
    position: absolute;
    left: -4px;
    right: -200px;
    top: 21px;
    transform: translateY(-50%);
    height: 250%;
    background-image: var(--localized-img-become-green);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-de .become-trazado::after {
    top: 10px;
    left: -16px;
    right: -200px;
    height: 135%;
  }

  body.lang-it .become-trazado:after {
    content: "";
    position: absolute;
    left: -4px;
    right: -200px;
    top: 31px;
    transform: translateY(-50%);
    height: 360%;
    background-image: var(--localized-img-become-green);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-fr .become-trazado:after {
    content: "";
    position: absolute;
    left: -4px;
    right: -200px;
    top: 27px;
    transform: translateY(-50%);
    height: 290%;
    background-image: var(--localized-img-become-green);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-en .become-trazado:after {
    content: "";
    position: absolute;
    left: -4px;
    right: -200px;
    top: 28px;
    transform: translateY(-50%);
    height: 310%;
    background-image: var(--localized-img-become-green);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 26px;
    transform: translateY(-50%);
    height: 268%;
    width: 184px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-nl .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 26px;
    transform: translateY(-50%);
    height: 277%;
    width: 193px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-de .my-brand-trazado::after {
    left: -9px;
    right: -272px;
    top: 23px;
    width: 221px;
    height: 249%;
  }

  body.lang-it .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 35px;
    transform: translateY(-50%);
    height: 438%;
    width: 186px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-fr .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -16px;
    right: -203px;
    top: 30px;
    transform: translateY(-50%);
    height: 287%;
    width: 197px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  body.lang-en .my-brand-trazado:after {
    content: "";
    position: absolute;
    left: -7px;
    right: -200px;
    top: 32px;
    transform: translateY(-50%);
    height: 288%;
    width: 224px;
    background-image: var(--localized-img-mybrand-red);
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1;
    pointer-events: none;
  }

  .mobile-footer {
    display: block;
    max-width: 440px;
    margin: 0 auto;
    padding: 20px 24px 56px;
    overflow-x: hidden;
    text-align: center;
    margin-top: 40px;
  }

  .mobile-footer__logo {
    width: min(66%, 300px);
    display: block;
    margin: 0 auto 29px;
  }

  .mobile-footer__follow {
    margin: 0 auto;
    font-size: clamp(34px, 9.6vw, 56px);
    text-align: center;
    max-width: none;
    line-height: 1;
  }

  .mobile-footer__follow-arrow {
    display: block;
    width: clamp(185px, 13vw, 82px);
    margin: 10px auto 21px;
  }

  body.lang-de .mobile-footer__follow-arrow {
    width: clamp(130px, 24vw, 155px);
    margin: 8px auto 16px;
  }

  .mobile-footer__social {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    width: 170px;
    margin: auto;
    margin-bottom: 36px;
  }

  .mobile-footer__social img {
    width: clamp(42px, 11vw, 62px);
    height: clamp(42px, 11vw, 62px);
    object-fit: contain;
  }

  .mobile-footer__links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-bottom: 96px;
  }

  .mobile-footer__links a {
    text-decoration: none;
    color: #111;
    font-size: 16px;
    line-height: 1.15;
  }

  .mobile-footer__bic-group {
    margin: 0 auto 9px;
    max-width: none;
    text-align: center;
    color: #de0019;
    font-size: clamp(40px, 10.2vw, 66px);
    line-height: 1;
  }

  .mobile-footer__bic-cta {
    position: relative;
    display: table;
    margin: 0 auto 36px;
  }

  .mobile-footer__bic-btn {
    display: inline-block;
    margin: 0;
    font-size: clamp(18px, 4.6vw, 30px);
    min-width: 138px;
    text-align: center;
    padding: 9px 24px;
  }

  .mobile-footer__bic-arrow {
    position: absolute;
    min-width: 160px;
    right: -24px;
    bottom: 27px;
    transform: rotate(-6deg);
    pointer-events: none;
  }

  body.lang-en .mobile-footer__bic-arrow {
    position: absolute;
    min-width: 160px;
    right: -24px;
    bottom: 37px;
    transform: rotate(-6deg);
    pointer-events: none;
  }

  body.lang-es .mobile-footer__bic-arrow {
    position: absolute;
    min-width: 130px;
    right: -6px;
    bottom: 36px;
    transform: rotate(-6deg);
    pointer-events: none;
  }

  body.lang-it .mobile-footer__bic-arrow {
    position: absolute;
    bottom: 50px;
    min-width: 100px;
    left: -20px;
    right: auto;
  }

  body.lang-fr .mobile-footer__bic-arrow {
    position: absolute;
    min-width: 160px;
    right: -8px;
    bottom: 39px;
    transform: rotate(-6deg);
    pointer-events: none;
  }

  body.lang-it footer img[src*="it/BGE_Landing_Flecha_Footer_BIC-web"] {
    position: absolute !important;
    bottom: 50px !important;
    min-width: 100px !important;
    left: 4px !important;
  }

  body.lang-de footer img[src*="BGE_Landing_Flecha_Footer_BIC-web"] {
    position: absolute !important;
    bottom: 40px !important;
    min-width: 114px !important;
    left: 0px !important;
  }

  .mobile-footer__copyright {
    text-align: center;
    font-size: 12px;
    line-height: 1.2;
  }

  .joy-trazado::after {
    left: -12px;
    right: -6px;
    top: 43%;
    height: 117%;
  }

  .simplicity-trazado::after {
    left: -0.28em;
    right: -0.28em;
    top: 41%;
    transform: translateY(-50%) scaleX(1.14);
    transform-origin: center;
    height: 1.15em;
    background-size: 185% 100%;
  }

  body.lang-fr .simplicity-trazado::after {
    left: -0.28em;
    right: -0.28em;
    top: 41%;
    transform: translateY(-50%) scaleX(1.44);
    transform-origin: center;
    height: 1.15em;
    background-size: 185% 100%;
  }

  body.lang-en .simplicity-trazado::after {
    left: -0.28em;
    right: -0.28em;
    top: 41%;
    transform: translateY(-50%) scaleX(1.44);
    transform-origin: center;
    height: 1.15em;
    background-size: 185% 100%;
  }

  body.lang-it .simplicity-trazado::after {
    left: -0.28em;
    right: -0.28em;
    top: 41%;
    transform: translateY(-50%) scaleX(1.44);
    transform-origin: center;
    height: 1.15em;
    background-size: 185% 100%;
  }

  body.lang-de .joy-trazado::after {
    left: -12px;
    right: -6px;
    top: -21%;
    height: 121%;
    transform: scaleX(1.3);
  }

  body.lang-de .simplicity-trazado::after {
    left: -0.28em;
    right: -0.28em;
    top: 41%;
    transform: translateY(-50%) scaleX(1.44);
    transform-origin: center;
    height: 1.15em;
    background-size: 185% 100%;
  }
}
