.ssb-soft-body {
  margin: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,255,255,.18)),
    repeating-linear-gradient(45deg, rgba(219, 39, 52, .12) 0 1px, transparent 1px 38px),
    linear-gradient(180deg, #fff6df 0%, #ffd8df 42%, #ff8292 100%);
  color: #241411;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 800;
}
.ssb-soft-body--footer-white { background-color: #fff; }
.ssb-soft-body--footer-black { background-color: #06070b; }
.ssb-soft-body--footer-gray { background-color: #3b3f46; }
.ssb-soft-body--footer-red { background-color: #d80019; }
.ssb-soft-page {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 32px 0 0;
  --ssb-soft-topnav-hero-gap-pc: 28px;
  --ssb-soft-topnav-hero-gap-tablet: 24px;
  --ssb-soft-topnav-hero-gap-mobile: 20px;
  --ssb-soft-list-footer-gap-pc: 52px;
  --ssb-soft-list-footer-gap-tablet: 44px;
  --ssb-soft-list-footer-gap-mobile: 34px;
}
.ssb-soft-topnav {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--ssb-soft-topnav-hero-gap-pc);
}
.ssb-soft-topnav a,
.ssb-soft-contact a {
  color: #4a2b00;
  background: linear-gradient(180deg, #fff9ca 0%, #ffe47a 48%, #ffc642 100%);
  border: 3px solid #a86f00;
  border-radius: 999px;
  box-shadow: 0 4px 0 rgba(154, 92, 0, .24), 0 12px 24px rgba(255, 198, 66, .18);
  padding: 12px 24px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ssb-soft-topnav--red a {
  color: #542000;
  background: linear-gradient(180deg, #fff3ea 0%, #ffc79f 48%, #fb923c 100%);
  border-color: #c05621;
  box-shadow: 0 4px 0 rgba(192, 86, 33, .22), 0 12px 24px rgba(251, 146, 60, .18);
}
.ssb-soft-topnav--blue a {
  color: #0b255c;
  background: linear-gradient(180deg, #eff8ff 0%, #91d7ff 52%, #4f9cf8 100%);
  border-color: #2563eb;
  box-shadow: 0 4px 0 rgba(37, 99, 235, .2), 0 12px 24px rgba(79, 156, 248, .18);
}
.ssb-soft-topnav--green a {
  color: #063c37;
  background: linear-gradient(180deg, #ecfffa 0%, #7cf0d1 52%, #2fc6ae 100%);
  border-color: #0f766e;
  box-shadow: 0 4px 0 rgba(15, 118, 110, .22), 0 12px 24px rgba(47, 198, 174, .18);
}
.ssb-soft-topnav--pink a {
  color: #5b102b;
  background: linear-gradient(180deg, #fff4fa 0%, #ffc8df 52%, #ff8fbd 100%);
  border-color: #d94684;
  box-shadow: 0 4px 0 rgba(217, 70, 132, .22), 0 12px 24px rgba(255, 143, 189, .16);
}
.ssb-soft-topnav--dark a {
  color: #fff;
  background: linear-gradient(180deg, #334155 0%, #1e293b 52%, #0f172a 100%);
  border-color: #0f172a;
  box-shadow: 0 4px 0 rgba(15, 23, 42, .26), 0 12px 24px rgba(15, 23, 42, .18);
}
.ssb-soft-hero {
  position: relative;
  overflow: hidden;
  text-align: center;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 250, 224, 0.82) 26%, rgba(255, 221, 95, 0.9) 52%, rgba(190, 124, 18, 0.92) 100%),
    linear-gradient(180deg, #fff8cf 0%, #f7c441 48%, #b76c12 100%);
  border: 3px solid #a96a0b;
  border-radius: 1.25rem;
  box-shadow:
    0 0 0 4px rgba(255, 252, 222, 0.92) inset,
    0 7px 0 rgba(125, 74, 8, 0.28),
    0 0.85rem 1.65rem rgba(141, 80, 6, 0.2);
  padding: 1.65rem 2rem;
}
.ssb-soft-hero::before {
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  background: linear-gradient(120deg, rgba(255, 255, 255, 0.42), transparent 34%, rgba(255, 255, 255, 0.24) 58%, transparent 76%);
}
.ssb-soft-hero--shine {
  animation: ssb-soft-campaign-card-glow 1.8s ease-in-out infinite;
}
.ssb-soft-hero--shine::after {
  animation: ssb-soft-campaign-shine 2.8s ease-in-out infinite;
  background: linear-gradient(105deg, transparent 0%, transparent 38%, rgba(255, 255, 255, 0.2) 44%, rgba(255, 255, 255, 0.95) 50%, rgba(255, 255, 255, 0.22) 56%, transparent 62%, transparent 100%);
  background-size: 260% 100%;
  content: "";
  height: 100%;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: 2;
}
@keyframes ssb-soft-campaign-shine {
  0%, 42% {
    background-position: -180% 0;
    opacity: 0;
  }
  52% {
    opacity: 0.95;
  }
  78%, 100% {
    background-position: 180% 0;
    opacity: 0;
  }
}
@keyframes ssb-soft-campaign-card-glow {
  0%, 100% {
    filter: brightness(1);
  }
  45%, 58% {
    filter: brightness(1.22) saturate(1.16);
  }
}
.ssb-soft-kicker {
  position: relative;
  z-index: 3;
  color: #6e3600;
  margin: 0 0 8px;
  letter-spacing: 0;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.82);
}
.ssb-soft-hero h1 {
  position: relative;
  z-index: 3;
  margin: 0;
  color: #6e3600;
  font-size: clamp(30px, 4vw, 58px);
  line-height: 1.18;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.82);
}
.ssb-soft-lead {
  position: relative;
  z-index: 3;
  margin: 22px auto 0;
  max-width: 780px;
  font-size: 20px;
  line-height: 1.9;
  color: #3b2505;
}
.ssb-soft-notice,
.ssb-soft-contact,
.ssb-soft-empty {
  margin: 28px auto 0;
  padding: 24px;
  border-radius: 18px;
  background: rgba(255,255,255,.9);
  border: 3px solid #e60019;
  box-shadow: 0 8px 0 rgba(216, 0, 25, .12);
}
.ssb-soft-notice h2 {
  margin: 0 0 10px;
  color: #d80019;
  text-align: center;
}
.ssb-soft-notice div,
.ssb-soft-contact p {
  line-height: 1.9;
  text-align: center;
}
.ssb-soft-notice .ssb-soft-download {
  display: flex;
  margin: 18px auto 0;
  width: fit-content;
}
.ssb-soft-contact {
  text-align: center;
}
.ssb-soft-contact a {
  color: #fff;
  background: linear-gradient(180deg, #38a7ff, #0067c8);
  border-color: #0054ac;
  box-shadow: 0 4px 0 rgba(0, 54, 120, .36);
}
.ssb-soft-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  margin-top: 34px;
}
.ssb-soft-card {
  background: #fff;
  border: 3px solid #d80019;
  border-radius: 20px;
  box-shadow: 0 10px 0 rgba(120, 0, 12, .16);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-height: 320px;
}
.ssb-soft-list--float .ssb-soft-card {
  animation: ssb-soft-card-float 5.8s ease-in-out infinite;
  transform-origin: 50% 60%;
  will-change: transform;
}
.ssb-soft-list--float .ssb-soft-card:nth-child(2n) {
  animation-delay: -1.8s;
}
.ssb-soft-list--float .ssb-soft-card:nth-child(3n) {
  animation-delay: -3.2s;
}
@keyframes ssb-soft-card-float {
  0%, 100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  25% {
    transform: translate3d(0, -7px, 0) rotate(.35deg);
  }
  50% {
    transform: translate3d(0, 4px, 0) rotate(-.25deg);
  }
  75% {
    transform: translate3d(0, -4px, 0) rotate(.18deg);
  }
}
.ssb-soft-card__content {
  display: flex;
  flex: 1;
  flex-direction: column;
}
.ssb-soft-card--cream {
  background: #fff5c8;
}
.ssb-soft-card--soft {
  background: linear-gradient(145deg, #fff7df, #ffe7ed);
}
.ssb-soft-card--dark {
  background: #182033;
  color: #fff;
  border-color: #33415f;
  box-shadow: 0 10px 0 rgba(5, 8, 18, .34);
}
.ssb-soft-card--coming-soon {
  position: relative;
}
.ssb-soft-card__meta {
  color: #c08400;
  margin: 0 0 8px;
  text-align: center;
}
.ssb-soft-card--dark .ssb-soft-card__meta {
  color: #26f0d0;
}
.ssb-soft-card h2 {
  color: #18120f;
  font-size: 28px;
  font-weight: 950;
  line-height: 1.3;
  margin: 0 0 14px;
  text-align: center;
}
.ssb-soft-card--dark h2 {
  color: #fff;
}
.ssb-soft-card__desc-wrap {
  min-height: 118px;
  position: relative;
}
.ssb-soft-card__desc {
  line-height: 1.85;
}
.ssb-soft-coming-stamp {
  align-items: center;
  background:
    radial-gradient(circle at 12% 24%, rgba(255,255,255,.78) 0 1px, transparent 2px),
    radial-gradient(circle at 72% 36%, rgba(255,255,255,.58) 0 1px, transparent 2px),
    radial-gradient(circle at 42% 72%, rgba(255,255,255,.5) 0 1px, transparent 2px),
    linear-gradient(135deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, 0));
  border: 5px double rgba(216, 0, 25, .88);
  border-radius: 8px;
  box-shadow:
    0 2px 0 rgba(120, 0, 12, .12),
    inset 0 0 0 2px rgba(216, 0, 25, .18);
  color: rgba(216, 0, 25, .86);
  display: flex;
  font-size: clamp(32px, 4.2vw, 52px);
  font-weight: 950;
  justify-content: center;
  left: 50%;
  letter-spacing: 0;
  line-height: 1;
  min-height: 74px;
  opacity: .92;
  padding: 10px 24px;
  position: absolute;
  text-shadow: 1px 1px 0 rgba(255,255,255,.45);
  top: 50%;
  transform: translate(-50%, -50%) rotate(-11deg);
  width: min(92%, 330px);
  z-index: 2;
}
.ssb-soft-coming-stamp::before {
  background:
    repeating-linear-gradient(0deg, transparent 0 4px, rgba(255,255,255,.36) 4px 5px),
    repeating-linear-gradient(90deg, transparent 0 10px, rgba(255,255,255,.26) 10px 11px);
  content: "";
  inset: 6px;
  mix-blend-mode: screen;
  opacity: .62;
  pointer-events: none;
  position: absolute;
}
.ssb-soft-card--dark .ssb-soft-coming-stamp {
  color: rgba(255, 64, 88, .92);
  border-color: rgba(255, 64, 88, .9);
}
.ssb-soft-card__file {
  color: #6b5544;
  font-size: 14px;
  line-height: 1.5;
  margin: auto 0 0;
  text-align: center;
}
.ssb-soft-card__file--soon {
  color: #d80019;
  text-align: center;
}
.ssb-soft-card--dark .ssb-soft-card__file {
  color: #c9d8ff;
}
.ssb-soft-download {
  border-radius: 999px;
  border: 3px solid transparent;
  overflow: hidden;
  padding: 12px 24px;
  position: relative;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  font-size: 20px;
}
.ssb-soft-download--shine::after {
  animation: ssb-soft-button-shine 2.6s ease-in-out infinite;
  background: linear-gradient(105deg, transparent 0%, transparent 38%, rgba(255,255,255,.24) 45%, rgba(255,255,255,.96) 50%, rgba(255,255,255,.24) 56%, transparent 64%, transparent 100%);
  content: "";
  height: 160%;
  left: -80%;
  pointer-events: none;
  position: absolute;
  top: -30%;
  transform: skewX(-18deg);
  width: 52%;
}
@keyframes ssb-soft-button-shine {
  0%, 38% {
    left: -80%;
    opacity: 0;
  }
  48% {
    opacity: .95;
  }
  78%, 100% {
    left: 130%;
    opacity: 0;
  }
}
.ssb-soft-download--soon {
  cursor: default;
  pointer-events: none;
}
.ssb-soft-download--external {
  text-decoration: none;
}
.ssb-soft-download--compact {
  font-size: 16px;
  margin-top: 18px;
  padding: 10px 22px;
}
.ssb-soft-download--gold {
  color: #9d0012;
  background: linear-gradient(180deg, #fff8c7 0%, #ffd84d 45%, #f29a00 100%);
  border-color: #c87b00;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 4px 0 rgba(157, 92, 0, .32);
}
.ssb-soft-download--silver {
  color: #2c3035;
  background: linear-gradient(180deg, #ffffff 0%, #edf0f3 34%, #bfc6cf 72%, #f9fafb 100%);
  border-color: #aab2bc;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.95), 0 4px 0 rgba(66, 74, 84, .32);
}
.ssb-soft-download--red {
  color: #fff;
  background: linear-gradient(180deg, #ff6172 0%, #e60019 55%, #a90013 100%);
  border-color: #b60015;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 4px 0 rgba(120, 0, 12, .34);
}
.ssb-soft-download--blue {
  color: #fff;
  background: linear-gradient(180deg, #54c1ff 0%, #0078e8 55%, #0051a8 100%);
  border-color: #0058b2;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 4px 0 rgba(0, 58, 122, .34);
}
.ssb-soft-download--white {
  color: #d80019;
  background: linear-gradient(180deg, #fff 0%, #fffaf0 50%, #f2eee6 100%);
  border-color: #e60019;
  box-shadow: inset 0 1px 0 rgba(255,255,255,1), 0 4px 0 rgba(150, 0, 14, .22);
}
.ssb-soft-download--black {
  color: #fff;
  background: linear-gradient(180deg, #3b4252 0%, #151923 55%, #05070d 100%);
  border-color: #05070d;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 4px 0 rgba(0, 0, 0, .38);
}
.ssb-soft-download-progress {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 10px;
}
.ssb-soft-download-progress span {
  color: #d80019;
  font-size: 14px;
}
.ssb-soft-download-progress button {
  background: #fff;
  border: 2px solid #d80019;
  border-radius: 999px;
  color: #d80019;
  cursor: pointer;
  font-weight: 800;
  padding: 5px 14px;
}
.ssb-soft-modal-open {
  overflow: hidden;
}
.ssb-soft-modal[aria-hidden="true"] {
  display: none;
}
.ssb-soft-modal {
  align-items: center;
  display: flex;
  inset: 0;
  justify-content: center;
  padding: 24px;
  position: fixed;
  z-index: 99999;
}
.ssb-soft-modal__backdrop {
  background: rgba(20, 12, 18, .58);
  inset: 0;
  position: absolute;
}
.ssb-soft-modal__panel {
  background: #fffdf6;
  border: 3px solid #d80019;
  border-radius: 20px;
  box-shadow: 0 18px 48px rgba(80, 0, 12, .28);
  max-height: min(82vh, 760px);
  max-width: 720px;
  overflow: auto;
  padding: 34px 28px 30px;
  position: relative;
  width: min(100%, 720px);
}
.ssb-soft-modal__panel h2 {
  color: #d80019;
  margin: 0 44px 18px;
  text-align: center;
}
.ssb-soft-modal__body {
  line-height: 1.9;
}
.ssb-soft-modal__close {
  align-items: center;
  background: #d80019;
  border: 0;
  border-radius: 999px;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font-size: 24px;
  height: 40px;
  justify-content: center;
  position: absolute;
  right: 16px;
  top: 16px;
  width: 40px;
}
.ssb-soft-footer {
  text-align: center;
  margin: var(--ssb-soft-list-footer-gap-pc) calc(50% - 50vw) 0;
  min-height: 76px;
  padding: 18px 16px;
  background: #fff;
  border-top: 4px solid #d80019;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ssb-soft-body--footer-black .ssb-soft-footer {
  background: #06070b;
  border-top-color: #202638;
}
.ssb-soft-body--footer-gray .ssb-soft-footer {
  background: #3b3f46;
  border-top-color: #606774;
}
.ssb-soft-body--footer-red .ssb-soft-footer {
  background: #d80019;
  border-top-color: #9c0012;
}
.ssb-soft-footer-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px 42px;
}
.ssb-soft-footer-nav a {
  color: #111;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
  text-decoration: none;
  font-size: 15px;
  line-height: 1.5;
}
.ssb-soft-body--footer-black .ssb-soft-footer-nav a,
.ssb-soft-body--footer-gray .ssb-soft-footer-nav a,
.ssb-soft-body--footer-red .ssb-soft-footer-nav a {
  color: #fff;
}
.ssb-soft-footer-nav a:hover {
  color: #d80019;
}
.ssb-soft-body--footer-red .ssb-soft-footer-nav a:hover,
.ssb-soft-body--footer-black .ssb-soft-footer-nav a:hover,
.ssb-soft-body--footer-gray .ssb-soft-footer-nav a:hover {
  color: #ffe66d;
}
@media (max-width: 640px) {
  .ssb-soft-page {
    width: min(100% - 20px, 1120px);
    padding-top: 20px;
  }
  .ssb-soft-hero {
    padding: 34px 18px;
  }
  .ssb-soft-lead {
    font-size: 16px;
  }
}
@media (max-width: 900px) {
  .ssb-soft-topnav {
    margin-bottom: var(--ssb-soft-topnav-hero-gap-tablet);
  }
  .ssb-soft-footer {
    margin-top: var(--ssb-soft-list-footer-gap-tablet);
  }
}
@media (max-width: 640px) {
  .ssb-soft-topnav {
    margin-bottom: var(--ssb-soft-topnav-hero-gap-mobile);
  }
  .ssb-soft-footer {
    margin-top: var(--ssb-soft-list-footer-gap-mobile);
  }
  .ssb-soft-footer-nav {
    gap: 14px 22px;
  }
}
