/* ========================================
   Reset & Base Styles
======================================== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-family: "Zen Old Mincho", serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  width: 100%;
  background: #fff;
  color: #1c2a3a;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

ul {
  list-style: none;
}

/* ========================================
   FV (Ceramic)
======================================== */
.fv.fv--ceramic {
  position: relative;
  width: 100%;
  z-index: 1;
  height: 53.125vw; /* 680/1280: keep same crop on any width */
}

.fv.fv--ceramic .fv__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.fv.fv--ceramic .fv__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.fv.fv--ceramic .fv__container {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}

.fv.fv--ceramic .fv__kicker {
  position: absolute;
  left: 46.796875vw; /* 599px at 1280 */
  top: 11.171875vw; /* 143px at 1280 */
  width: 38.359375vw; /* 491px at 1280 */
  font-weight: 900;
  font-size: 2.8125vw; /* 36px at 1280 */
  line-height: 1.2;
  text-align: center;
  color: #ffffff;
  text-shadow: 0 0 0.9375vw #0a75a6; /* 12px at 1280 */
  white-space: nowrap;
}

.fv.fv--ceramic .fv__title {
  position: absolute;
  left: 41.875vw; /* 536px at 1280 */
  top: 15.15625vw; /* 194px at 1280 */
  width: 48.125vw; /* 616px at 1280 */
  font-size: 4.375vw; /* 56px at 1280 */
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-align: center;
  font-weight: 900;
  white-space: nowrap;
  display: block;
  z-index: 2;
}

.fv.fv--ceramic .fv__title-outline,
.fv.fv--ceramic .fv__title-fill {
  display: block;
  white-space: nowrap;
}

/* Outline (縁取り): text-shadow only */
.fv.fv--ceramic .fv__title-outline {
  position: absolute;
  inset: 0;
  color: transparent;
  text-shadow:
    -0.15625vw -0.15625vw 0 #eef7fc,
    0 -0.15625vw 0 #eef7fc,
    0.15625vw -0.15625vw 0 #eef7fc,
    -0.15625vw 0 0 #eef7fc,
    0.15625vw 0 0 #eef7fc,
    -0.15625vw 0.15625vw 0 #eef7fc,
    0 0.15625vw 0 #eef7fc,
    0.15625vw 0.15625vw 0 #eef7fc,
    0 0 0.46875vw #eef7fc;
}

/* Gradient fill */
.fv.fv--ceramic .fv__title-fill {
  position: relative;
  background-image: linear-gradient(98.1977deg, #2b98c9 2.8477%, #61bfe9 54.939%, #0c638e 96.783%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* PC/SP visibility control */
.fv.fv--ceramic .fv__title-outline--sp,
.fv.fv--ceramic .fv__title-fill--sp {
  display: none;
}

.fv.fv--ceramic .fv__badges {
  position: absolute;
  left: 41.25vw; /* 528px at 1280 */
  top: 26.875vw; /* 344px at 1280 */
  width: 49.375vw; /* 632px at 1280 */
  height: 16.875vw; /* 216px at 1280 */
  display: flex;
  gap: 1.25vw; /* 16px at 1280 */
  align-items: flex-start;
}

.fv.fv--ceramic .fv__badge {
  position: relative;
  width: 15.625vw; /* 200px at 1280 */
  height: 15.625vw;
  flex: 0 0 auto;
  isolation: isolate;
}

.fv.fv--ceramic .fv__badge::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, #ffffff 0%, rgba(255, 255, 255, 0.8) 100%);
  clip-path: polygon(
    29.29% 0%,
    70.71% 0%,
    100% 29.29%,
    100% 70.71%,
    70.71% 100%,
    29.29% 100%,
    0% 70.71%,
    0% 29.29%
  );
  border: 0.15625vw solid #ffffff; /* 2px at 1280 */
  /* box-shadow is clipped by clip-path in most browsers */
  filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.05));
  z-index: 0;
}

.fv.fv--ceramic .fv__badge--blue {
  color: #2b98c9;
}

.fv.fv--ceramic .fv__badge--pink {
  color: #ff8fab;
}

/* Figma: middle badge is 16px lower */
.fv.fv--ceramic .fv__badge:nth-child(2) {
  margin-top: 1.25vw; /* 16px at 1280 */
}

.fv.fv--ceramic .fv__badge-crown {
  position: absolute;
  width: 3.125vw; /* 40px at 1280 */
  height: 1.640625vw; /* 21px at 1280 */
  z-index: 1;
}

.fv.fv--ceramic .fv__badge-crown svg {
  width: 100%;
  height: 100%;
  display: block;
}

.fv.fv--ceramic .fv__badge-text {
  position: absolute;
  font-weight: 900;
  font-size: 2.1875vw; /* 28px at 1280 */
  line-height: 1.3;
  text-align: center;
  color: currentColor;
  white-space: nowrap;
  text-shadow: 0 0 0.625vw rgba(255, 255, 255, 0.9); /* 8px at 1280 */
  z-index: 1;
}

/* Badge offsets from Figma */
.fv.fv--ceramic .fv__badge:nth-child(1) .fv__badge-crown,
.fv.fv--ceramic .fv__badge:nth-child(2) .fv__badge-crown,
.fv.fv--ceramic .fv__badge:nth-child(3) .fv__badge-crown {
  left: 6.25vw; /* 80px at 1280 */
}

.fv.fv--ceramic .fv__badge:nth-child(1) .fv__badge-crown,
.fv.fv--ceramic .fv__badge:nth-child(2) .fv__badge-crown {
  top: 3.75vw; /* 48px at 1280 */
}

.fv.fv--ceramic .fv__badge:nth-child(3) .fv__badge-crown {
  top: 2.5vw; /* 32px at 1280 */
}

.fv.fv--ceramic .fv__badge:nth-child(1) .fv__badge-text {
  left: 3.4375vw; /* 44px at 1280 */
  top: 6.015625vw; /* 77px at 1280 */
  width: 8.75vw; /* 112px at 1280 */
}

.fv.fv--ceramic .fv__badge:nth-child(2) .fv__badge-text {
  left: 3.4375vw;
  top: 6.015625vw;
  width: 8.75vw;
}

.fv.fv--ceramic .fv__badge:nth-child(3) .fv__badge-text {
  left: 2.65625vw; /* 34px at 1280 */
  top: 5.078125vw; /* 65px at 1280 */
  width: 10.3125vw; /* 132px at 1280 */
  font-size: 1.71875vw; /* 22px at 1280 */
}

/* Vertical EN strip */
.fv.fv--ceramic .fv__en {
  position: absolute;
  top: 0;
  right: 0; /* align to FV right edge */
  width: 5.703125vw; /* 73px at 1280 */
  height: 104.21875vw; /* 1334/1280 */
  background: transparent;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

.fv.fv--ceramic .fv__en-wrap {
  position: absolute;
  left: -1.171875vw; /* -15px at 1280 */
  top: 0;
  width: 9.375vw; /* 120px at 1280 */
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fv.fv--ceramic .fv__en-rotate {
  transform: rotate(90deg);
  transform-origin: center;
}

.fv.fv--ceramic .fv__en-text {
  position: relative;
  font-weight: 900;
  font-size: 7.8125vw; /* 100px at 1280 */
  line-height: 1.2;
  letter-spacing: 0.3125vw; /* 4px at 1280 */
  color: #5db0d5;
  opacity: 0.2;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .fv.fv--ceramic {
    height: 206.25vw; /* 825px at 400px */
  }

  .fv.fv--ceramic .fv__container {
    width: 100%;
  }

  .fv.fv--ceramic .fv__kicker {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 100.75vw; /* 403px at 400px */
    width: auto;
    font-weight: 900;
    font-size: 6vw; /* 24px at 400px */
    line-height: 1.2;
    text-align: center;
    color: #ffffff;
    text-shadow: 0 0 2vw #00405d; /* 8px at 400px */
    white-space: nowrap;
  }

  /* Hide PC, show SP */
  .fv.fv--ceramic .fv__title-outline--pc,
  .fv.fv--ceramic .fv__title-fill--pc {
    display: none;
  }

  .fv.fv--ceramic .fv__title-outline--sp,
  .fv.fv--ceramic .fv__title-fill--sp {
    display: block;
  }

  .fv.fv--ceramic .fv__title {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 109.25vw; /* 437px at 400px */
    width: auto;
    font-size: 11.5vw; /* 46px at 400px */
    line-height: 1.2;
    letter-spacing: 0.02em;
    text-align: center;
    font-weight: 900;
    display: block;
    white-space: nowrap;
    z-index: 2;
  }

  .fv.fv--ceramic .fv__title-outline--sp,
  .fv.fv--ceramic .fv__title-fill--sp {
    display: block;
    white-space: nowrap;
  }

  .fv.fv--ceramic .fv__title-outline--sp {
    position: absolute;
    inset: 0;
    color: transparent;
    text-shadow:
      -0.5vw -0.5vw 0 #eef7fc,
      0 -0.5vw 0 #eef7fc,
      0.5vw -0.5vw 0 #eef7fc,
      -0.5vw 0 0 #eef7fc,
      0.5vw 0 0 #eef7fc,
      -0.5vw 0.5vw 0 #eef7fc,
      0 0.5vw 0 #eef7fc,
      0.5vw 0.5vw 0 #eef7fc,
      0 0 1.5vw #eef7fc;
  }

  .fv.fv--ceramic .fv__title-fill--sp {
    position: relative;
    background-image: linear-gradient(98.1977deg, #2b98c9 2.8477%, #61bfe9 54.939%, #0c638e 96.783%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
  }

  .fv.fv--ceramic .fv__badges {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }

  .fv.fv--ceramic .fv__badge {
    position: absolute;
    width: 22vw; /* 88px at 400px for badge 1 & 2 */
  }

  .fv.fv--ceramic .fv__badge::before {
    content: "";
    position: absolute;
    width: 37.5vw; /* 150px at 400px */
    height: 37.5vw;
    background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.7) 100%);
    clip-path: polygon(
      29.29% 0%,
      70.71% 0%,
      100% 29.29%,
      100% 70.71%,
      70.71% 100%,
      29.29% 100%,
      0% 70.71%,
      0% 29.29%
    );
    z-index: 0;
  }

  .fv.fv--ceramic .fv__badge--blue {
    color: #2b98c9;
  }

  .fv.fv--ceramic .fv__badge--pink {
    color: #ff8fab;
  }

  /* 1つ目のバッジ（銀座駅） - Union x=8, y=611 */
  .fv.fv--ceramic .fv__badge:nth-child(1) {
    left: 9.75vw; /* text x=39px at 400px */
    top: 159.5vw; /* frame y=638px at 400px */
    width: 22vw; /* 88px at 400px */
  }

  .fv.fv--ceramic .fv__badge:nth-child(1)::before {
    left: -7.75vw; /* 39-8=31px at 400px */
    top: -6.75vw; /* 638-611=27px at 400px */
  }

  /* 2つ目のバッジ（有楽町駅） - Union x=125, y=635 */
  .fv.fv--ceramic .fv__badge:nth-child(2) {
    left: 39vw; /* text x=156px at 400px */
    top: 165.5vw; /* frame y=662px at 400px */
    width: 22vw; /* 88px at 400px */
  }

  .fv.fv--ceramic .fv__badge:nth-child(2)::before {
    left: -7.75vw; /* 156-125=31px at 400px */
    top: -6.75vw; /* 662-635=27px at 400px */
  }

  /* 3つ目のバッジ（全国各地） - Union x=242, y=611 */
  .fv.fv--ceramic .fv__badge:nth-child(3) {
    left: 65.75vw; /* text x=263px at 400px */
    top: 157.75vw; /* frame y=631px at 400px */
    width: 27vw; /* 108px at 400px */
  }

  .fv.fv--ceramic .fv__badge:nth-child(3)::before {
    left: -5.25vw; /* 263-242=21px at 400px */
    top: -5vw; /* 631-611=20px at 400px */
  }

  .fv.fv--ceramic .fv__badge-crown {
    position: absolute;
    width: 10vw; /* 40px at 400px */
    height: 5.25vw; /* 21px at 400px */
    z-index: 1;
  }

  .fv.fv--ceramic .fv__badge-crown svg {
    width: 100%;
    height: 100%;
    display: block;
  }

  /* Badge 1 & 2 crown position: centered in 22vw container */
  .fv.fv--ceramic .fv__badge:nth-child(1) .fv__badge-crown,
  .fv.fv--ceramic .fv__badge:nth-child(2) .fv__badge-crown {
    left: 6vw; /* (22vw - 10vw) / 2 = 6vw */
    top: 0;
  }

  /* Badge 3 crown position: centered in 27vw container */
  .fv.fv--ceramic .fv__badge:nth-child(3) .fv__badge-crown {
    left: 8.5vw; /* (27vw - 10vw) / 2 = 8.5vw */
    top: 0;
  }

  .fv.fv--ceramic .fv__badge-text {
    position: absolute;
    font-weight: 900;
    line-height: 1.3;
    text-align: center;
    color: currentColor;
    z-index: 1;
  }

  /* Badge 1 text */
  .fv.fv--ceramic .fv__badge:nth-child(1) .fv__badge-text {
    left: 0;
    top: 6.75vw; /* 27px at 400px */
    width: 100%;
    font-size: 5.5vw; /* 22px at 400px */
  }

  /* Badge 2 text */
  .fv.fv--ceramic .fv__badge:nth-child(2) .fv__badge-text {
    left: 0;
    top: 6.75vw; /* 27px at 400px */
    width: 100%;
    font-size: 5.5vw; /* 22px at 400px */
  }

  /* Badge 3 text */
  .fv.fv--ceramic .fv__badge:nth-child(3) .fv__badge-text {
    left: 0;
    top: 7vw; /* 28px at 400px */
    width: 100%;
    font-size: 4.5vw; /* 18px at 400px */
  }

  .fv.fv--ceramic .fv__en {
    display: none;
  }
}

/* ========================================
   Cases (Ceramic)
======================================== */
.cases.cases--ceramic {
  position: relative;
  width: 100%;
  background: transparent;
  padding-top: 40px;
  padding-bottom: 80px;
  --cases-ceramic-bg-offset: 97vw;
}

.cases.cases--ceramic::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: var(--cases-ceramic-bg-offset);
  bottom: 0;
  background: #eefaff;
  z-index: 0;
}

.cases.cases--ceramic > * {
  position: relative;
  z-index: 1;
}

.cases.cases--ceramic .cases__inner {
  width: 1120px;
  margin: 0 auto;
}

.cases.cases--ceramic .cases__title {
  width: 207px; /* Figma: 114:202 */
  margin: 0 auto 40px;
  text-align: center;
}

.cases.cases--ceramic .cases__title-main {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 40px;
  line-height: 1.3;
  letter-spacing: 2px;
  color: #15729f;
}

.cases.cases--ceramic .cases__title-sub {
  margin-top: 4px;
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 22px;
  line-height: 1.3;
  letter-spacing: 1.1px;
  color: #15729f;
  white-space: nowrap;
}

.cases.cases--ceramic .cases__list {
  width: 960px;
  margin: 0 auto;
}

.cases.cases--ceramic .cases__divider {
  width: 390px; /* Figma: 168:2874 */
  height: 8px;
  margin: 40px auto;
}

.cases.cases--ceramic .cases__divider-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

.cases.cases--ceramic .cases-ba__title {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 16px;
}

.cases.cases--ceramic .cases-ba__title-bar {
  width: 2px;
  height: auto;
  align-self: stretch;
  background: #15729f;
  flex: 0 0 auto;
}

.cases.cases--ceramic .cases-ba__title-text {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 20px;
  line-height: 1.35;
  letter-spacing: 1px;
  color: #485676;
}

.cases.cases--ceramic .cases-ba__media {
  position: relative;
  width: 960px;
  padding: 8px;
  margin-bottom: 16px;
}

.cases.cases--ceramic .cases-ba__media-image {
  position: relative;
  width: 944px; /* Figma: 168:2835 */
  overflow: hidden;
}

.cases.cases--ceramic .cases-ba__media-img {
  position: relative;
  z-index: 0;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.cases.cases--ceramic .cases-ba__labels {
  position: absolute;
  left: 345px; /* Figma: 168:2842 */
  top: 1.5vw;
  width: 270px;
  height: 40px;
  z-index: 2;
}

.cases.cases--ceramic .cases-ba__pill {
  width: 100%;
  height: 100%;
  display: flex;
  --cases-ba-notch: 15px; /* 168:2845 / 168:2858 */
}

.cases.cases--ceramic .cases-ba__label {
  display: none;
}

.cases.cases--ceramic .cases-ba__pill-half {
  position: relative;
  width: 50%;
  height: 100%;
  display: flex;
  align-items: center;
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.66px;
  padding-top: 0;
  padding-bottom: 2px;
  white-space: nowrap;
}

.cases.cases--ceramic .cases-ba__pill-half--before {
  background-color: #485676;
  color: #ffffff;
  padding-left: 46px;
  clip-path: polygon(var(--cases-ba-notch) 0, 100% 0, 100% 100%, var(--cases-ba-notch) 100%, 0 50%);
}

.cases.cases--ceramic .cases-ba__pill-half--after {
  background-color: #ffffff;
  color: #15729f;
  padding-left: 23px;
  clip-path: polygon(0 0, calc(100% - var(--cases-ba-notch)) 0, 100% 50%, calc(100% - var(--cases-ba-notch)) 100%, 0 100%);
}

.cases.cases--ceramic .cases-ba__pill-icon {
  position: absolute;
  width: 20px;
  height: 20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

.cases.cases--ceramic .cases-ba__pill-icon--before {
  left: 12px;
}

.cases.cases--ceramic .cases-ba__pill-icon--after {
  right: 12px;
}

.cases.cases--ceramic .cases-ba__logo {
  position: absolute;
  right: 20px; /* Figma: x=819 => right 20 */
  bottom: 20px; /* Figma: y=249 => bottom 20 */
  width: 121px; /* Figma logo */
  height: 40px;
  z-index: 3;
  pointer-events: none;
  object-fit: contain;
  transform: none;
}

/* Tall BA (2 rows) uses centered logo */
.cases.cases--ceramic .cases-ba__media--tall .cases-ba__logo {
  right: auto;
  bottom: auto;
  left: 50%;
  top: 238px; /* Figma: y=281 within 516 => top 238 */
  transform: translateX(-50%);
}

.cases.cases--ceramic .cases-ba__texts {
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cases.cases--ceramic .cases-ba__desc {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.7px;
  color: #485676;
}

.cases.cases--ceramic .cases-ba__meta {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  font-size: 12px;
  line-height: 1.6;
  letter-spacing: 0.24px;
  color: #6f788e;
}

@media (max-width: 768px) {
  .cases.cases--ceramic {
    --cases-ceramic-bg-offset: 224vw;
  }

  .cases.cases--ceramic {
    padding: 14vw 0 24vw 0;
  }

  .cases.cases--ceramic .cases__inner {
    width: 100%;
    padding: 0;
  }

  .cases.cases--ceramic .cases__title {
    gap: 1vw; /* 4px at 400px */
  }

  .cases.cases--ceramic .cases__title-main {
    font-size: 9vw; /* 36px at 400px */
    letter-spacing: 0.45vw; /* 1.8px at 400px */
  }

  .cases.cases--ceramic .cases__title-sub {
    font-size: 4.5vw; /* 18px at 400px */
    letter-spacing: 0.225vw; /* 0.9px at 400px */
  }

  .cases.cases--ceramic .cases__list {
    width: 88vw; /* 352px at 400px */
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 8vw; /* 32px at 400px */
  }

  .cases.cases--ceramic .cases-ba {
    display: flex;
    flex-direction: column;
    gap: 4vw; /* 16px at 400px */
  }

  .cases.cases--ceramic .cases-ba__title {
    gap: 2vw; /* 8px at 400px */
    margin-bottom: 0;
  }

  .cases.cases--ceramic .cases-ba__title-bar {
    width: 0.5vw;
    height: auto;
    align-self: stretch;
  }

  .cases.cases--ceramic .cases-ba__title-text {
    font-size: 4.5vw; /* 18px at 400px */
    letter-spacing: 0.225vw; /* 0.9px at 400px */
  }

  .cases.cases--ceramic .cases-ba__media {
    width: 88vw; /* 352px at 400px */
    height: 92.5vw; /* 370px at 400px */
    margin-left: auto;
    margin-right: auto;
    padding: 0;
    margin-bottom: 0;
  }

  .cases.cases--ceramic .cases-ba__labels {
    inset: 0;
    width: auto;
    height: auto;
    transform: none;
  }

  .cases.cases--ceramic .cases-ba__media-img {
    object-fit: contain;
  }

  .cases.cases--ceramic .cases-ba__pill,
  .cases.cases--ceramic .cases-ba__pill-icon {
    display: none;
  }

  .cases.cases--ceramic .cases-ba__label {
    display: block;
    position: absolute;
    width: 27.5vw; /* 110px at 400px */
    height: 9vw; /* 36px at 400px */
    font-family: 'Zen Old Mincho', serif;
    font-weight: 900;
    font-size: 4.5vw; /* 18px at 400px */
    line-height: 1;
    letter-spacing: 0.135vw; /* 0.54px at 400px */
    --cases-ba-notch: 3.3vw; /* 13.2px at 400px */
    -webkit-clip-path: polygon(var(--cases-ba-notch) 0, 100% 0, 100% 100%, var(--cases-ba-notch) 100%, 0 50%);
    clip-path: polygon(var(--cases-ba-notch) 0, 100% 0, 100% 100%, var(--cases-ba-notch) 100%, 0 50%);
  }

  .cases.cases--ceramic .cases-ba__label--before {
    top: 4vw; /* 16px at 400px */
    right: 0;
    background-color: #485676;
    color: #ffffff;
    padding: 2vw 0 0 10vw; /* text: x+40px, y+8px */
  }

  .cases.cases--ceramic .cases-ba__label--after {
    top: 46.25vw; /* 185px at 400px */
    left: 0;
    background-color: #ffffff;
    color: #197bc4;
    padding: 1.75vw 0 0 4vw; /* text: x+16px, y+7px */
    -webkit-clip-path: polygon(0 0, calc(100% - var(--cases-ba-notch)) 0, 100% 50%, calc(100% - var(--cases-ba-notch)) 100%, 0 100%);
    clip-path: polygon(0 0, calc(100% - var(--cases-ba-notch)) 0, 100% 50%, calc(100% - var(--cases-ba-notch)) 100%, 0 100%);
  }

  .cases.cases--ceramic .cases-ba__label-icon {
    position: absolute;
    width: 5vw;
    height: 5vw;
    top: 50%;
    transform: translateY(-50%);
  }

  .cases.cases--ceramic .cases-ba__label--before .cases-ba__label-icon {
    left: 3vw; /* 12px at 400px */
  }

  .cases.cases--ceramic .cases-ba__label--after .cases-ba__label-icon {
    right: 3vw; /* 12px at 400px */
  }

  .cases.cases--ceramic .cases-ba__logo {
    right: 7vw; /* 28px at 400px */
    bottom: 7vw; /* 28px at 400px */
    width: 22.75vw; /* 91px at 400px */
    height: 7.5vw; /* 30px at 400px */
  }

  .cases.cases--ceramic .cases-ba__media--tall {
    height: 177vw; /* 708px at 400px */
  }

  .cases.cases--ceramic .cases-ba__media--tall .cases-ba__logo {
    right: auto;
    bottom: auto;
    left: 50%;
    top: 100.75vw; /* 403px at 400px */
    transform: translateX(-50%);
  }

  .cases.cases--ceramic .cases-ba__media--tall .cases-ba__label--before {
    top: 4vw;
  }

  .cases.cases--ceramic .cases-ba__media--tall .cases-ba__label--after {
    top: 46.25vw; /* 185px at 400px */
  }

  .cases.cases--ceramic .cases-ba__media--tall .cases-ba__label--before:nth-of-type(3) {
    top: 88.5vw; /* 354px at 400px */
  }

  .cases.cases--ceramic .cases-ba__media--tall .cases-ba__label--after:nth-of-type(4) {
    top: 130.75vw; /* 523px at 400px */
  }

  .cases.cases--ceramic .cases-ba__texts {
    padding: 0;
    gap: 2vw; /* 8px at 400px */
  }

  .cases.cases--ceramic .cases-ba__desc {
    font-size: 3.5vw; /* 14px at 400px */
    letter-spacing: 0.175vw; /* 0.7px at 400px */
  }

  .cases.cases--ceramic .cases-ba__meta {
    font-size: 3vw; /* 12px at 400px */
    letter-spacing: 0.06vw; /* 0.24px at 400px */
  }

  .cases.cases--ceramic .cases__divider {
    width: 88vw; /* 352px at 400px */
    height: 2vw; /* 8px at 400px */
    margin: 0 auto;
  }

  .cases.cases--ceramic .cases__divider-img {
    height: 100%;
  }
}

/* ========================================
   Ceramic Banner
======================================== */
.ceramic-banner {
  position: relative;
  width: 100%;
  background: #eefaff;
  padding: 40px 0 80px;
}

.ceramic-banner__inner {
  width: 1120px;
  margin: 0 auto;
}

.ceramic-banner__list {
  width: 790px; /* Figma: 114:1055 */
  margin: 0 auto;
  display: flex;
  gap: 16px; /* 790 - (387*2) = 16 */
}

.ceramic-banner__item {
  width: 387px; /* Figma: 114:1056/1057 */
  height: 200px;
  flex: 0 0 auto;
  overflow: hidden;
}

.ceramic-banner__link {
  display: block;
  width: 100%;
  height: 100%;
  transition: opacity 0.3s ease;
}

.ceramic-banner__link:hover {
  opacity: 0.7;
}

.ceramic-banner__link:focus-visible {
  outline: 2px solid #15729f;
  outline-offset: 4px;
}

.ceramic-banner__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

@media (max-width: 768px) {
  .ceramic-banner {
    padding: 10vw 0 14vw;
  }

  .ceramic-banner__inner {
    width: 100%;
    padding: 0 6vw;
  }

  .ceramic-banner__list {
    width: 100%;
    flex-direction: column;
    gap: 4vw;
  }

  .ceramic-banner__item {
    width: 100%;
    height: auto;
    aspect-ratio: 387 / 200;
  }
}

/* ========================================
   Recommend (Ceramic)
======================================== */
.recommend.recommend--ceramic {
  position: relative;
  width: 100%;
  padding: 6.25vw 0; /* 80px at 1280 */
  background: #ffffff;
}

.recommend.recommend--ceramic::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* Stop a bit above the card bottom (80 + 497 - 40 at 1280) */
  height: calc(6.25vw + 38.828125vw - 5.5vw);
  background: #eefaff;
  z-index: 0;
  pointer-events: none;
}

.recommend.recommend--ceramic::after {
  content: "";
  position: absolute;
  left: 0;
  top: auto;
  bottom: -11.6vw;
  width: 35.15625vw; /* 450px at 1280 */
  height: 23.4375vw; /* 300px at 1280 */
  background-image: url("../images/ceramic-about-shadow.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left bottom;
  z-index: 1;
  pointer-events: none;
}

.recommend.recommend--ceramic .recommend__inner {
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0;
  z-index: 2;
}

.recommend.recommend--ceramic .recommend__card {
  position: relative;
  width: 93.75vw; /* 1200px at 1280 */
  height: 38.828125vw; /* 497px at 1280 */
  margin-left: auto;
  margin-right: 0;
  background-color: #5db0d5;
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.05);
  z-index: 1;
}

.recommend.recommend--ceramic .recommend__card::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 68.3333333%; /* 820/1200 */
  height: 100%;
  background-image: url("../images/ceramic-recommend-bg.webp");
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  z-index: 0;
}

.recommend.recommend--ceramic .recommend__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 41.4166667%; /* 497/1200 */
  height: 100%;
  /* Match Figma gradient vector length (x1=0,y1=497 -> x2=248.5,y2=239.496) */
  background: linear-gradient(44deg, #d5fcff 0%, #5db0d5 50.6%, #5db0d5 100%);
  clip-path: polygon(0 0, 100% 100%, 0 100%);
  z-index: 1;
  pointer-events: none;
}

.recommend.recommend--ceramic .recommend__content {
  position: absolute;
  left: 6.25vw; /* 80px at 1280 */
  top: 5vw; /* 64px at 1280 */
  width: 46.875vw; /* 600px at 1280 */
  z-index: 2;
}

.recommend.recommend--ceramic .recommend__title {
  width: 36.71875vw; /* 470px at 1280 */
  color: #ffffff;
}

.recommend.recommend--ceramic .recommend__title-main {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 3.125vw; /* 40px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.15625vw; /* 2px at 1280 */
}

.recommend.recommend--ceramic .recommend__title-sub {
  margin-top: 0.3125vw; /* 4px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.71875vw; /* 22px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.0859375vw; /* 1.1px at 1280 */
}

.recommend.recommend--ceramic .recommend__list {
  margin-top: 2.5vw; /* 32px at 1280 */
  width: 46.875vw; /* 600px at 1280 */
  display: flex;
  flex-direction: column;
  gap: 0.625vw; /* 8px at 1280 */
}

.recommend.recommend--ceramic .recommend__item {
  height: 4.453125vw; /* 57px at 1280 */
  border: 0.15625vw solid #ffffff; /* 2px at 1280 */
  background: linear-gradient(90deg, #eefaff 0%, #b2e7ff 100%);
  padding: 1.09375vw 1.25vw; /* 14px 16px at 1280 */
  display: flex;
  align-items: center;
  gap: 0.625vw; /* 8px at 1280 */
}

.recommend.recommend--ceramic .recommend__item-icn {
  width: 1.875vw; /* 24px at 1280 */
  height: 1.875vw;
  flex: 0 0 auto;
}

.recommend.recommend--ceramic .recommend__item-text {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.40625vw; /* 18px at 1280 */
  line-height: 1.6;
  letter-spacing: 0.0703125vw; /* 0.9px at 1280 */
  color: #485676;
}

@media (max-width: 768px) {
  .recommend.recommend--ceramic {
    padding: 0;
    height: 218.5vw; /* 874px at 400px */
  }

  .recommend.recommend--ceramic::before {
    display: none;
  }

  .recommend.recommend--ceramic::after {
    display: none;
  }

  .recommend.recommend--ceramic .recommend__inner {
    width: 100%;
    padding: 0;
  }

  .recommend.recommend--ceramic .recommend__card {
    width: 92vw; /* 368px at 400px */
    height: 218.5vw; /* 874px at 400px */
    margin: 0 auto;
    background: #5db0d5;
    box-shadow: 10px 10px 10px 0px rgba(0, 0, 0, 0.05);
  }

  .recommend.recommend--ceramic .recommend__card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: none;
    background-image: url("../images/ceramic-recommend-bg-sp.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    clip-path: none;
    z-index: 0;
  }

  .recommend.recommend--ceramic .recommend__card::after {
    display: none;
  }

  .recommend.recommend--ceramic .recommend__content {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 92.25vw; /* 369px at 400px */
    width: 80vw; /* 320px at 400px */
    padding: 0;
    z-index: 1;
  }

  .recommend.recommend--ceramic .recommend__title {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 1vw; /* 4px at 400px */
  }

  .recommend.recommend--ceramic .recommend__title-main {
    font-size: 9vw; /* 36px at 400px */
    letter-spacing: 0.45vw; /* 1.8px at 400px */
  }

  .recommend.recommend--ceramic .recommend__title-sub {
    font-size: 4.5vw; /* 18px at 400px */
    letter-spacing: 0.225vw; /* 0.9px at 400px */
  }

  .recommend.recommend--ceramic .recommend__list {
    width: 100%;
    margin-top: 8vw; /* 32px at 400px */
    gap: 2vw; /* 8px at 400px */
  }

  .recommend.recommend--ceramic .recommend__item {
    height: auto;
    border-width: 0.5vw; /* 2px at 400px */
    padding: 3.5vw 4vw; /* 14px 16px at 400px */
  }

  .recommend.recommend--ceramic .recommend__item-icn {
    width: 6vw; /* 24px at 400px */
    height: 6vw;
  }

  .recommend.recommend--ceramic .recommend__item-text {
    font-size: 4.5vw; /* 18px at 400px */
    letter-spacing: 0.225vw; /* 0.9px at 400px */
  }
}

/* ========================================
   About (Ceramic)
======================================== */
.about.about--ceramic {
  position: relative;
  width: 100%;
  background: #ffffff;
}

.about.about--ceramic::before {
  content: "";
  position: absolute;
  left: 0;
  top: 21.875vw; /* 280px at 1280 */
  width: 100%;
  height: 63.046875vw; /* 807px at 1280 */
  background-image: url("../images/ceramic-about-bg.webp");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  z-index: 1;
  pointer-events: none;
}

.about.about--ceramic::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 35.15625vw; /* 450px at 1280 */
  height: 23.4375vw; /* 300px at 1280 */
  background-image: url("../images/ceramic-about-shadow2.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: right top;
  z-index: 0;
  pointer-events: none;
}

.about.about--ceramic .about__inner {
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0;
  padding-bottom: 6.25vw; /* 80px at 1280 */
  z-index: 2;
}

.about.about--ceramic .about__title {
  width: 52.96875vw; /* 678px at 1280 */
  margin: 0 auto;
  text-align: center;
  color: #2b98c9;
}

.about.about--ceramic .about__title-main {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 3.125vw; /* 40px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.15625vw; /* 2px at 1280 */
}

.about.about--ceramic .about__title-main-gradient {
  background-image: linear-gradient(112.225deg, #2b98c9 2.8477%, #61bfe9 54.939%, #0c638e 96.783%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.about.about--ceramic .about__title-sub {
  margin-top: 0.625vw; /* 8px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 2.1875vw; /* 28px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.109375vw; /* 1.4px at 1280 */
}

.about.about--ceramic .about__title-sub-br {
  display: none;
}

.about.about--ceramic .about__hero {
  position: relative;
  width: 96.875vw; /* 1240px at 1280 */
  height: 45.546875vw; /* 583px at 1280 */
  margin-top: 5vw; /* 64px at 1280 */
  margin-left: 0;
  z-index: 1;
}

.about.about--ceramic .about__hero-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about.about--ceramic .about__texts {
  position: relative;
  width: 81.25vw; /* 1040px at 1280 */
  margin-left: 9.375vw; /* 120px at 1280 */
  margin-top: -3.59375vw; /* -46px at 1280 */
  display: flex;
  gap: 3.125vw; /* 40px at 1280 */
  align-items: flex-end;
  z-index: 2;
}

.about.about--ceramic .about__col {
  width: 37.5vw; /* 480px at 1280 */
  display: flex;
  flex-direction: column;
  gap: 0.9375vw; /* 12px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.6;
  letter-spacing: 0.0625vw; /* 0.8px at 1280 */
  color: #ffffff;
}

.about.about--ceramic .about__em {
  font-weight: 900;
}

.about.about--ceramic .about__divider {
  position: relative;
  width: 0;
  height: 24.21875vw; /* 310px at 1280 */
  flex: 0 0 0;
}

.about.about--ceramic .about__divider::before {
  content: "";
  position: absolute;
  top: 0;
  left: -0.078125vw; /* half of 2px at 1280 */
  width: 0.15625vw; /* 2px at 1280 */
  height: 100%;
  background: rgba(255, 255, 255, 0.6);
}

@media (max-width: 768px) {
  .about.about--ceramic {
    margin-top: 12vw; /* 48px at 400px */
    height: 356vw; /* 1424px at 400px */
  }

  .about.about--ceramic::before {
    top: 70vw; /* 280px at 400px */
    left: 0;
    width: 100%;
    height: 286vw; /* 1144px at 400px */
    background-image: url("../images/ceramic-about-bg-sp.webp");
    background-size: cover;
    background-position: center;
  }

  .about.about--ceramic::after {
    display: none;
  }

  .about.about--ceramic .about__inner {
    padding: 0 6vw; /* 24px at 400px */
  }

  .about.about--ceramic .about__title {
    width: 100%;
    margin: 0;
    padding: 0;
  }

  .about.about--ceramic .about__title-main {
    font-size: 8vw; /* 32px at 400px */
    letter-spacing: 0.4vw; /* 1.6px at 400px */
  }

  .about.about--ceramic .about__title-sub {
    margin-top: 2vw; /* 8px at 400px */
    font-size: 6vw; /* 24px at 400px */
    letter-spacing: 0.3vw; /* 1.2px at 400px */
  }

  .about.about--ceramic .about__title-sub-br {
    display: block;
  }

  .about.about--ceramic .about__hero {
    width: 98vw; /* 392px at 400px */
    height: 89vw; /* 356px at 400px */
    margin-top: 12vw; /* 48px at 400px - from title bottom to image top */
    margin-left: -6vw; /* offset the inner padding */
  }

  .about.about--ceramic .about__texts {
    width: 100%;
    margin: 0;
    margin-top: 10vw; /* 40px at 400px - from image bottom to text top */
    padding: 0;
    flex-direction: column;
    gap: 3vw; /* 12px at 400px */
    align-items: stretch;
  }

  .about.about--ceramic .about__divider {
    display: none;
  }

  .about.about--ceramic .about__col {
    width: 100%;
    gap: 3vw; /* 12px at 400px */
    font-size: 4vw; /* 16px at 400px */
    letter-spacing: 0.2vw; /* 0.8px at 400px */
    color: #485676;
  }

  .about.about--ceramic .about__em {
    color: #15729f;
  }
}

/* ========================================
   Element Header (Ceramic)
======================================== */
.element.element--ceramic {
  position: relative;
  width: 100%;
  height: 39.6875vw; /* 508px at 1280 */
  background: #f7fdff;
}

.element.element--ceramic .element__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.element.element--ceramic .element__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
}

.element.element--ceramic .element__inner {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.element.element--ceramic .element__title {
  position: absolute;
  left: 6.25vw; /* 80px at 1280 */
  top: 9.375vw; /* 120px at 1280 */
  width: 40.859375vw; /* 523px at 1280 */
  text-align: center;
}

.element.element--ceramic .element__title-en {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 5vw; /* 64px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.25vw; /* 3.2px at 1280 */
  background-image: linear-gradient(101.17deg, #2b98c9 2.8477%, #61bfe9 54.939%, #0c638e 96.783%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  white-space: nowrap;
}

.element.element--ceramic .element__title-ja {
  margin-top: 0.3125vw; /* 4px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 2.5vw; /* 32px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.125vw; /* 1.6px at 1280 */
  background-image: linear-gradient(100.628deg, #2b98c9 2.8477%, #61bfe9 54.939%, #0c638e 96.783%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.element.element--ceramic .element__title-ja-br {
  display: none;
}

@media (max-width: 768px) {
  .element.element--ceramic {
    height: 102vw; /* 408px at 400px */
    margin-bottom: 26vw;
  }

  .element.element--ceramic .element__bg img {
    object-position: center;
  }

  .element.element--ceramic .element__title {
    left: 6vw; /* 24px at 400px */
    top: 70vw; /* 280px at 400px */
    width: 88vw; /* 352px at 400px */
    text-align: center;
  }

  .element.element--ceramic .element__title-en {
    font-size: 10vw; /* 40px at 400px */
    letter-spacing: 0.5vw; /* 2px at 400px */
    white-space: nowrap;
  }

  .element.element--ceramic .element__title-ja {
    margin-top: 1vw; /* 4px at 400px */
    font-size: 7vw; /* 28px at 400px */
    letter-spacing: 0.35vw; /* 1.4px at 400px */
    white-space: nowrap;
  }

  .element.element--ceramic .element__title-ja-br {
    display: block;
  }
}

/* ========================================
   Element Contents BG (Ceramic)
======================================== */
.element-contents.element-contents--ceramic {
  position: relative;
  width: 100%;
  margin-top: -10.703125vw; /* same overlap as element-content--ceramic used to have */
}

.element-contents.element-contents--ceramic::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../images/bg-about.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -1;
  pointer-events: none;
}

.element-contents.element-contents--ceramic > .element-content {
  position: relative;
  z-index: 1;
}

/* ========================================
   Element Content (Ceramic) - 01 Zirconia
======================================== */
.element-content.element-content--ceramic {
  position: relative;
  width: 100%;
  padding-bottom: 6.25vw; /* 80px at 1280 */
}

.element-content.element-content--ceramic .element-content__stage {
  position: relative;
  width: 96.875vw; /* 1240px at 1280 */
  height: 92.109375vw; /* 1179px at 1280 */
  margin: 0 auto;
}

.element-content.element-content--ceramic .element-content__card {
  position: absolute;
  left: 6.25vw; /* 80px at 1280 */
  top: 4.609375vw; /* 59px at 1280 */
  width: 81.25vw; /* 1040px at 1280 */
  height: 87.5vw; /* 1120px at 1280 */
  background: #ffffff;
  box-shadow: 1.5625vw 1.5625vw 1.5625vw rgba(0, 0, 0, 0.05); /* 20px at 1280 */
  z-index: 0;
}

.element-content.element-content--ceramic .element-content__img-top {
  position: absolute;
  left: 0;
  top: 1.484375vw; /* 19px at 1280 */
  width: 54.6875vw; /* 700px at 1280 */
  height: 42.96875vw; /* 550px at 1280 */
  display: block;
  background: #ffffff;
  overflow: hidden;
  z-index: 1;
}

.element-content.element-content--ceramic .element-content__img-top-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
}

.element-content.element-content--ceramic .element-content__num {
  position: absolute;
  top: 0;
  right: 7.59375vw; /* 97px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 9.375vw; /* 120px at 1280 */
  line-height: 1;
  letter-spacing: 0.46875vw; /* 6px at 1280 */
  text-align: center;
  opacity: 0.3;
  transform: skewX(-10deg);
  background-image: linear-gradient(29.3363deg, #2b98c9 3.7558%, #0c638e 79.564%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  z-index: 2;
  pointer-events: none;
}

.element-content.element-content--ceramic .element-content__head {
  position: absolute;
  left: 43.4375vw; /* 556px at 1280 */
  top: 9.921875vw; /* 127px at 1280 */
  width: 39.0625vw; /* 500px at 1280 */
  display: flex;
  flex-direction: column;
  gap: 1.875vw; /* 24px at 1280 */
  z-index: 3;
}

.element-content.element-content--ceramic .element-content__name {
  display: flex;
  align-items: center;
  gap: 0.9375vw; /* 12px at 1280 */
  color: #2b98c9;
  line-height: 1.3;
}

.element-content.element-content--ceramic .element-content__name-ja {
  font-weight: 900;
  font-size: 3.125vw; /* 40px at 1280 */
  letter-spacing: 0.15625vw; /* 2px at 1280 */
}

.element-content.element-content--ceramic .element-content__name-ja-br-sp {
  display: none;
}

.element-content.element-content--ceramic .element-content__features-title-br-sp {
  display: none;
}

.element-content.element-content--ceramic .element-content__name-en {
  font-weight: 900;
  font-size: 1.5625vw; /* 20px at 1280 */
  letter-spacing: 0.078125vw; /* 1px at 1280 */
}

.element-content.element-content--ceramic .element-content__desc {
  display: flex;
  flex-direction: column;
  gap: 0.9375vw; /* 12px at 1280 */
  font-weight: 700;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.6;
  letter-spacing: 0.0625vw; /* 0.8px at 1280 */
  color: #485676;
}

.element-content.element-content--ceramic .element-content__features {
  position: absolute;
  left: 11.25vw; /* 144px at 1280 */
  top: 35.078125vw; /* 449px at 1280 */
  width: 58.515625vw; /* 749px at 1280 */
  display: flex;
  flex-direction: column;
  gap: 2.5vw; /* 32px at 1280 */
  z-index: 2;
}

.element-content.element-content--ceramic .element-content__features-title {
  width: 100%;
  height: 3.90625vw; /* 50px at 1280 */
  background: linear-gradient(90deg, #2b98c9 0%, #61bfe9 46%, #fd94af 100%);
  display: flex;
  align-items: center;
}

.element-content.element-content--ceramic .element-content__features-title-text {
  padding-left: 1.25vw; /* 16px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 2.1875vw; /* 28px at 1280 */
  line-height: 1.3;
  letter-spacing: 0.109375vw; /* 1.4px at 1280 */
  color: #ffffff;
  white-space: nowrap;
}

.element-content.element-content--ceramic .element-content__list {
  width: 42.96875vw; /* 550px at 1280 */
  display: flex;
  flex-direction: column;
  gap: 0.78125vw; /* 10px at 1280 */
}

.element-content.element-content--ceramic .element-content__item {
  display: flex;
  align-items: center;
  gap: 0.625vw; /* 8px at 1280 */
}

.element-content.element-content--ceramic .element-content__check {
  width: 1.875vw; /* 24px at 1280 */
  height: 1.875vw;
  flex: 0 0 auto;
}

.element-content.element-content--ceramic .element-content__item-text {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.6;
  letter-spacing: 0.0625vw; /* 0.8px at 1280 */
  color: #0c638e;
}

.element-content.element-content--ceramic .element-content__img-bottom {
  position: absolute;
  left: 40.859375vw; /* 523px at 1280 */
  top: 33.203125vw; /* 425px at 1280 */
  width: 56.015625vw; /* 717px at 1280 */
  height: 58.90625vw; /* 754px at 1280 */
  display: block;
  overflow: hidden;
  z-index: 2;
  pointer-events: none;
}

.element-content.element-content--ceramic .element-content__img-bottom-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.element-content.element-content--ceramic .element-table.element-table--zirconia {
  position: absolute;
  left: 11.25vw; /* 144px at 1280 */
  top: 71.015625vw; /* 909px at 1280 */
  width: 71.25vw; /* 912px at 1280 */
  height: 16.09375vw; /* 206px at 1280 */
  background: #ffffff;
  border: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
  z-index: 5;
}

.element-content.element-content--ceramic .element-table__row {
  display: flex;
  width: 100%;
}

.element-content.element-content--ceramic .element-table__row--h46 {
  height: 3.51vw;
}

.element-content.element-content--ceramic .element-table__row--h68 {
  height: 5.3125vw; /* 68px at 1280 */
}

.element-content.element-content--ceramic .element-table__row--h92 {
  height: 7.1875vw; /* 92px at 1280 */
}

.element-content.element-content--ceramic .element-table__row:not(:last-child) {
  border-bottom: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
}

.element-content.element-content--ceramic .element-table__head {
  width: 14.0625vw; /* 180px at 1280 */
  background: #2b98c9;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.35;
  letter-spacing: 0.025vw; /* 0.32px at 1280 */
  padding: 0 0.625vw;
  flex: 0 0 auto;
  border-right: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
}

.element-content.element-content--ceramic .element-table__cell {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  padding: 0 1.25vw; /* 16px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.35;
  letter-spacing: 0.025vw; /* 0.32px at 1280 */
  color: #485676;
}

.element-content.element-content--ceramic .element-table__row--split {
  gap: 0;
  padding: 0;
}

.element-content.element-content--ceramic .element-table__row--split .element-table__split {
  width: 50%;
  display: flex;
  height: 100%;
}

.element-content.element-content--ceramic .element-table__row--split .element-table__split + .element-table__split {
  border-left: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
}

.element-content.element-content--ceramic .element-table__row--split .element-table__split .element-table__head {
  border-right: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
}

.element-content.element-content--ceramic .element-table__row--split .element-table__split .element-table__cell {
  padding: 0 1.25vw;
}

@media (max-width: 768px) {
  .element-content.element-content--ceramic {
    margin-top: 0;
    padding-bottom: 14vw;
  }

  .element-contents.element-contents--ceramic {
    margin-top: -24vw;
    overflow-x: hidden;
  }

  .element-contents.element-contents--ceramic::before {
    content: none;
  }

  .element-content.element-content--ceramic .element-content__stage {
    width: 100%;
    height: auto;
    padding: 0 6vw;
  }

  .element-content.element-content--ceramic .element-content__card,
  .element-content.element-content--ceramic .element-content__img-top,
  .element-content.element-content--ceramic .element-content__num,
  .element-content.element-content--ceramic .element-content__head,
  .element-content.element-content--ceramic .element-content__features,
  .element-content.element-content--ceramic .element-content__img-bottom,
  .element-content.element-content--ceramic .element-table.element-table--zirconia {
    position: static;
    width: 100%;
    height: auto;
    left: auto;
    top: auto;
    right: auto;
    margin: 0;
    transform: none;
  }

  .element-content.element-content--ceramic .element-content__card {
    display: none;
  }

  .element-content.element-content--ceramic .element-content__img-top {
    aspect-ratio: 700 / 550;
    margin-top: 6vw;
  }

  .element-content.element-content--ceramic .element-content__head {
    margin-top: 6vw;
    gap: 4vw;
  }

  .element-content.element-content--ceramic .element-content__name-ja {
    font-size: 8vw;
    letter-spacing: 0.4vw;
  }

  .element-content.element-content--ceramic .element-content__name-ja-br-sp {
    display: block;
  }

  .element-content.element-content--ceramic .element-content__features-title-br-sp {
    display: block;
  }

  .element-content.element-content--ceramic .element-content__name-en {
    font-size: 4.2vw;
    letter-spacing: 0.2vw;
  }

  .element-content.element-content--ceramic .element-content__desc,
  .element-content.element-content--ceramic .element-content__item-text {
    font-size: 4vw;
    letter-spacing: 0.15vw;
  }

  .element-content.element-content--ceramic .element-content__features {
    margin-top: 10vw;
    gap: 5vw;
  }

  .element-content.element-content--ceramic .element-content__features-title {
    height: 12vw;
  }

  .element-content.element-content--ceramic .element-content__features-title-text {
    padding-left: 6vw;
    font-size: 6vw;
    letter-spacing: 0.25vw;
  }

  .element-content.element-content--ceramic .element-content__list {
    width: 100%;
    gap: 3vw;
  }

  .element-content.element-content--ceramic .element-content__check {
    width: 7vw;
    height: 7vw;
  }

  .element-content.element-content--ceramic .element-content__img-bottom {
    aspect-ratio: 717 / 754;
    margin-top: 8vw;
  }

  .element-content.element-content--ceramic .element-table.element-table--zirconia {
    margin-top: 10vw;
    border-width: 0.4vw;
  }

  .element-content.element-content--ceramic .element-table__row--h46,
  .element-content.element-content--ceramic .element-table__row--h68,
  .element-content.element-content--ceramic .element-table__row--h92 {
    height: auto;
    min-height: 12vw;
  }

  .element-content.element-content--ceramic .element-table__row {
    flex-direction: column;
  }

  .element-content.element-content--ceramic .element-table__head {
    width: 100%;
    border-right: 0;
    border-bottom: 0.4vw solid #b2e7ff;
    padding: 2.5vw 4vw;
    justify-content: flex-start;
  }

  .element-content.element-content--ceramic .element-table__cell {
    width: 100%;
    padding: 3vw 4vw;
  }

  .element-content.element-content--ceramic .element-table__row--split {
    gap: 0;
    padding: 0;
  }

  .element-content.element-content--ceramic .element-table__row--split .element-table__split {
    width: 100%;
    flex-direction: column;
  }

  .element-content.element-content--ceramic .element-table__row--split .element-table__split + .element-table__split {
    border-top: 0.4vw solid #b2e7ff;
  }
}

@media (max-width: 768px) {
  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) {
    --zirconia-sp-base: min(100vw, 400px);
    padding-bottom: 0;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__stage {
    position: relative;
    width: var(--zirconia-sp-base);
    height: calc(var(--zirconia-sp-base) * 1727 / 400);
    margin: 0 auto;
    padding: 0;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__card {
    display: block;
    position: absolute;
    left: calc(var(--zirconia-sp-base) * 24 / 400);
    top: calc(var(--zirconia-sp-base) * 241 / 400);
    width: calc(var(--zirconia-sp-base) * 352 / 400);
    height: calc(var(--zirconia-sp-base) * 1486 / 400);
    background: #ffffff;
    box-shadow:
      calc(var(--zirconia-sp-base) * 20 / 400)
      calc(var(--zirconia-sp-base) * 20 / 400)
      calc(var(--zirconia-sp-base) * 20 / 400)
      rgba(0, 0, 0, 0.05);
    z-index: 0;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__img-top {
    position: absolute;
    left: 0;
    top: calc(var(--zirconia-sp-base) * 48 / 400);
    width: calc(var(--zirconia-sp-base) * 376 / 400);
    height: calc(var(--zirconia-sp-base) * 295 / 400);
    margin: 0;
    overflow: hidden;
    z-index: 1;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__img-top-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__img-bottom {
    position: absolute;
    left: calc(var(--zirconia-sp-base) * 112 / 400);
    top: calc(var(--zirconia-sp-base) * 96 / 400);
    width: calc(var(--zirconia-sp-base) * 352 / 400);
    height: calc(var(--zirconia-sp-base) * 360 / 400);
    margin: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 2;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__img-bottom-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__num {
    position: absolute;
    top: 0;
    left: calc(var(--zirconia-sp-base) * 282.89 / 400);
    right: auto;
    width: auto;
    height: auto;
    margin: 0;
    font-size: calc(var(--zirconia-sp-base) * 80 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 4 / 400);
    line-height: 1;
    transform: translateX(-50%) skewX(-10deg);
    z-index: 3;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__head {
    position: absolute;
    left: calc(var(--zirconia-sp-base) * 48 / 400);
    top: calc(var(--zirconia-sp-base) * 248 / 400);
    width: calc(var(--zirconia-sp-base) * 304 / 400);
    margin: 0;
    gap: calc(var(--zirconia-sp-base) * 24 / 400);
    z-index: 3;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__name {
    flex-direction: column;
    align-items: flex-start;
    gap: calc(var(--zirconia-sp-base) * 4 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__name-ja {
    font-size: calc(var(--zirconia-sp-base) * 32 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 1.6 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__name-en {
    font-size: calc(var(--zirconia-sp-base) * 20 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 1 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__desc {
    gap: calc(var(--zirconia-sp-base) * 12 / 400);
    font-size: calc(var(--zirconia-sp-base) * 16 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 0.8 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__features {
    position: absolute;
    left: calc(var(--zirconia-sp-base) * 48 / 400);
    top: calc(var(--zirconia-sp-base) * 660 / 400);
    width: calc(var(--zirconia-sp-base) * 304 / 400);
    margin: 0;
    gap: calc(var(--zirconia-sp-base) * 24 / 400);
    z-index: 3;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__features-title {
    height: calc(var(--zirconia-sp-base) * 45 / 400);
    background: #2b98c9;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__features-title-text {
    width: 100%;
    padding-left: 0;
    font-size: calc(var(--zirconia-sp-base) * 24 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 1.2 / 400);
    text-align: center;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__list {
    width: 100%;
    gap: calc(var(--zirconia-sp-base) * 10 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__item {
    align-items: center;
    gap: calc(var(--zirconia-sp-base) * 8 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__check {
    width: calc(var(--zirconia-sp-base) * 24 / 400);
    height: calc(var(--zirconia-sp-base) * 24 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-content__item-text {
    font-size: calc(var(--zirconia-sp-base) * 16 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 0.8 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia {
    position: absolute;
    left: calc(var(--zirconia-sp-base) * 48 / 400);
    top: calc(var(--zirconia-sp-base) * 1263 / 400);
    width: calc(var(--zirconia-sp-base) * 304 / 400);
    height: calc(var(--zirconia-sp-base) * 432 / 400);
    margin: 0;
    background: #ffffff;
    border: calc(var(--zirconia-sp-base) * 1.5 / 400) solid #bfe9fa;
    z-index: 5;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row {
    flex-direction: row;
    border-bottom: calc(var(--zirconia-sp-base) * 1.5 / 400) solid #bfe9fa;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row:last-child {
    border-bottom: none;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row:nth-child(1) {
    height: calc(var(--zirconia-sp-base) * 60 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row:nth-child(2) {
    height: calc(var(--zirconia-sp-base) * 170 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row:nth-child(3) {
    height: calc(var(--zirconia-sp-base) * 120 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row:nth-child(4) {
    height: calc(var(--zirconia-sp-base) * 82 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row--split {
    flex-direction: column;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table.element-table--zirconia .element-table__row--split .element-table__split {
    width: 100%;
    height: calc(var(--zirconia-sp-base) * 60 / 400);
    display: flex;
    flex-direction: row;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03)
    .element-table.element-table--zirconia
    .element-table__row--split
    .element-table__split
    + .element-table__split {
    border-left: 0;
    border-top: calc(var(--zirconia-sp-base) * 1.5 / 400) solid #bfe9fa;
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table__head {
    width: calc(var(--zirconia-sp-base) * 100 / 400);
    background: #eefaff;
    color: #2b98c9;
    border-bottom: 0;
    border-right: calc(var(--zirconia-sp-base) * 1.5 / 400) solid #bfe9fa;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-weight: 900;
    font-size: calc(var(--zirconia-sp-base) * 16 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 0.32 / 400);
    padding: 0 calc(var(--zirconia-sp-base) * 5 / 400);
  }

  .element-content.element-content--ceramic:not(.element-content--ceramic02):not(.element-content--ceramic03) .element-table__cell {
    width: auto;
    flex: 1 1 auto;
    align-items: center;
    padding: 0 calc(var(--zirconia-sp-base) * 10 / 400);
    font-weight: 600;
    font-size: calc(var(--zirconia-sp-base) * 16 / 400);
    letter-spacing: calc(var(--zirconia-sp-base) * 0.32 / 400);
    color: #485676;
  }
}

/* ========================================
   Element Content (Ceramic) - 02 IPS e.max
======================================== */
.element-content.element-content--ceramic.element-content--ceramic02 {
  margin-top: 3.59375vw; /* 46px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__stage {
  width: 100%;
  height: 77.34375vw; /* 990px at 1280 */
  margin: 0;
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__card {
  left: 50%;
  top: 4.53125vw; /* 58px at 1280 */
  width: 81.25vw; /* 1040px at 1280 */
  height: 72.8125vw; /* 932px at 1280 */
  transform: translateX(-50%);
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-top {
  left: auto;
  right: 0;
  top: 1.40625vw; /* 18px at 1280 */
  width: 54.6875vw; /* 700px at 1280 */
  height: 42.96875vw; /* 550px at 1280 */
  z-index: 1;
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-top-img {
  object-position: right center;
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__num {
  top: 0;
  left: 20.033vw; /* 256.42px at 1280 */
  right: auto;
  transform: translateX(-50%) skewX(-10deg);
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__head {
  left: 14.375vw; /* 184px at 1280 */
  top: 9.84375vw; /* 126px at 1280 */
  width: 43.4375vw; /* 556px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__desc {
  width: 39.0625vw; /* 500px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__features {
  left: 42.65625vw; /* 546px at 1280 */
  top: 27.96875vw; /* 358px at 1280 */
  width: 57.34375vw; /* 734px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__features-title {
  background: linear-gradient(90deg, #2b98c9 0%, #61bfe9 46%, #fd94af 100%);
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-bottom {
  left: 0;
  top: 26.09375vw; /* 334px at 1280 */
  width: 44.453125vw; /* 569px at 1280 */
  height: 51.25vw; /* 656px at 1280 */
  z-index: 1;
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-bottom-img {
  object-position: left top;
}

.element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax {
  position: absolute;
  left: 14.375vw; /* 184px at 1280 */
  top: 56.25vw; /* 720px at 1280 */
  width: 71.25vw; /* 912px at 1280 */
  height: 16.09375vw; /* 206px at 1280 */
  background: #ffffff;
  border: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
  z-index: 5;
}

@media (max-width: 768px) {
  .element-content.element-content--ceramic.element-content--ceramic02 {
    --emax-sp-base: min(100vw, 400px);
    margin-top: calc(var(--emax-sp-base) * 16 / 400);
    padding-bottom: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__stage {
    position: relative;
    width: var(--emax-sp-base);
    height: calc(var(--emax-sp-base) * 1571 / 400);
    margin: 0 auto;
    padding: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__card {
    display: block;
    position: absolute;
    left: 50%;
    top: calc(var(--emax-sp-base) * 241 / 400);
    width: calc(var(--emax-sp-base) * 352 / 400);
    height: calc(var(--emax-sp-base) * 1330 / 400);
    transform: translateX(-50%);
    background: #ffffff;
    box-shadow:
      calc(var(--emax-sp-base) * 20 / 400)
      calc(var(--emax-sp-base) * 20 / 400)
      calc(var(--emax-sp-base) * 20 / 400)
      rgba(0, 0, 0, 0.05);
    z-index: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-top {
    position: absolute;
    left: calc(var(--emax-sp-base) * 24 / 400);
    right: auto;
    top: calc(var(--emax-sp-base) * 48 / 400);
    width: calc(var(--emax-sp-base) * 376 / 400);
    height: calc(var(--emax-sp-base) * 295 / 400);
    margin: 0;
    overflow: hidden;
    z-index: 1;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-top-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-bottom {
    position: absolute;
    left: 0;
    right: auto;
    top: calc(var(--emax-sp-base) * 96 / 400);
    width: calc(var(--emax-sp-base) * 312.256103515625 / 400);
    height: calc(var(--emax-sp-base) * 360 / 400);
    margin: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 2;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__img-bottom-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__num {
    position: absolute;
    top: 0;
    left: calc(var(--emax-sp-base) * 119.89 / 400);
    right: auto;
    width: auto;
    height: auto;
    margin: 0;
    font-size: calc(var(--emax-sp-base) * 80 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 4 / 400);
    line-height: 1;
    transform: translateX(-50%) skewX(-10deg);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__head {
    position: absolute;
    left: calc(var(--emax-sp-base) * 48 / 400);
    top: calc(var(--emax-sp-base) * 248 / 400);
    width: calc(var(--emax-sp-base) * 304 / 400);
    margin: 0;
    gap: calc(var(--emax-sp-base) * 24 / 400);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__name {
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    gap: calc(var(--emax-sp-base) * 4 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__name-ja {
    font-size: calc(var(--emax-sp-base) * 32 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 1.6 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__name-en {
    font-size: calc(var(--emax-sp-base) * 20 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 1 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__desc {
    gap: calc(var(--emax-sp-base) * 12 / 400);
    font-size: calc(var(--emax-sp-base) * 16 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 0.8 / 400);
    width: 100%;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__features {
    position: absolute;
    left: calc(var(--emax-sp-base) * 48 / 400);
    top: calc(var(--emax-sp-base) * 518 / 400);
    width: calc(var(--emax-sp-base) * 304 / 400);
    margin: 0;
    gap: calc(var(--emax-sp-base) * 24 / 400);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__features-title {
    height: calc(var(--emax-sp-base) * 107 / 400);
    background: #2b98c9;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__features-title-text {
    width: 100%;
    padding: calc(var(--emax-sp-base) * 7 / 400) calc(var(--emax-sp-base) * 8 / 400) 0;
    font-size: calc(var(--emax-sp-base) * 24 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 1.2 / 400);
    line-height: 1.3;
    text-align: left;
    white-space: normal;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__list {
    width: 100%;
    gap: calc(var(--emax-sp-base) * 10 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__item {
    align-items: center;
    gap: calc(var(--emax-sp-base) * 8 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__check {
    width: calc(var(--emax-sp-base) * 24 / 400);
    height: calc(var(--emax-sp-base) * 24 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-content__item-text {
    font-size: calc(var(--emax-sp-base) * 16 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 0.8 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax {
    position: absolute;
    left: calc(var(--emax-sp-base) * 48 / 400);
    top: calc(var(--emax-sp-base) * 1085 / 400);
    width: calc(var(--emax-sp-base) * 304 / 400);
    height: calc(var(--emax-sp-base) * 454 / 400);
    margin: 0;
    background: #ffffff;
    border: calc(var(--emax-sp-base) * 1.5 / 400) solid #bfe9fa;
    z-index: 5;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row {
    flex-direction: row;
    border-bottom: calc(var(--emax-sp-base) * 1.5 / 400) solid #bfe9fa;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row:last-child {
    border-bottom: none;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row:nth-child(1) {
    height: calc(var(--emax-sp-base) * 60 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row:nth-child(2) {
    height: calc(var(--emax-sp-base) * 170 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row:nth-child(3) {
    height: calc(var(--emax-sp-base) * 120 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row:nth-child(4) {
    height: calc(var(--emax-sp-base) * 104 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row--split {
    flex-direction: column;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table.element-table--emax .element-table__row--split .element-table__split {
    width: 100%;
    height: calc(var(--emax-sp-base) * 60 / 400);
    display: flex;
    flex-direction: row;
  }

  .element-content.element-content--ceramic.element-content--ceramic02
    .element-table.element-table--emax
    .element-table__row--split
    .element-table__split
    + .element-table__split {
    border-left: 0;
    border-top: calc(var(--emax-sp-base) * 1.5 / 400) solid #bfe9fa;
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table__head {
    width: calc(var(--emax-sp-base) * 100 / 400);
    background: #eefaff;
    color: #2b98c9;
    border-bottom: 0;
    border-right: calc(var(--emax-sp-base) * 1.5 / 400) solid #bfe9fa;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-weight: 900;
    font-size: calc(var(--emax-sp-base) * 16 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 0.32 / 400);
    padding: 0 calc(var(--emax-sp-base) * 5 / 400);
  }

  .element-content.element-content--ceramic.element-content--ceramic02 .element-table__cell {
    width: auto;
    flex: 1 1 auto;
    align-items: center;
    padding: 0 calc(var(--emax-sp-base) * 10 / 400);
    font-weight: 600;
    font-size: calc(var(--emax-sp-base) * 16 / 400);
    letter-spacing: calc(var(--emax-sp-base) * 0.32 / 400);
    color: #485676;
  }
}

/* ========================================
   Element Content (Ceramic) - 03 Hybrid ceramic
======================================== */
.element-content.element-content--ceramic.element-content--ceramic03 {
  margin-top: 3.515625vw; /* 45px at 1280 */
  padding-bottom: 6.25vw; /* 80px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__stage {
  width: 100%;
  height: 76.171875vw; /* 975px at 1280 */
  margin: 0;
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__card {
  left: 50%;
  top: 4.609375vw; /* 59px at 1280 */
  width: 81.25vw; /* 1040px at 1280 */
  height: 71.5625vw; /* 916px at 1280 */
  transform: translateX(-50%);
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__num {
  top: 0;
  right: 10.3125vw; /* 132px at 1280 */
  left: auto;
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__head {
  left: 14.375vw; /* 184px at 1280 */
  top: 9.921875vw; /* 127px at 1280 */
  width: 71.25vw; /* 912px at 1280 */
  gap: 1.875vw; /* 24px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__name {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.3125vw; /* 4px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__features {
  left: 14.375vw; /* 184px at 1280 */
  top: 25.390625vw; /* 325px at 1280 */
  width: 56.796875vw; /* 727px at 1280 */
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__img-bottom {
  left: auto;
  right: 0;
  top: 23.515625vw; /* 301px at 1280 */
  width: 53.28125vw; /* 682px at 1280 */
  height: 52.65625vw; /* 674px at 1280 */
  z-index: 2;
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-content__img-bottom-img {
  object-position: right bottom;
}

.element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid {
  position: absolute;
  left: 14.375vw; /* 184px at 1280 */
  top: 53.203125vw; /* 681px at 1280 */
  width: 71.25vw; /* 912px at 1280 */
  height: 17.96875vw; /* 230px at 1280 */
  background: #ffffff;
  border: 0.15625vw solid #b2e7ff; /* 2px at 1280 */
  z-index: 5;
}

@media (max-width: 768px) {
  .element-content.element-content--ceramic.element-content--ceramic03 {
    --hybrid-sp-base: min(100vw, 405px);
    margin-top: calc(var(--hybrid-sp-base) * 16 / 405);
    padding-bottom: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__stage {
    position: relative;
    width: var(--hybrid-sp-base);
    height: calc(var(--hybrid-sp-base) * 1532 / 405);
    margin: 0 auto;
    padding: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__card {
    display: block;
    position: absolute;
    left: 50%;
    top: calc(var(--hybrid-sp-base) * 48 / 405);
    width: calc(var(--hybrid-sp-base) * 352 / 405);
    height: calc(var(--hybrid-sp-base) * 1484 / 405);
    transform: translateX(-50%);
    background: #ffffff;
    box-shadow:
      calc(var(--hybrid-sp-base) * 20 / 405)
      calc(var(--hybrid-sp-base) * 20 / 405)
      calc(var(--hybrid-sp-base) * 20 / 405)
      rgba(0, 0, 0, 0.05);
    z-index: 0;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__img-bottom {
    position: absolute;
    left: calc(var(--hybrid-sp-base) * 53 / 405);
    right: auto;
    top: calc(var(--hybrid-sp-base) * 32 / 405);
    width: calc(var(--hybrid-sp-base) * 376 / 405);
    height: calc(var(--hybrid-sp-base) * 360 / 405);
    margin: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 1;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__img-bottom-img {
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__num {
    position: absolute;
    top: 0;
    left: calc(var(--hybrid-sp-base) * 95.95 / 405);
    right: auto;
    width: auto;
    height: auto;
    margin: 0;
    font-size: calc(var(--hybrid-sp-base) * 80 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 4 / 405);
    line-height: 1;
    transform: translateX(-50%) skewX(-10deg);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__head {
    position: absolute;
    left: calc(var(--hybrid-sp-base) * 48 / 405);
    top: calc(var(--hybrid-sp-base) * 248 / 405);
    width: calc(var(--hybrid-sp-base) * 304 / 405);
    margin: 0;
    gap: calc(var(--hybrid-sp-base) * 24 / 405);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__name {
    flex-direction: column;
    align-items: flex-start;
    gap: calc(var(--hybrid-sp-base) * 4 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__name-ja {
    font-size: calc(var(--hybrid-sp-base) * 32 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 1.6 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__name-en {
    font-size: calc(var(--hybrid-sp-base) * 20 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 1 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__desc {
    gap: calc(var(--hybrid-sp-base) * 12 / 405);
    font-size: calc(var(--hybrid-sp-base) * 16 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 0.8 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__features {
    position: absolute;
    left: calc(var(--hybrid-sp-base) * 48 / 405);
    top: calc(var(--hybrid-sp-base) * 522 / 405);
    width: calc(var(--hybrid-sp-base) * 304 / 405);
    margin: 0;
    gap: calc(var(--hybrid-sp-base) * 24 / 405);
    z-index: 3;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__features-title {
    height: calc(var(--hybrid-sp-base) * 68 / 405);
    background: #2b98c9;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__features-title-text {
    width: 100%;
    padding-left: calc(var(--hybrid-sp-base) * 16 / 405);
    font-size: calc(var(--hybrid-sp-base) * 24 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 1.2 / 405);
    line-height: 1.3;
    white-space: normal;
    text-align: left;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__list {
    width: 100%;
    gap: calc(var(--hybrid-sp-base) * 10 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__item {
    align-items: center;
    gap: calc(var(--hybrid-sp-base) * 8 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__check {
    width: calc(var(--hybrid-sp-base) * 24 / 405);
    height: calc(var(--hybrid-sp-base) * 24 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-content__item-text {
    font-size: calc(var(--hybrid-sp-base) * 16 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 0.8 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid {
    position: absolute;
    left: calc(var(--hybrid-sp-base) * 48 / 405);
    top: calc(var(--hybrid-sp-base) * 1046 / 405);
    width: calc(var(--hybrid-sp-base) * 304 / 405);
    height: calc(var(--hybrid-sp-base) * 454 / 405);
    margin: 0;
    background: #ffffff;
    border: calc(var(--hybrid-sp-base) * 1.5 / 405) solid #bfe9fa;
    z-index: 5;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row {
    flex-direction: row;
    border-bottom: calc(var(--hybrid-sp-base) * 1.5 / 405) solid #bfe9fa;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row:last-child {
    border-bottom: none;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row:nth-child(1) {
    height: calc(var(--hybrid-sp-base) * 60 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row:nth-child(2) {
    height: calc(var(--hybrid-sp-base) * 214 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row:nth-child(3) {
    height: calc(var(--hybrid-sp-base) * 120 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row:nth-child(4) {
    height: calc(var(--hybrid-sp-base) * 60 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row--split {
    flex-direction: column;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table.element-table--hybrid .element-table__row--split .element-table__split {
    width: 100%;
    height: calc(var(--hybrid-sp-base) * 60 / 405);
    display: flex;
    flex-direction: row;
  }

  .element-content.element-content--ceramic.element-content--ceramic03
    .element-table.element-table--hybrid
    .element-table__row--split
    .element-table__split
    + .element-table__split {
    border-left: 0;
    border-top: calc(var(--hybrid-sp-base) * 1.5 / 405) solid #bfe9fa;
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table__head {
    width: calc(var(--hybrid-sp-base) * 100 / 405);
    background: #eefaff;
    color: #2b98c9;
    border-bottom: 0;
    border-right: calc(var(--hybrid-sp-base) * 1.5 / 405) solid #bfe9fa;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-weight: 900;
    font-size: calc(var(--hybrid-sp-base) * 16 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 0.32 / 405);
    padding: 0 calc(var(--hybrid-sp-base) * 5 / 405);
  }

  .element-content.element-content--ceramic.element-content--ceramic03 .element-table__cell {
    width: auto;
    flex: 1 1 auto;
    align-items: center;
    padding: 0 calc(var(--hybrid-sp-base) * 10 / 405);
    font-weight: 600;
    font-size: calc(var(--hybrid-sp-base) * 16 / 405);
    letter-spacing: calc(var(--hybrid-sp-base) * 0.32 / 405);
    color: #485676;
  }
}

/* ========================================
   Price (Ceramic)
======================================== */
.price.price--ceramic {
  position: relative;
  width: 100%;
  height: 50.3125vw; /* 644px at 1280 */
}

.price.price--ceramic .price__bg {
  position: absolute;
  inset: 0;
  background-color: #485676;
  z-index: 0;
}

.price.price--ceramic .price__content {
  position: relative;
  width: 62.5vw; /* 800px at 1280 */
  margin: 0 auto;
  padding-top: 6.25vw; /* 80px at 1280 */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.125vw; /* 40px at 1280 */
  z-index: 1;
}

.price.price--ceramic .price__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.625vw; /* 8px at 1280 */
}

.price.price--ceramic .price__title-main {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 3.125vw; /* 40px at 1280 */
  line-height: 1.2;
  letter-spacing: 0.15625vw; /* 2px at 1280 */
  color: #fcffcc;
  text-align: center;
}

.price.price--ceramic .price__title-sub {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.71875vw; /* 22px at 1280 */
  line-height: 1.2;
  letter-spacing: 0.0859375vw; /* 1.1px at 1280 */
  color: #fcffcc;
  text-align: center;
  width: 34.84375vw; /* 446px at 1280 */
}

.price.price--ceramic .price__fee {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1.875vw; /* 24px at 1280 */
}

.price.price--ceramic .price__table {
  position: relative;
  width: 100%;
  height: 13.28125vw; /* 170px at 1280 */
  border-collapse: collapse;
  border: 0.117188vw solid #ffffff; /* 1.5px at 1280 */
}

.price.price--ceramic .price__table::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 27.34375vw; /* 350px at 1280 */
  height: 100%;
  background-color: rgba(255, 255, 255, 0.3);
  z-index: 0;
  pointer-events: none;
}

.price.price--ceramic .price__table::after {
  content: "";
  position: absolute;
  top: 0;
  left: 27.34375vw; /* 350px at 1280 */
  width: 0.117188vw; /* 1.5px at 1280 */
  height: 100%;
  background-color: #ffffff;
  z-index: 0;
  pointer-events: none;
}

.price.price--ceramic .price__table tbody,
.price.price--ceramic .price__table th,
.price.price--ceramic .price__table td {
  position: relative;
  z-index: 1;
}

.price.price--ceramic .price__row {
  height: 4.453125vw; /* 57px at 1280 */
  border-bottom: 0.117188vw solid #ffffff; /* 1.5px at 1280 */
}

.price.price--ceramic .price__row:last-child {
  border-bottom: none;
}

.price.price--ceramic .price__item-header {
  padding: 0 0.9375vw; /* 0 12px at 1280 */
  text-align: left;
  vertical-align: middle;
}

.price.price--ceramic .price__item-name {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.35;
  letter-spacing: 0.025vw; /* 0.32px at 1280 */
  color: #ffffff;
}

.price.price--ceramic .price__item-price {
  padding: 0 1.71875vw 0 0.9375vw; /* 0 22px 0 12px at 1280 */
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  font-size: 1.25vw; /* 16px at 1280 */
  line-height: 1.35;
  letter-spacing: 0.025vw; /* 0.32px at 1280 */
  color: #ffffff;
  text-align: right;
  vertical-align: middle;
}

.price.price--ceramic .price__notes p {
  font-family: "Zen Old Mincho", "Noto Sans JP", serif;
  font-weight: 400;
  font-size: 1.09375vw; /* 14px at 1280 */
  line-height: 1.5;
  letter-spacing: 0.021875vw; /* 0.28px at 1280 */
  color: #ffffff;
}

@media (max-width: 768px) {
  .price.price--ceramic {
    height: auto;
    padding: 14vw 0;
  }

  .price.price--ceramic .price__content {
    width: 100%;
    padding: 0 6vw;
    gap: 8vw;
  }

  .price.price--ceramic .price__title-main {
    font-size: 10vw;
    letter-spacing: 0.5vw;
  }

  .price.price--ceramic .price__title-sub {
    width: 100%;
    font-size: 5.5vw;
    letter-spacing: 0.2vw;
  }

  .price.price--ceramic .price__fee {
    gap: 6vw;
  }

  .price.price--ceramic .price__table {
    height: auto;
    border: none;
  }

  .price.price--ceramic .price__table::before,
  .price.price--ceramic .price__table::after {
    display: none;
  }

  .price.price--ceramic .price__row {
    display: block;
    height: auto;
    border-bottom: none;
  }

  .price.price--ceramic .price__item-header {
    display: block;
    background: rgba(255, 255, 255, 0.3);
    padding: 3vw 4vw;
    text-align: center;
  }

  .price.price--ceramic .price__item-name {
    font-size: 4vw;
    letter-spacing: 0.15vw;
  }

  .price.price--ceramic .price__item-price {
    display: block;
    padding: 3.5vw 4vw 5vw;
    text-align: center;
    font-size: 4vw;
    letter-spacing: 0.15vw;
  }

  .price.price--ceramic .price__notes p {
    font-size: 3.6vw;
    letter-spacing: 0.14vw;
  }
}
