/* === Red Ribbon (only) === */
.ribbon-red {
  /* ribbon shape variables */
  --s: 40px; /* side size */
  --d: 20px; /* depth */
  --c: 20px; /* cutout */

  padding: 0 calc(var(--s) + var(--d)) var(--d);
  background:
    conic-gradient(at left var(--s) bottom var(--d),
      #0000 25%, #0008 0 37.5%, #0004 0) 0 /50% no-repeat,
    conic-gradient(at right var(--s) bottom var(--d),
      #0004 62.5%, #0008 0 75%, #0000 0) 100% /50% no-repeat;

  clip-path: polygon(
    0 var(--d),
    var(--s) var(--d),
    var(--s) 0,
    calc(100% - var(--s)) 0,
    calc(100% - var(--s)) var(--d),
    100% var(--d),
    calc(100% - var(--c)) calc(50% + var(--d)/2),
    100% 100%,
    calc(100% - var(--s) - var(--d)) 100%,
    calc(100% - var(--s) - var(--d)) calc(100% - var(--d)),
    calc(var(--s) + var(--d)) calc(100% - var(--d)),
    calc(var(--s) + var(--d)) 100%,
    0 100%,
    var(--c) calc(50% + var(--d)/2)
  );

  /* positioning */
  position: fixed;        /* stays on top */
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;

  /* sizing */
  width: calc(100% - 40px);
  max-width: 940px;

  /* style */
  background-color: #ffc600;
  color: black;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.2em;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-align: center;
  line-height: 1.6;

  /* animation */
  transition: transform 0.4s ease, opacity 0.4s ease;
}

/* === Hide on scroll === */
.ribbon-red.hide {
  transform: translate(-50%, -100%); /* slides up */
  opacity: 0;
}

.ribbon-red .desktop {
  display: inline;
}
.ribbon-red .mobile {
  display: none;
}

@media (max-width: 600px) {
  .ribbon-red .desktop {
    display: none;
  }
  .ribbon-red .mobile {
    display: inline;
  }
}


