#kv {
  position: relative;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-color: var(--color-navy);
  background-position: center top;
  background-image: url(../img/toppage/kv_bg@sp.webp);
  width: 100%;
  aspect-ratio: 750/1700;
}

#kv .bg {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  mix-blend-mode: screen;
  pointer-events: none;
}

#kv .bg video {
  transform: translate3d(0, 0, 0);
  width: 100%;
  object-fit: cover;
  object-position: center bottom;
  opacity: 0.4;
  height: 54%;
}

#kv .ill {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  width: 100%;
}

#kv .ill,
#kv .logo,
#kv .lead {
  visibility: hidden;
}

#kv .logo {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  will-change: filter;
  padding-top: 116vw;
  width: 42.6666666667vw;
  filter: drop-shadow(0 0 1.3333333333vw var(--color-white)) drop-shadow(0 0 1.3333333333vw var(--color-white));
}

#kv .lead {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  padding-top: 24vw;
  width: 77.8666666667vw;
  filter: drop-shadow(0 0 1.0666666667vw rgba(var(--color-white-rgb), 0.3)) drop-shadow(0 0 1.0666666667vw rgba(var(--color-white-rgb), 0.3));
}

#md {
  background: var(--color-key5);
  height: 64vw;
}

#news {
  position: relative;
}

#news .inner {
  position: relative;
  z-index: 2;
  margin: 0 auto;
}

#news h2.title {
  width: 48vw;
}

#news .list {
  position: relative;
  z-index: 1;
  margin: 0 auto;
}

#news a {
  position: relative;
  display: flex;
  flex-direction: column;
  line-height: 1.6;
  gap: 1.3333333333vw;
  padding: 4vw 10.6666666667vw 4vw 0;
  font-size: 18px;
}

#news a::after {
  content: "";
  align-self: center;
  aspect-ratio: 1;
  border-top: 2px solid #1d357a;
  border-right: 2px solid #1d357a;
  transform: rotate(45deg);
}

#news .update {
  color: var(--color-navy);
  font-weight: 700;
}

#news .title {
  flex: 1;
  font-weight: 400;
}

#nav {
  background: #fff;
}

#nav .header {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#nav h2.title {
  position: relative;
  will-change: filter;
  width: 72.6666666667vw;
}

#nav h2.title::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 35%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-image: url(../img/toppage/nav_bg_h2@sp.svg);
  width: 100vw;
  aspect-ratio: 750/617;
}

#nav h2.title span {
  filter: drop-shadow(0.9333333333vw 0.9333333333vw 0 rgba(var(--color-black-rgb), 0.1));
}

#nav .lead {
  position: relative;
  line-height: 2;
  width: 89.3333333333vw;
  font-size: 18px;
}

#nav h3.title {
  position: relative;
  line-height: 1;
  font-weight: 900;
  font-style: italic;
  margin-top: 16vw;
  font-size: 42px;
}

#nav h3.title::before,
#nav h3.title::after {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
  position: absolute;
  aspect-ratio: 98/18;
  width: 19.6vw;
}

#nav h3.title::before {
  background-image: url(../img/toppage/nav_bg_h3_l.svg);
  right: 50%;
}

#nav h3.title::after {
  background-image: url(../img/toppage/nav_bg_h3_r.svg);
  left: 50%;
}

#nav h3.title span {
  transform: translateZ(0);
  filter: drop-shadow(0.5333333333vw 0.5333333333vw 0 rgba(var(--color-black-rgb), 0.1));
}

#nav nav {
  margin: 0 auto;
  padding-bottom: 18.6666666667vw;
}

#nav nav .nav-block {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12vw;
}

#nav nav .nav-block.first {
  margin-bottom: 12vw;
}

#nav nav a {
  position: relative;
  background-repeat: no-repeat;
  background-size: 100% auto;
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 710/384;
  width: 94.6666666667vw;
  transition: opacity 0.3s;
}

#nav nav .game a {
  background-image: url(../img/toppage/nav_bg_01@sp.webp);
}

#nav nav .cardgame a {
  background-image: url(../img/toppage/nav_bg_02@sp.webp);
  margin-left: auto;
}

#nav nav .pokemongo a {
  background-image: url(../img/toppage/nav_bg_03@sp.webp);
}

#nav nav .pokemonunite a {
  background-image: url(../img/toppage/nav_bg_04@sp.webp);
  margin-left: auto;
}

#nav nav .title {
  position: absolute;
  top: -4vw;
  left: 0;
  will-change: filter;
  filter: drop-shadow(1.8666666667vw 1.8666666667vw 0 var(--color-black));
}

#nav nav .game .title {
  width: 61.2vw;
}

#nav nav .cardgame .title {
  width: 66.6666666667vw;
}

#nav nav .pokemongo .title {
  width: 77.2vw;
}

#nav nav .pokemonunite .title {
  width: 82.6666666667vw;
}

#nav nav .game .logo {
  width: 50.6666666667vw;
}

#nav nav .cardgame .logo {
  width: 60vw;
}

#nav nav .pokemongo .logo {
  width: 43.7333333333vw;
}

#nav nav .pokemonunite .logo {
  width: 48.6666666667vw;
}

#nav nav .game .button .icon {
  background: var(--color-key1);
}

#nav nav .cardgame .button .icon {
  background: var(--color-key2);
}

#nav nav .pokemongo .button .icon {
  background: var(--color-key3);
}

#nav nav .pokemonunite .button .icon {
  background: var(--color-key4);
}

#nav nav .button {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--color-white);
  position: absolute;
  gap: 1.3333333333vw;
  right: 11.3333333333vw;
  bottom: -2.6666666667vw;
  padding: 2.4vw 3.2vw 2.4vw 5.3333333333vw;
  font-style: italic;
  font-size: 16px;
}

#nav nav .button::before,
#nav nav .button::after {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  clip-path: polygon(3.2vw 0, 100% 0, calc(100% - 3.2vw) 100%, 0 100%);
}

#nav nav .button::before {
  background: var(--color-black);
}

#nav nav .button::after {
  background: rgba(var(--color-black-rgb), 0.4);
  transform: translate(1.0666666667vw, 1.0666666667vw);
}

#nav nav .button .icon {
  position: relative;
  aspect-ratio: 39/30;
  width: 5.2vw;
  clip-path: polygon(1.3333333333vw 0, 100% 0, calc(100% - 1.3333333333vw) 100%, 0 100%);
}

#nav nav .button .icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--color-white);
  aspect-ratio: 18/27;
  -webkit-mask: url(../img/common/ic_arrow@sp.svg) no-repeat;
  -webkit-mask-size: 100% auto;
  mask: url(../img/common/ic_arrow@sp.svg) no-repeat;
  mask-size: 100% auto;
  width: 1.3333333333vw;
}

#nav .ill_r,
#nav .ill_l {
  pointer-events: none;
  position: absolute;
}

#nav .ill_r img,
#nav .ill_l img {
  vertical-align: bottom;
}

#nav .ill_r {
  width: 50.2666666667vw;
  bottom: -4vw;
  right: -13.3333333333vw;
}

#nav .ill_l {
  width: 70.5333333333vw;
  bottom: -20vw;
  left: -24vw;
}

#outline {
  position: relative;
  z-index: 1;
  --slant: 10.67vw;
}

#outline .swiper-wrapper {
  transition-timing-function: linear !important;
}

#outline .swiper-slide {
  overflow: visible;
  position: relative;
  width: 42.6666666667vw;
}

#outline .clip {
  position: relative;
  height: 100%;
  width: calc(100% + var(--slant));
  clip-path: polygon(var(--slant) 0, 100% 0, calc(100% - var(--slant)) 100%, 0 100%);
  margin-left: calc(var(--slant) * -1);
}

#outline .clip img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#outline .inner {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  width: 89.3333333333vw;
  padding-bottom: 20vw;
}

#outline .texts {
  display: flex;
  flex-direction: column;
  gap: 2.6666666667vw;
  margin-bottom: 3.3333333333vw;
}

#outline .texts div {
  display: flex;
  align-items: flex-start;
}

#outline .texts dt,
#outline .texts dd {
  line-height: 1.5;
  font-size: 18px;
}

#outline .texts dt {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  background: #222;
  color: var(--color-white);
  font-weight: 700;
  width: 29.3333333333vw;
  padding: 2vw 4vw;
  clip-path: polygon(0 0, 100% 0, calc(100% - 4vw) 100%, 0 100%);
}

#outline .texts dd {
  flex: 1;
  background: var(--color-white);
  font-weight: 400;
  padding: 2.6666666667vw 4vw 2.6666666667vw 18.6666666667vw;
  margin-left: -16vw;
  margin-top: 4vw;
}

#outline .caution {
  display: flex;
  flex-direction: column;
  color: var(--color-white);
  line-height: 1.5;
  font-weight: 400;
  text-shadow: 3px 3px 5px rgba(var(--color-black-rgb), 0.8);
  font-size: 14px;
}

#outline .caution li {
  text-indent: -1em;
  margin-left: 1em;
}

.cmn-bg {
  bottom: 29.3333333333vw;
}

@media print, screen and (min-width: 768px) {
  #kv {
    background-image: url(../img/toppage/kv_bg@pc.webp);
    aspect-ratio: 1366/940;
  }

  #kv .bg video {
    height: 49%;
  }

  #kv .ill {
    top: 1.4641288433vw;
  }

  #kv .logo {
    padding-top: 36.6032210835vw;
    width: 18.3016105417vw;
    filter: drop-shadow(0 0 min(7px,  calc(7 / 1366 * 100vw)) var(--color-white)) drop-shadow(0 0 min(7px,  calc(7 / 1366 * 100vw)) var(--color-white));
  }

  #kv .lead {
    padding-top: 2.9282576867vw;
    width: 72.9136163982vw;
    filter: drop-shadow(0 0 min(5px,  calc(5 / 1366 * 100vw)) rgba(var(--color-white-rgb), 0.3)) drop-shadow(0 0 min(5px,  calc(5 / 1366 * 100vw)) rgba(var(--color-white-rgb), 0.3));
  }

  #md {
    height: min(250px,  calc(250 / 1366 * 100vw));
  }

  #news {
    padding-top: min(70px,  calc(70 / 1366 * 100vw));
  }

  #news::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: linear-gradient(180deg, var(--color-navy) 60%, var(--color-white));
    width: 100%;
    height: calc(100% + min(150px,  calc(150 / 1366 * 100vw)));
  }

  #news .inner {
    padding: min(80px,  calc(80 / 1366 * 100vw)) 0 min(60px,  calc(60 / 1366 * 100vw)) 0;
    width: min(1080px,  calc(1080 / 1366 * 100vw));
  }

  #news .inner::before,
  #news .inner::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  #news .inner::before {
    background: var(--color-white);
  }

  #news .inner::after {
    background-image: repeating-linear-gradient(0deg, rgba(var(--color-white-rgb), 0.4), rgba(var(--color-white-rgb), 0.4) 2px, transparent 2px, transparent 4px);
  }

  #news h2.title {
    position: absolute;
    z-index: 1;
    top: min(12px,  calc(12 / 1366 * 100vw));
    left: min(45px,  calc(45 / 1366 * 100vw));
    width: min(276px,  calc(276 / 1366 * 100vw));
  }

  #news .list {
    width: min(760px,  calc(760 / 1366 * 100vw));
  }

  #news .list li:not(:last-child) {
    border-bottom: 1px solid #1d357a;
  }

  #news a {
    flex-direction: row;
    gap: min(40px,  calc(40 / 1366 * 100vw));
    padding: min(25px,  calc(25 / 1366 * 100vw)) min(5px,  calc(5 / 1366 * 100vw)) min(25px,  calc(25 / 1366 * 100vw)) 0;
  }

  #news a::after {
    transform: rotate(45deg);
    width: min(12px,  calc(12 / 1366 * 100vw));
  }

  #nav .header {
    padding-top: min(90px,  calc(90 / 1366 * 100vw));
    gap: min(60px,  calc(60 / 1366 * 100vw));
    margin-bottom: min(60px,  calc(60 / 1366 * 100vw));
  }

  #nav .header::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: linear-gradient(180deg, var(--color-navy), var(--color-white));
    width: 100%;
    height: min(200px,  calc(200 / 1366 * 100vw));
  }

  #nav h2.title {
    width: min(684px,  calc(684 / 1366 * 100vw));
  }

  #nav h2.title::before {
    aspect-ratio: 1366/567;
    background-image: url(../img/toppage/nav_bg_h2@pc.svg);
  }

  #nav h2.title span {
    filter: drop-shadow(min(7px,  calc(7 / 1366 * 100vw)) min(7px,  calc(7 / 1366 * 100vw)) 0 rgba(var(--color-black-rgb), 0.1));
  }

  #nav .lead {
    width: min(994px,  calc(994 / 1366 * 100vw));
  }

  #nav h3.title {
    margin-top: 0;
  }

  #nav h3.title::before,
  #nav h3.title::after {
    top: 50%;
    transform: translateY(-50%);
    width: min(98px,  calc(98 / 1366 * 100vw));
  }

  #nav h3.title::before {
    margin-right: min(110px,  calc(110 / 1366 * 100vw));
  }

  #nav h3.title::after {
    margin-left: min(125px,  calc(125 / 1366 * 100vw));
  }

  #nav h3.title span {
    filter: drop-shadow(min(4px,  calc(4 / 1366 * 100vw)) min(4px,  calc(4 / 1366 * 100vw)) 0 rgba(var(--color-black-rgb), 0.1));
  }

  #nav nav {
    width: min(1080px,  calc(1080 / 1366 * 100vw));
    padding-bottom: min(110px,  calc(110 / 1366 * 100vw));
  }

  #nav nav .nav-block {
    position: relative;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }

  #nav nav .nav-block.first {
    margin-bottom: min(40px,  calc(40 / 1366 * 100vw));
    transform: translateX(max(-80px,  calc(-80 / 1366 * 100vw)));
  }

  #nav nav .nav-block.last {
    transform: translateX(min(80px,  calc(80 / 1366 * 100vw)));
  }

  #nav nav a {
    aspect-ratio: 560/320;
    width: min(560px,  calc(560 / 1366 * 100vw));
  }

  #nav nav .game a {
    background-image: url(../img/toppage/nav_bg_01@pc.webp);
    margin-right: max(-20px,  calc(-20 / 1366 * 100vw));
  }

  #nav nav .cardgame a {
    background-image: url(../img/toppage/nav_bg_02@pc.webp);
    margin-left: max(-20px,  calc(-20 / 1366 * 100vw));
  }

  #nav nav .pokemongo a {
    background-image: url(../img/toppage/nav_bg_03@pc.webp);
    margin-right: max(-20px,  calc(-20 / 1366 * 100vw));
  }

  #nav nav .pokemonunite a {
    background-image: url(../img/toppage/nav_bg_04@pc.webp);
    margin-left: max(-20px,  calc(-20 / 1366 * 100vw));
  }

  #nav nav .title {
    top: min(20px,  calc(20 / 1366 * 100vw));
    left: min(55px,  calc(55 / 1366 * 100vw));
    filter: drop-shadow(min(7px,  calc(7 / 1366 * 100vw)) min(7px,  calc(7 / 1366 * 100vw)) 0 var(--color-black));
  }

  #nav nav .game .title {
    width: min(375px,  calc(375 / 1366 * 100vw));
  }

  #nav nav .cardgame .title {
    width: min(376px,  calc(376 / 1366 * 100vw));
  }

  #nav nav .pokemongo .title {
    width: min(416px,  calc(416 / 1366 * 100vw));
  }

  #nav nav .pokemonunite .title {
    width: min(456px,  calc(456 / 1366 * 100vw));
  }

  #nav nav .logo {
    margin-top: min(40px,  calc(40 / 1366 * 100vw));
  }

  #nav nav .game .logo {
    width: min(296px,  calc(296 / 1366 * 100vw));
  }

  #nav nav .cardgame .logo {
    width: min(322px,  calc(322 / 1366 * 100vw));
  }

  #nav nav .pokemongo .logo {
    width: min(255px,  calc(255 / 1366 * 100vw));
  }

  #nav nav .pokemonunite .logo {
    width: min(266px,  calc(266 / 1366 * 100vw));
  }

  #nav nav .button {
    gap: min(10px,  calc(10 / 1366 * 100vw));
    right: min(70px,  calc(70 / 1366 * 100vw));
    bottom: max(-12px,  calc(-12 / 1366 * 100vw));
    padding: min(12px,  calc(12 / 1366 * 100vw)) min(20px,  calc(20 / 1366 * 100vw)) min(12px,  calc(12 / 1366 * 100vw)) min(36px,  calc(36 / 1366 * 100vw));
  }

  #nav nav .button::before,
  #nav nav .button::after {
    clip-path: polygon(min(16px,  calc(16 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(16px,  calc(16 / 1366 * 100vw))) 100%, 0 100%);
  }

  #nav nav .button::after {
    transform: translate(min(5px,  calc(5 / 1366 * 100vw)), min(5px,  calc(5 / 1366 * 100vw)));
  }

  #nav nav .button .icon {
    aspect-ratio: 28/20;
    width: min(28px,  calc(28 / 1366 * 100vw));
    clip-path: polygon(min(6px,  calc(6 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(6px,  calc(6 / 1366 * 100vw))) 100%, 0 100%);
  }

  #nav nav .button .icon::after {
    width: min(6px,  calc(6 / 1366 * 100vw));
  }

  #nav .ill_r {
    width: min(377px,  calc(377 / 1366 * 100vw));
    bottom: auto;
    right: auto;
    top: max(-40px,  calc(-40 / 1366 * 100vw));
    left: 50%;
    margin-left: min(435px,  calc(435 / 1366 * 100vw));
  }

  #nav .ill_l {
    width: min(529px,  calc(529 / 1366 * 100vw));
    bottom: auto;
    left: auto;
    top: min(30px,  calc(30 / 1366 * 100vw));
    right: 50%;
    margin-right: min(380px,  calc(380 / 1366 * 100vw));
  }

  #outline {
    --slant: min(80px, calc(80 / 1366 * 100vw));
  }

  #outline .swiper-slide {
    width: calc(min(320px,  calc(320 / 1366 * 100vw)));
  }

  #outline .inner {
    width: min(994px,  calc(994 / 1366 * 100vw));
    padding-bottom: min(110px,  calc(110 / 1366 * 100vw));
  }

  #outline .texts {
    gap: min(12px,  calc(12 / 1366 * 100vw));
    margin-bottom: min(20px,  calc(20 / 1366 * 100vw));
  }

  #outline .texts dt {
    width: min(220px,  calc(220 / 1366 * 100vw));
    padding: min(12px,  calc(12 / 1366 * 100vw)) min(40px,  calc(40 / 1366 * 100vw));
    clip-path: polygon(min(15px,  calc(15 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(15px,  calc(15 / 1366 * 100vw))) 100%, 0 100%);
  }

  #outline .texts dd {
    padding: min(12px,  calc(12 / 1366 * 100vw)) min(40px,  calc(40 / 1366 * 100vw)) min(12px,  calc(12 / 1366 * 100vw)) min(90px,  calc(90 / 1366 * 100vw));
    clip-path: polygon(min(15px,  calc(15 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(15px,  calc(15 / 1366 * 100vw))) 100%, 0 100%);
    margin-left: max(-70px,  calc(-70 / 1366 * 100vw));
    margin-top: min(10px,  calc(10 / 1366 * 100vw));
  }

  .cmn-bg {
    bottom: min(130px,  calc(130 / 1366 * 100vw));
  }

  .cmn-bg::before {
    clip-path: polygon(0 0, 100% calc(100% - 44.6559297218vw), 100% 100%, 0% 100%);
    background-color: #efefef;
  }
}

@media print, screen and (min-width: 768px) and (min-width: 768px) {
  #news .inner::before {
    width: min(1080px,  calc(1080 / 1366 * 100vw));
    height: 100%;
    clip-path: polygon(min(90px,  calc(90 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(90px,  calc(90 / 1366 * 100vw))) 100%, 0 100%);
  }

  #news .inner::after {
    width: min(1100px,  calc(1100 / 1366 * 100vw));
    height: calc(100% + min(20px,  calc(20 / 1366 * 100vw)));
    clip-path: polygon(min(90px,  calc(90 / 1366 * 100vw)) 0, 100% 0, calc(100% - min(90px,  calc(90 / 1366 * 100vw))) 100%, 0 100%);
  }
}

@media print and (hover: hover), screen and (min-width: 768px) and (hover: hover) {
  #news a:hover .title {
    text-decoration: underline;
  }

  #nav nav a:hover {
    opacity: 0.7 !important;
  }
}

@media screen and (min-width: 768px) and (-ms-high-contrast: active), screen and (min-width: 768px) and (-ms-high-contrast: none) {
  #news a:hover .title {
    text-decoration: underline;
  }

  #nav nav a:hover {
    opacity: 0.7 !important;
  }
}

@media only screen and (max-width: 767.8px) {
  #news .inner {
    background: var(--color-white);
    padding: 8vw 0 13.3333333333vw 0;
  }

  #news h2.title {
    margin-bottom: 8vw;
  }

  #news .list {
    width: 78.6666666667vw;
    border-top: 1px solid #1d357a;
  }

  #news .list li {
    border-bottom: 1px solid #1d357a;
  }

  #news a {
    font-size: 3rem;
  }

  #news a::after {
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    right: 2.6666666667vw;
    width: 2.4vw;
  }

  #nav .header {
    gap: 12vw;
    padding-top: 16vw;
    margin-bottom: 20vw;
  }

  #nav .header::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: linear-gradient(180deg, var(--color-navy), var(--color-white));
    width: 100%;
    height: 26.6666666667vw;
  }

  #nav .lead {
    font-size: 3rem;
  }

  #nav h3.title {
    font-size: 6.3rem;
  }

  #nav h3.title::before {
    bottom: -8vw;
    margin-right: 5.3333333333vw;
  }

  #nav h3.title::after {
    top: -6.6666666667vw;
    margin-left: 5.3333333333vw;
  }

  #nav nav .cardgame .title {
    left: 8vw;
  }

  #nav nav .pokemonunite .title {
    left: 8vw;
  }

  #nav nav .game .logo {
    margin-right: 10.6666666667vw;
  }

  #nav nav .cardgame .logo {
    margin-left: 10.6666666667vw;
  }

  #nav nav .pokemongo .logo {
    margin-right: 10.6666666667vw;
  }

  #nav nav .pokemonunite .logo {
    margin-left: 10.6666666667vw;
  }

  #nav nav .cardgame .button,
  #nav nav .pokemonunite .button {
    right: 1.3333333333vw;
  }

  #nav nav .button {
    font-size: 2.8rem;
  }

  #outline .texts dt,
  #outline .texts dd {
    font-size: 3rem;
  }

  #outline .caution {
    font-size: 2.4rem;
  }

  #outline .caution {
    gap: 1.3333333333vw;
  }

  .cmn-bg::before {
    background-image: url(../img/toppage/bg@sp.webp);
    aspect-ratio: 750/2172;
  }
}

@media screen and (min-width: 768px) and (max-width: 1365.8px) {
  #news a {
    font-size: 1.8rem;
  }

  #nav .lead {
    font-size: 1.8rem;
  }

  #nav h3.title {
    font-size: 4.2rem;
  }

  #nav nav .button {
    font-size: 1.6rem;
  }

  #outline .texts dt,
  #outline .texts dd {
    font-size: 1.8rem;
  }

  #outline .caution {
    font-size: 1.4rem;
  }
}