@charset "Shift_JIS";@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500&family=Roboto:wght@500&display=swap");@import 'https://fonts.googleapis.com/css2?family=Aboreto&display=swap';
/* stylelint-disable */


/* https://piccalil.li/blog/a-modern-css-reset/ */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizespeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  display: block;
  max-width: 100%;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
/* ============================== アワード共通CSS ============================== */
/*--- リセット ---*/
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td {
  padding: 0;
  margin: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}

fieldset,
img,
a img {
  border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-weight: normal;
  font-style: normal;
}

ol,
ul,
li {
  list-style: none;
  margin: 0;
  padding: 0;
}

caption,
th {
  text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  font-size: 100%;
}

q:before,
q:after {
  content: "";
}

abbr,
acronym {
  border: 0;
}

img {
  vertical-align: bottom;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

select {
  margin: 0;
}

html {
  overflow: auto;
}

/*--- 共通 ---*/
body {
  background-color: #fff;
  font-size: 100%;
  color: #2a2a2a;
  text-align: center;
  font-family: "メイリオ", Meiryo, "MS Pゴシック", "MS P Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Osaka", arial, sans-serif, verdana, Helvetica;
}

a:link {
  text-decoration: none;
  cursor: pointer;
}

#contentAll {
  text-align: left;
  overflow: hidden;
}

#contentAll h1 {
  position: absolute;
  color: transparent;
}

.mediaSP {
  display: none;
}

.mediaSP-inline {
  display: none;
}

.preload * {
  transition: none !important;
}

/*--- ヘッダー ---*/
#header_lp {
  width: 100%;
  background: #000;
  height: 70px;
  padding-top: 10px;
}

.header_inner {
  width: 1280px;
  margin: 0 auto;
}

.logo {
  display: block;
  width: 127px;
  height: 50px;
  background: url("/award/images2025/logo_beauty.png?20240222") no-repeat center left;
  background-size: 127px 50px;
  overflow: hidden;
  white-space: nowrap;
  color: transparent !important;
}

/*--- ぱんくず ---*/
#breadcrumbs {
  padding: 15px 0;
  margin: 0 auto 0;
  width: 1240px;
  text-align: center;
  border-top: 1px solid #cccccc;
}

#breadcrumbs p {
  max-width: 1240px;
  margin: 0 auto;
  color: #666666;
  font-size: 10px;
  line-height: 120%;
  text-align: left;
}

#breadcrumbs a {
  font-weight: normal;
}

#breadcrumbs a:link {
  color: #999999;
  text-decoration: none;
  cursor: pointer;
}

#breadcrumbs a:visited {
  color: #7976a6;
  text-decoration: none;
}

#breadcrumbs a:hover {
  color: #7878cc;
  text-decoration: underline;
}

#breadcrumbs a:active {
  color: #7878cc;
  text-decoration: underline;
}

/*=============== メインビジュアル ===============*/
.lowerHeader {
  position: relative;
  display: flex;
  justify-content: center;
  height: 260px;
  background: url("/award/images2024/MV_bgShort.jpg?20240222") no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lowerHeader {
    height: clamp(200px, 53vw, 260px);
  }
}
@media screen and (max-width: 488px) {
  .lowerHeader {
    background: url("/award/images2024/MV_bgShortSP.jpg?20240222") no-repeat;
    background-size: cover;
    background-position: center center;
  }
}
.lowerHeader__logo {
  display: block;
  width: 700px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .lowerHeader__logo {
    display: none;
  }
}
.lowerHeader__logoSP {
  display: none;
}
@media screen and (max-width: 767px) {
  .lowerHeader__logoSP {
    display: block;
    width: auto;
    height: 100%;
  }
}
.lowerHeader__logoImg {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .lowerHeader__logoImg {
    width: auto;
    height: 100%;
  }
}

/*=============== コンテンツ ===============*/
#container {
  position: relative;
  z-index: 1;
  color: #ffffff;
  background-color: #18131d;
  background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 28%, rgba(173, 52, 190, 0.19) 43%, rgba(173, 52, 190, 0.2) 48%, rgba(0, 0, 0, 0) 61%);
  text-align: center;
  font-family: "Noto Sans JP", "Roboto", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
@media screen and (max-width: 767px) {
  #container {
    background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 33%, rgba(173, 52, 190, 0.23) 53%, rgba(0, 0, 0, 0) 65%);
  }
}

.main_outer {
  position: relative;
  z-index: 1;
  width: 100%;
  background-color: #18131d;
  padding: 64px 48px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .main_outer {
    padding: 55px 0px 80px;
  }
}
.main_outer--contest {
  padding: 72px 48px 64px;
  background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 15%, rgba(173, 52, 190, 0.14) 30.56%, rgba(173, 52, 190, 0.15) 35.76%, rgba(84, 84, 84, 0) 49.35%);
}
.main_outer--style {
  background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 23%, rgba(0, 202, 171, 0.095) 49.57%, rgba(0, 202, 171, 0.1) 58.9%, rgba(0, 0, 0, 0) 82.52%);
}
@media screen and (max-width: 767px) {
  .main_outer--style {
    background-image: none;
  }
}
.main_outer--ceremony {
  padding: 24px 48px 80px;
}
@media screen and (max-width: 767px) {
  .main_outer--ceremony {
    padding: 12px 0px 80px;
  }
}

/*--- 見出し ---*/
.title_sp,
.title_sp_sml {
  display: none;
}

.contents_title_tag_txt {
  position: relative;
  display: inline-block;
  background-color: rgba(0, 202, 171, 0.1);
  padding: 4px 24px 6px 32px;
  border: 1px solid #ffffff;
  border-radius: 50px;
  font-size: 16px;
  color: #fff;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .contents_title_tag_txt {
    padding: 5px 17px 6px;
    font-size: 12px;
  }
}
.contents_title_tag_txt--mens {
  padding: 4px 29px 6px 37px;
}
@media screen and (max-width: 767px) {
  .contents_title_tag_txt--mens {
    padding: 5px 20px 6px;
    font-size: 12px;
  }
}
.contents_title_tag_txt::before {
  z-index: -10;
  content: "";
  display: block;
  position: absolute;
  top: -2px;
  left: -2px;
  width: calc(100% + 4px);
  height: calc(100% + 4px);
  border: 3px solid #00caab;
  border-radius: 50px;
}
.contents_title_tag_txt::after {
  z-index: -20;
  content: "";
  display: block;
  position: absolute;
  top: -3px;
  left: -3px;
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  border: 6px solid #00caab;
  border-radius: 50px;
  filter: blur(10px);
}

.title_jp {
  display: block;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
}

.title_jp_wht {
  color: #fff;
}

.other_contents_title .title_jp,
.sub_contents_title .title_jp {
  margin-bottom: 40px;
}

.title_lead {
  max-width: 761px;
  margin: 40px auto 0;
  font-size: 14px;
  line-height: 2;
  text-align: center;
}

.caution {
  display: block;
  font-size: 14px;
  line-height: 1.4285714286;
  letter-spacing: 0.05em;
}

.caution_top {
  margin-top: 5px;
  margin-left: 1em;
}

.caution_under {
  margin-left: 1em;
}

.caution::before {
  content: "※";
  margin-left: -1em;
}

/*--- バナーリンク ---*/
.link_bn {
  margin-top: 120px;
  padding: 0 20px;
}
@media screen and (max-width: 767px) {
  .link_bn {
    margin-top: 80px;
  }
}

.link_bn a {
  display: block;
  margin: 0 auto;
  width: fit-content;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .link_bn a {
    width: auto;
  }
}

@media screen and (max-width: 767px) {
  .link_bn img {
    width: 100%;
  }
}

.link_bn a:hover {
  opacity: 0.6;
}
@media screen and (max-width: 767px) {
  .link_bn a:hover {
    opacity: 1;
  }
}

/*--- その他のコンテンツ ---*/
.other_contents {
  width: 100%;
  padding: 64px 48px;
  margin-bottom: 80px;
  background: #979797;
  color: #fff;
  text-align: center;
}

.other_contents_list {
  max-width: 780px;
  margin: 0 auto -10px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.other_contents_list li {
  width: 244px;
  height: auto;
  margin: 0 5px 10px;
  background-color: #000;
}

.other_contents_list li a {
  display: block;
  transition: 0.3s;
}

.other_contents_list li a:hover {
  opacity: 0.6;
}

.other_contents_list li img {
  width: 100%;
}

/*--- SNS ---*/
.snsArea {
  position: relative;
  border-top: 1px solid #c1bcbc;
  border-bottom: 1px solid #c1bcbc;
  width: 400px;
  margin: 60px auto 30px;
  padding: 20px 0;
}

.snsArea p {
  width: 160px;
  display: block;
  position: absolute;
  top: -10px;
  right: 0;
  left: 0;
  margin: 0 auto;
  text-align: center;
  margin-bottom: 10px;
  font-size: 14px;
}

.snsArea p span {
  display: block;
  width: 160px;
  padding: 0;
  font-weight: bold;
  color: #ef507a;
  background-color: #fff;
}

.snsArea .inner {
  width: 180px;
  margin: 5px auto 0;
}

.snsArea .inner .snsArea_fb,
.snsArea .inner .snsArea_tw {
  float: left;
  width: 40px;
  margin-right: 30px;
}

.snsArea .inner .snsArea_line {
  float: left;
  width: 40px;
  margin-right: 0;
}

.snsArea .snsArea_line img,
.snsArea .snsArea_tw img,
.snsArea .snsArea_fb img {
  width: 40px;
  height: 40px;
}

.snsArea .inner .snsArea_line img:hover,
.snsArea .inner .snsArea_tw img:hover,
.snsArea .inner .snsArea_fb img:hover {
  opacity: 0.7;
}

.snsArea .inner:after {
  content: "";
  display: block;
  clear: both;
}

.snsArea .snsArea_line .snsArea_line_sp,
.snsArea .snsArea_tw .snsArea_tw_sp,
.snsArea .snsArea_fb .snsArea_fb_sp {
  display: none;
}

.snsArea .snsArea_line .snsArea_line_pc,
.snsArea .snsArea_tw .snsArea_tw_pc,
.snsArea .snsArea_fb .snsArea_fb_pc {
  width: 40px;
  height: 40px;
}

/*--- フッター ---*/
#footer_lp {
  position: relative;
  max-width: 1240px;
  margin: 0 auto 10px;
  padding: 10px 0 20px;
  border-top: 1px solid #dddddd;
}

#copyright_lp a {
  font-size: 10px;
  color: #435b67;
  font-weight: bold;
}

#footer_lp a {
  line-height: initial;
}

#footer_lp a:link {
  color: #999999;
  text-decoration: none;
  cursor: pointer;
}

#footer_lp a:visited {
  color: #999999;
  text-decoration: none;
}

#footer_lp a:hover {
  color: #7878cc;
  text-decoration: underline;
}

#footer_lp a:active {
  color: #7878cc;
  text-decoration: underline;
}

#copyright_lp a:link {
  color: #999999;
  text-decoration: none;
}

#copyright_lp a:visited {
  color: #4c4c80;
  text-decoration: none;
}

#copyright_lp a:hover {
  color: #7878cc;
  text-decoration: underline;
}

#copyright_lp a:active {
  color: #7878cc;
  text-decoration: underline;
}

#footerLinks_lp {
  font-size: 12px;
  overflow: hidden;
  position: absolute;
  top: 10px;
  right: -15px;
}

#footerLinks_lp:after {
  content: "";
  display: block;
  clear: both;
}

#footerLinks_lp li {
  float: left;
  border-right: 1px solid #ddd;
  padding-right: 15px;
  margin-left: 15px;
  margin-right: -1px;
}

/*--- ボタン ---*/
.common_link_btn_container {
  display: flex;
  justify-content: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .common_link_btn_container {
    padding: 0 20px;
  }
}

.common_link_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin: 0 auto;
  margin-top: 64px;
  width: 240px;
  height: 48px;
  border: 1px solid #ffffff;
  border-radius: 2px;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .common_link_btn {
    margin-top: 40px;
    width: 100%;
  }
}

.common_link_btn_inner {
  z-index: 1;
  font-size: 14px;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: 0.08em;
  text-decoration: none;
}

.common_link_btn::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 100%);
  border-radius: 2px;
  transition: 0.3s;
  opacity: 0;
}

.common_link_btn::after {
  display: block;
  content: "";
  position: absolute;
  top: 20px;
  right: 14px;
  width: 7px;
  height: 7px;
  border-top: 1px solid #ffffff;
  border-left: 1px solid #ffffff;
  transform: rotate(135deg);
  transition: 0.3s;
}

.common_link_btn:hover::before {
  transition: 0.3s;
  opacity: 1;
}

/*--- ページトップボタン ---*/
.pageTop {
  position: fixed;
  width: 60px;
  height: 60px;
  right: 80px;
  bottom: 70px;
  border: 1px solid #e223af;
  background-color: rgba(0, 0, 0, 0.14);
  backdrop-filter: blur(7.83px);
  border-radius: 50px;
  opacity: 0;
  transition: 0.8s;
  pointer-events: none;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .pageTop {
    right: 10px;
    bottom: 16px;
  }
}
.pageTop--active {
  opacity: 1;
}
.pageTop:hover::before {
  opacity: 1;
}
.pageTop::before {
  position: absolute;
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to top, rgba(234, 66, 170, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
  border-radius: 50px;
  opacity: 0;
  transition: 0.3s;
}
.pageTop__button {
  display: block;
  width: 100%;
  height: 100%;
  pointer-events: auto;
}
.pageTop__button::before {
  display: block;
  content: "";
  position: absolute;
  top: 28px;
  right: 13px;
  width: 19px;
  height: 2px;
  border-radius: 1px;
  background-color: #e223af;
  transform: rotate(45deg);
}
.pageTop__button::after {
  display: block;
  content: "";
  position: absolute;
  top: 28px;
  right: 26px;
  width: 19px;
  height: 2px;
  border-radius: 1px;
  background-color: #e223af;
  transform: rotate(-45deg);
}

/* ============================== iPad対応 max-width: 834px ============================== */
/* ============================== SP対応 max-width: 767px ============================== */
@media screen and (max-width: 767px) {
  /*--- 共通 ---*/
  body {
    line-height: 1.3;
    min-width: 320px;
    -webkit-text-size-adjust: none;
    font-family: "メイリオ", Meiryo, "MS Pゴシック", "MS P Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Osaka", arial, sans-serif, verdana, Helvetica;
  }
  .mediaPC {
    display: none;
  }
  .mediaSP {
    display: block;
  }
  .mediaSP-inline {
    display: inline;
  }
  .mediaTab {
    display: block;
  }
  #contentAll {
    min-width: 100%;
  }
  /*--- ヘッダー ---*/
  #header_lp {
    width: auto;
    min-width: 100%;
    height: 54px;
    padding: 10px 20px;
  }
  .logo {
    display: block;
    width: auto;
    height: 34px;
    background-size: auto 34px;
  }
  /*--- ぱんくず ---*/
  #breadcrumbs {
    margin: 0 15px;
    width: auto;
  }
  #breadcrumbs a {
    color: #999999;
    line-height: 1.5;
  }
  #breadcrumbs a:visited {
    text-decoration: underline;
  }
  #breadcrumbs a:link {
    text-decoration: underline;
  }
  /*=============== メインビジュアル ===============*/
  #container {
    line-height: 1.3;
    min-width: 320px;
    -webkit-text-size-adjust: none;
  }
  /*=============== コンテンツ ===============*/
  /*--- 見出し ---*/
  .contents_title,
  .other_contents_title {
    max-width: fit-content;
    margin: 0 auto;
    text-align: center;
  }
  .title_pc {
    display: none;
  }
  .title_sp {
    display: block;
  }
  .title_sp_sml {
    display: block;
    height: 22px;
  }
  .title_jp {
    font-size: 12px;
    margin-top: 16px;
  }
  .contents_title .title_jp,
  .other_contents_title .title_jp {
    display: block;
    font-size: 12px;
  }
  .other_contents_title .title_jp {
    margin-top: 14px;
  }
  .title_lead {
    padding-right: 20px;
    padding-left: 20px;
    font-size: 14px;
    line-height: 2;
    text-align: left;
  }
  /*--- バナーリンク ---*/
  .link_bn a img {
    width: 100%;
    height: auto;
  }
  .link_bn a:hover {
    opacity: 1;
  }
  /*--- その他のコンテンツ ---*/
  .other_contents {
    padding: 60px 20px 40px;
    margin-bottom: 60px;
  }
  .other_contents_list {
    width: 100%;
    margin-bottom: 0;
  }
  .other_contents_list:after {
    content: none;
  }
  .other_contents_list li {
    width: auto;
    margin: 20px 0 0;
    text-align: center;
  }
  .other_contents_list li:first-child {
    margin: 0;
  }
  .other_contents_list li a:hover {
    opacity: 1;
  }
  .other_contents_list li img {
    width: 100%;
  }
  /*--- SNS ---*/
  .snsArea {
    border-bottom: none;
    width: 80%;
    margin: 52px auto 0;
    padding: 20px 0;
  }
  .snsArea p span {
    padding: 0 5px;
  }
  .snsArea .inner {
    width: 180px;
    margin: 0 auto;
  }
  .snsArea .inner .snsArea_fb,
  .snsArea .inner .snsArea_tw {
    margin-right: 30px;
  }
  .snsArea .snsArea_line .snsArea_line_sp,
  .snsArea .snsArea_tw .snsArea_tw_sp,
  .snsArea .snsArea_fb .snsArea_fb_sp {
    width: 40px;
    display: block;
  }
  .snsArea .snsArea_line .snsArea_line_pc,
  .snsArea .snsArea_tw .snsArea_tw_pc,
  .snsArea .snsArea_fb .snsArea_fb_pc {
    display: none;
  }
  .snsArea .inner .snsArea_line img:hover,
  .snsArea .inner .snsArea_tw img:hover,
  .snsArea .inner .snsArea_fb img:hover {
    opacity: 1;
  }
  /*--- フッター ---*/
  #footer_lp {
    border-top: 1px solid #ddd;
    padding-top: 5px;
    width: 94%;
    margin: 5px auto 20px auto;
    height: auto;
  }
  #footer_lp a:link,
  #footer_lp a:visited,
  #copyright_lp a:link,
  #copyright_lp a:link {
    text-decoration: underline;
  }
  #copyright_lp {
    position: static;
    padding: 0;
    margin-top: 22px;
  }
  #footerLinks_lp {
    font-size: 10px;
    line-height: 14px;
    position: static;
  }
  #footerLinks_lp li {
    padding: 0 5px 0 0;
    margin: 0 5px 5px 0;
  }
  /*--- ボタン ---*/
  .common_link_btn a {
    width: 100%;
    height: 54px;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-decoration: none;
  }
  .common_link_btn a::after {
    top: 23px;
    right: 14px;
  }
}
.prizeHead__item, .sectionTitle__en {
  font-family: Aboreto, sans-serif;
}

.previous__link {
  font-family: Roboto, sans-serif;
}

body, .overview__text, .overview__note, .ceremony__text {
  font-family: "Noto Sans JP", sans-serif;
}

.snsArea,
#breadcrumbs,
#footer_lp {
  font-family: "メイリオ", Meiryo, "MS Pゴシック", "MS P Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, arial, sans-serif, verdana, Helvetica;
}

.overview__text, .overview__note, .ceremony__text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75;
  color: #001a57;
}

* {
  padding: 0;
  margin: 0;
  line-height: 1;
}

html {
  scroll-behavior: smooth;
}

main {
  display: block;
}

ul li {
  list-style: none;
}

.onlyPc {
  display: block;
}
.onlyPc.--inline {
  display: inline;
}
.onlyPc.--flex {
  display: flex;
}
@media screen and (max-width: 767px) {
  .onlyPc {
    display: none;
  }
  .onlyPc.--inline {
    display: none;
  }
  .onlyPc.--flex {
    display: none;
  }
}

.onlySp {
  display: none;
}
@media screen and (max-width: 767px) {
  .onlySp {
    display: block;
  }
  .onlySp.--inline {
    display: inline;
  }
  .onlySp.--flex {
    display: flex;
  }
}

.mv {
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 12px 0 20px;
  background-image: url("/award/images2025/mv/bg.png");
  background-repeat: repeat-x;
  background-position: top;
  background-size: 100% 100%;
}
@media screen and (max-width: 767px) {
  .mv {
    padding: 14px 0 24px;
    background-image: url("/award/images2025/mv/bg_sp.png");
  }
}
.mv--top {
  padding: 8px 0 42px;
  background-size: 100% 350px;
}
@media screen and (max-width: 767px) {
  .mv--top {
    padding: 26px 0 68px;
    background-size: 100% 310px;
  }
}

.top, .salon, .styleCollection, .contest {
  background: linear-gradient(90deg, #fffbf5 0%, #fff2fd 100%);
}
.top__main {
  position: relative;
  z-index: 10;
  margin-top: -25px;
}
@media screen and (max-width: 767px) {
  .top__main {
    margin-top: -48px;
  }
}
.top__ceremony {
  margin-top: 80px;
}
.top__overview {
  margin-top: 80px;
}
.top__previous {
  margin-top: 80px;
}

.mainContent {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  box-shadow: 0 4px 24px #906b9d33;
}

.mainContent {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 384px), 1fr));
  width: 100%;
  max-width: 1280px;
  padding: 60px 0;
  margin: 0 auto;
  background-color: #ffffff99;
  border-radius: 60px 6px;
}
@media screen and (max-width: 767px) {
  .mainContent {
    padding: 0;
  }
}
.mainContent__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  row-gap: 24px;
  padding: 0 min(48px, 3.3333333333vw);
}
@media screen and (max-width: 767px) {
  .mainContent__item {
    row-gap: 8px;
    padding: 64px 20px 60px;
  }
}
.mainContent__item:nth-of-type(even) {
  position: relative;
  padding-right: 50px;
}
@media screen and (max-width: 767px) {
  .mainContent__item:nth-of-type(even) {
    padding-right: 20px;
  }
}
.mainContent__item:nth-of-type(even)::before {
  position: absolute;
  left: 0;
  display: block;
  width: 2px;
  height: 100%;
  content: "";
  background: linear-gradient(90deg, #9969b7 0%, #f1bcdb 100%);
}
@media screen and (max-width: 767px) {
  .mainContent__item:nth-of-type(even)::before {
    width: 100%;
    height: 2px;
  }
}
.mainContent__style {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .mainContent__style {
    margin-top: 40px;
  }
}
.mainContent__text {
  font-size: 14px;
  line-height: 2;
  color: #001a57;
}
@media screen and (max-width: 767px) {
  .mainContent__text {
    padding-bottom: 32px;
  }
}
@media screen and (max-width: 767px) {
  .mainContent__text--adjustment {
    margin-top: 13px;
  }
}
.mainContent__mark {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .mainContent__mark {
    margin-top: unset;
  }
}

.sectionTitle {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .sectionTitle {
    gap: 6px;
  }
}
.sectionTitle__en {
  font-size: 48px;
  line-height: 1.1666666667;
  color: transparent;
  text-align: center;
  letter-spacing: 0.06em;
  background: linear-gradient(180deg, #4d4298 27.23%, #b13ea5 80.36%);
  background-clip: text;
}
@media screen and (max-width: 767px) {
  .sectionTitle__en {
    font-size: 40px;
    line-height: 1;
  }
}
.sectionTitle__ja {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  color: #606060;
}
@media screen and (max-width: 767px) {
  .sectionTitle__ja {
    font-size: 12px;
  }
}
.sectionTitle--pageTop .sectionTitle__en {
  font-size: 60px;
}
@media screen and (max-width: 767px) {
  .sectionTitle--pageTop .sectionTitle__en {
    font-size: 40px;
  }
}

.areaList {
  position: relative;
  padding: 47px 0 154px;
}
@media screen and (max-width: 767px) {
  .areaList {
    padding: 40px 0 75px;
  }
}
.areaList__map {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 413px;
  height: 450px;
}
@media screen and (max-width: 767px) {
  .areaList__map {
    width: 327px;
    height: 355px;
  }
}
.areaList__map--sa {
  display: none;
}
.areaList__map--sb {
  display: none;
}
.areaList__map--sc {
  display: none;
}
.areaList__map--sd {
  display: none;
}
.areaList__map--se {
  display: none;
}
.areaList__map--sf {
  display: none;
}
.areaList__map--sg {
  display: none;
}
.areaList__map--sh {
  display: none;
}
.areaList__map--si {
  display: none;
}
.areaList__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 13px 12px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .areaList__list {
    gap: 11px 15px;
    width: 100%;
  }
}
.areaList__link {
  position: relative;
  z-index: 10;
  display: inline-block;
  width: 132px;
  padding: 8px 0;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
  color: #574198;
  text-align: center;
  background: #ffffff99;
  border: 1px solid #d4b2e3;
}
@media screen and (max-width: 767px) {
  .areaList__link {
    width: 100%;
  }
}
.areaList__link::after {
  position: absolute;
  top: 50%;
  right: 10px;
  display: inline-block;
  width: 8px;
  height: 14px;
  content: "";
  background-image: url("/award/images2025/top/map/arrow.svg");
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .areaList__link::after {
    right: 14px;
  }
}
.areaList__link:hover {
  color: #ffffff;
  background: linear-gradient(104.08deg, #4d4298 -24.19%, #b13ea5 125.31%);
}
.areaList__link:hover::after {
  background-image: url("/award/images2025/top/map/arrow-white.svg");
}
.areaList__link--sa:hover + .areaList__map--sa {
  display: block;
}
.areaList__link--sb:hover + .areaList__map--sb {
  display: block;
}
.areaList__link--sc:hover + .areaList__map--sc {
  display: block;
}
.areaList__link--sd:hover + .areaList__map--sd {
  display: block;
}
.areaList__link--se:hover + .areaList__map--se {
  display: block;
}
.areaList__link--sf:hover + .areaList__map--sf {
  display: block;
}
.areaList__link--sg:hover + .areaList__map--sg {
  display: block;
}
.areaList__link--sh:hover + .areaList__map--sh {
  display: block;
}
.areaList__link--si:hover + .areaList__map--si {
  display: block;
}

.mark__title {
  padding: 2px 0 3px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  color: #574198;
  border-top: 1px solid #cabcdf;
  border-bottom: 1px solid #cabcdf;
}
@media screen and (max-width: 767px) {
  .mark__title {
    text-align: center;
  }
}
.mark__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 32px;
  max-width: 512px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .mark__list {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 436px;
    margin: 16px auto 0;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .mark__list {
    margin-top: 16px;
  }
}

.style {
  display: flex;
  gap: 12px;
  /* stylelint-disable-next-line no-descending-specificity */
}
.style__item {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 264px;
}
@media screen and (max-width: 767px) {
  .style__item {
    max-width: unset;
  }
}
.style__link {
  display: inline-block;
  overflow: hidden;
}
.style__link:hover {
  background-color: #000000;
}
.style__link:hover .style__image {
  opacity: 0.6;
  transition: 0.3s all;
  transform: scale(1.1);
}
.style__image {
  width: 100%;
  height: auto;
}
.style__linkText {
  position: relative;
  padding: 8px 0;
  font-size: min(18px, 1.25vw);
  font-weight: 400;
  line-height: 1.4444444444;
  color: #ffffff;
  text-align: center;
  background: linear-gradient(104.08deg, #4d4298 -24.19%, #b13ea5 125.31%);
}
@media screen and (max-width: 767px) {
  .style__linkText {
    padding: 4px 0;
    font-size: 12px;
    line-height: 1.5;
  }
}
.style__linkText::after {
  position: absolute;
  top: 50%;
  right: 16px;
  display: inline-block;
  width: 6px;
  height: 12px;
  content: "";
  background-image: url("/award/images2025/top/style/arrow.svg");
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .style__linkText::after {
    right: 8px;
  }
}

.overview, .ceremony {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  background-color: #ffffff99;
  filter: drop-shadow(0 4px 24px #906b9d33);
  backdrop-filter: blur(20px);
  border-radius: min(160px, 11.1111111111vw) 0 0 6px;
}
@media screen and (max-width: 767px) {
  .overview, .ceremony {
    border-radius: 120px 0 0;
  }
}
.overview::after, .ceremony::after {
  position: absolute;
  top: 0;
  right: -100%;
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  background-color: #ffffff99;
}

.ceremony {
  display: flex;
  gap: min(56px, 3.8888888889vw);
  align-items: center;
  padding: 32px min(74px, 5.1388888889%);
}
@media screen and (max-width: 767px) {
  .ceremony {
    flex-direction: column;
    padding: 60px 0 0;
  }
}
@media screen and (max-width: 767px) {
  .ceremony--hasReport {
    gap: 48px;
  }
}
.ceremony__content {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .ceremony__content {
    gap: 40px;
    padding: 0 20px;
  }
}
.ceremony__text {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .ceremony__text {
    text-align: unset;
  }
}
.ceremony__text--comingSoon {
  font-size: 24px;
  text-align: center;
}
.ceremony__image {
  width: 37.6388888889vw;
  max-width: 542px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .ceremony__image {
    width: 100%;
  }
}

.overview {
  padding: 60px 0;
  border-radius: 0 min(160px, 11.1111111111vw) 6px 0;
}
@media screen and (max-width: 767px) {
  .overview {
    border-radius: 0 160px 0 0;
  }
}
.overview::after {
  right: unset;
  left: -100%;
}
.overview__content {
  max-width: 864px;
  padding: 0 48px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .overview__content {
    width: 100%;
    padding: 0 20px;
  }
}
.overview__text {
  margin-top: 40px;
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .overview__text {
    margin-top: 32px;
    font-weight: 400;
    text-align: unset;
  }
}
.overview__note {
  margin-top: 16px;
  font-size: 12px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .overview__note {
    margin-top: 8px;
    font-weight: 400;
    text-align: unset;
  }
}

.link {
  position: relative;
  display: block;
  width: 100%;
  max-width: 236px;
  padding: 10px 0;
  margin: 0 auto;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4666666667;
  color: #574198;
  text-align: center;
  background-color: #ffffff99;
  border: 1px solid #d4b2e3;
}
.link:hover {
  color: #ffffff;
  background: linear-gradient(104.08deg, #4d4298 -24.19%, #b13ea5 125.31%);
}
.link::after {
  position: absolute;
  top: 18px;
  right: 16px;
  display: inline-block;
  width: 7.0710678119px;
  height: 7.0710678119px;
  content: "";
  border-right: 1px solid currentcolor;
  border-bottom: 1px solid currentcolor;
  transform: rotate(-45deg);
}

.previous {
  padding: 60px 0;
  background-image: url("/award/images2025/mv/bg.png");
  background-repeat: repeat-x;
  background-position: top;
  background-size: 100% 100%;
}
@media screen and (max-width: 767px) {
  .previous {
    background-image: url("/award/images2025/mv/bg_sp.png");
  }
}
.previous__list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  max-width: 861px;
  padding: 0 48px;
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .previous__list {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 0 20px;
  }
}
.previous__link {
  display: block;
  padding: 15px 0 13px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.2;
  color: #574198;
  text-align: center;
  background-color: #ffffff99;
  border: 1px solid #ffffff99;
  box-shadow: 0 0 16px #906b9d9d;
}
@media screen and (max-width: 767px) {
  .previous__link {
    width: 89.3333333333vw;
    padding: 18px 0;
  }
}
.previous__link:hover {
  color: #ffffff;
  background-color: #29156799;
  border-color: currentcolor;
}

.toTop {
  position: fixed;
  right: 80px;
  bottom: 70px;
  z-index: 100;
  display: none;
  width: 60px;
  height: 60px;
  cursor: pointer;
  background-color: #c1bcdfE5;
  border: none;
  border-radius: 50%;
  box-shadow: 0 4px 16px #430a5733;
}
@media screen and (max-width: 767px) {
  .toTop {
    right: 10px;
    bottom: 16px;
  }
}
.toTop[data-toTop-show=true] {
  display: block;
}
.toTop::before {
  position: absolute;
  top: 24px;
  left: 24px;
  display: block;
  width: 12.7279220614px;
  height: 12.7279220614px;
  content: "";
  border-color: #574198;
  border-top: 2px solid;
  border-right: 2px solid;
  transform: rotate(-45deg);
}
.toTop:hover {
  background-color: #574198e5;
}
.toTop:hover::before {
  border-color: #ffffff;
}
.toTop__text {
  display: none;
}

.modal__dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 100vw;
  overflow: hidden;
  pointer-events: none;
  background: transparent;
  border: none;
  transform: translate(-50%, -50%);
  animation-duration: 300ms;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
.modal__dialog::backdrop {
  pointer-events: auto;
  background-color: rgba(0, 0, 0, 0.8);
  animation-fill-mode: forwards;
  animation-duration: 300ms;
  animation-timing-function: ease-out;
}
.modal__dialog[open], .modal__dialog[open]::backdrop {
  animation-name: fade-in;
}
.modal__dialog.--closing {
  animation-name: fade-out;
}
.modal__dialog.--closing::backdrop {
  animation-name: fade-out;
}
.modal__dialog.--hasCloseButton {
  transform: translate(-50%, calc(-50% - 24px));
}
.modal__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
.modal__inner.--disablePointerEvents {
  pointer-events: none;
}
.modal__closeButton {
  position: relative;
  width: 24px;
  height: 24px;
  pointer-events: auto;
  background: rgba(0, 0, 0, 0);
  border: none;
}
.modal__closeButton::before, .modal__closeButton::after {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  content: "";
  background: #ffffff;
  transform-origin: 50%;
}
.modal__closeButton::before {
  transform: rotate(45deg);
}
.modal__closeButton::after {
  transform: rotate(-45deg);
}
.modal__closeButton:hover {
  cursor: pointer;
}
.modal__closeButton:hover::before, .modal__closeButton:hover::after {
  opacity: 0.7;
}

.scrollLock {
  overflow: hidden;
}

@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fade-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.carousel {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
  pointer-events: none;
}
.carousel__main {
  position: relative;
  display: flex;
  gap: 16px;
  align-items: center;
  height: 100%;
}
.carousel__slideDisplay {
  flex-grow: 0;
  flex-shrink: 1;
  max-width: 600px;
  aspect-ratio: 600/400;
  overflow: hidden;
  pointer-events: auto;
}
.carousel__slide {
  position: relative;
  display: none;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  user-select: none;
  object-fit: cover;
}
.carousel__slide.--active {
  display: block;
}
.carousel__button {
  flex-shrink: 0;
  width: 48px;
  height: 100%;
  appearance: none;
  pointer-events: auto;
  cursor: pointer;
  background: transparent;
  border: none;
}
.carousel__button::before {
  position: relative;
  left: 40%;
  display: block;
  width: 12px;
  height: 12px;
  content: "";
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  transform: rotate(-45deg);
}
.carousel__button:hover::before {
  border-top: 2px solid #ad6103;
  border-left: 2px solid #ad6103;
}
.carousel__button:disabled {
  pointer-events: none;
}
.carousel__button:disabled::before {
  opacity: 0;
}
.carousel__button--next::before {
  transform: rotate(135deg);
}

.contest {
  /* stylelint-disable-next-line scss/at-extend-no-missing-placeholder */
}
.contest__content {
  padding: 58px 48px 60px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .contest__content {
    padding: 48px 20px 80px;
  }
}

.ceremonyPage__awardTop, .salonLinkArea__awardTop, .collectionList__topLink, .contestLinkArea__awardTop, .introduction__link {
  position: relative;
  display: block;
  width: 312px;
  padding: 12px 0;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4666666667;
  color: #290680;
  text-align: center;
  background-color: #ffffff99;
  border: 1px solid #ffffff99;
  box-shadow: 0 0 16px #b58ec333;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__awardTop, .salonLinkArea__awardTop, .collectionList__topLink, .contestLinkArea__awardTop, .introduction__link {
    width: 280px;
    font-size: min(15px, 4vw);
  }
}
.ceremonyPage__awardTop:hover, .salonLinkArea__awardTop:hover, .collectionList__topLink:hover, .contestLinkArea__awardTop:hover, .introduction__link:hover {
  color: #ffffff;
  background: linear-gradient(345deg, #8251c6 -29.23%, #f1bcdb 97.84%);
}
.ceremonyPage__awardTop:hover::after, .salonLinkArea__awardTop:hover::after, .collectionList__topLink:hover::after, .contestLinkArea__awardTop:hover::after, .introduction__link:hover::after {
  background-image: url("/award/images2025/introduction/arrow-white.svg");
}
.ceremonyPage__awardTop::after, .salonLinkArea__awardTop::after, .collectionList__topLink::after, .contestLinkArea__awardTop::after, .introduction__link::after {
  position: absolute;
  top: 50%;
  right: 16px;
  display: inline-block;
  width: 8px;
  height: 16px;
  content: "";
  background-image: url("/award/images2025/introduction/arrow.svg");
  transform: translateY(-50%);
}

.introduction {
  max-width: 766px;
  margin: 0 auto;
}
.introduction__titleArea {
  width: fit-content;
  margin: 0 auto;
}
.introduction__title {
  position: relative;
  display: block;
  width: 100%;
  padding: 4px 0;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.4375;
  color: #574198;
  text-align: center;
  background-color: #ffffff66;
  border-radius: 14px 2px;
}
@media screen and (max-width: 767px) {
  .introduction__title {
    width: fit-content;
    min-width: 155px;
    padding: 5px 16px 4px;
    font-size: 12px;
    text-align: center;
  }
}
.introduction__title::after {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  content: "";
  background-image: linear-gradient(293.22deg, #8251c6 -4.79%, #f1bcdb 92.82%);
  background-clip: border-box;
  background-origin: border-box;
  border: 1px solid transparent;
  border-radius: 14px 2px;
  mask-image: linear-gradient(#ffffff 0 0), linear-gradient(#ffffff 0 0);
  mask-clip: padding-box, border-box;
  mask-composite: exclude;
}
.introduction__sectionTitle {
  margin-top: 22px;
}
@media screen and (max-width: 767px) {
  .introduction__sectionTitle {
    margin-top: 16px;
  }
}
.introduction__text, .introduction__annotation {
  font-size: 14px;
  line-height: 2;
  color: #001a57;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .introduction__text, .introduction__annotation {
    text-align: unset;
  }
}
.introduction__text {
  margin-top: 32px;
}
.introduction__annotation {
  margin-top: 16px;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .introduction__annotation {
    margin-top: 16px;
    line-height: 1.6666666667;
  }
}
.introduction__link {
  width: 360px;
  margin: 28px auto 0;
}
@media screen and (max-width: 767px) {
  .introduction__link {
    width: unset;
    max-width: 360px;
    padding: 8px 0;
    margin-top: 33px;
  }
}

.ranking {
  padding: 60px 0 161px;
  margin: 0 auto;
  /* stylelint-disable-next-line no-descending-specificity */
}
@media screen and (max-width: 767px) {
  .ranking {
    padding: 70px 0 80px;
  }
}
.ranking__item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin: 0 auto;
  background-color: #ffffff66;
  border: 2px solid transparent;
  border-image-source: linear-gradient(306.39deg, #8251c6 14.07%, #f1bcdb 58.51%);
  border-image-slice: 1;
}
@media screen and (max-width: 767px) {
  .ranking__item {
    grid-template-columns: 1fr;
    width: 100%;
  }
}
.ranking__item--first {
  width: 61.25vw;
  max-width: 882px;
}
.ranking__item--first .ranking__textArea {
  padding: 56px;
}
@media screen and (max-width: 767px) {
  .ranking__item--first {
    width: 100%;
  }
  .ranking__item--first .ranking__textArea {
    padding: 32px 0;
  }
}
.ranking__item:nth-child(2) {
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .ranking__item:nth-child(2) {
    margin-top: 0;
  }
}
.ranking__runnerUp {
  display: flex;
  gap: 52px;
  align-items: flex-start;
  max-width: 1188px;
  margin: 58px auto 0;
}
@media screen and (max-width: 767px) {
  .ranking__runnerUp {
    flex-direction: column;
    gap: 40px;
    padding: 0 19px;
    margin-top: 39px;
  }
}
.ranking__number {
  width: 9.1666666667vw;
  max-width: 132px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .ranking__number {
    width: 22.4vw;
  }
}
.ranking__textArea {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
@media screen and (max-width: 767px) {
  .ranking__textArea {
    padding: 24px 0;
  }
}
.ranking__salonName {
  margin-top: 32px;
  font-size: clamp(16px, 1.6666666667vw, 24px);
  font-weight: 500;
  line-height: 1.3333333333;
  color: #574198;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .ranking__salonName {
    margin-top: 20px;
    font-size: 24px;
    line-height: 1.4583333333;
  }
}
.ranking__salonName--first {
  font-size: 30px;
  line-height: 1.4666666667;
}
@media screen and (max-width: 767px) {
  .ranking__salonName--first {
    font-size: 24px;
    line-height: 1.4583333333;
  }
}
.ranking__stylistName {
  margin-top: 8px;
  font-size: 16px;
  line-height: 1.4375;
  color: #574198;
}
.ranking__image, .otherRank__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.3s all;
}
@media screen and (max-width: 767px) {
  .ranking__image, .otherRank__image {
    width: 100%;
  }
}
.ranking__image:hover, .otherRank__image:hover {
  opacity: 0.6;
  transform: scale(1.05);
}
.ranking__link, .otherRank__link {
  display: block;
  overflow: hidden;
}
.ranking__link:hover, .otherRank__link:hover {
  background-color: #000000;
}
.ranking__otherRank {
  max-width: 1182px;
  margin: 100px auto 0;
}
@media screen and (max-width: 767px) {
  .ranking__otherRank {
    margin-top: 63px;
  }
}

.otherRank {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
  gap: 32px min(24px, 1.6666666667vw);
}
@media screen and (max-width: 767px) {
  .otherRank {
    grid-template-columns: 1fr 1fr;
    gap: 24px 22px;
  }
}
.otherRank__item {
  position: relative;
  width: 12.2916666667vw;
  max-width: 177px;
  padding-top: 33px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .otherRank__item {
    width: 100%;
    max-width: unset;
    padding-top: 30px;
  }
}
.otherRank__num {
  position: absolute;
  top: 0;
  left: 10px;
  z-index: 10;
}
.otherRank__info {
  margin-top: 14px;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  font-weight: 500;
  color: #574198;
}
@media screen and (max-width: 767px) {
  .otherRank__info {
    font-size: 14px;
  }
}
.otherRank__salonName {
  line-height: 1.2857142857;
}
.otherRank__stylistName {
  margin-top: 8px;
  line-height: 1.2857142857;
}
@media screen and (max-width: 767px) {
  .otherRank__stylistName {
    margin-top: 6px;
  }
}
.otherRank__link {
  /* stylelint-disable-next-line scss/at-extend-no-missing-placeholder  */
}
.otherRank__image {
  /* stylelint-disable-next-line scss/at-extend-no-missing-placeholder  */
}

.contestLinkArea {
  width: fit-content;
  margin: 0 auto;
}
.contestLinkArea__hair {
  display: block;
}
.contestLinkArea__hairBanner {
  width: 752px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .contestLinkArea__hairBanner {
    width: 100%;
  }
}
.contestLinkArea__awardTop {
  margin: 60px auto 0;
}
@media screen and (max-width: 767px) {
  .contestLinkArea__awardTop {
    width: 100%;
    margin-top: 40px;
  }
}

.styleCollection {
  /* stylelint-disable-next-line scss/at-extend-no-missing-placeholder */
}
.styleCollection__content {
  padding: 60px 48px 64px;
}
@media screen and (max-width: 767px) {
  .styleCollection__content {
    padding: 48px 20px 80px;
  }
}

.collectionList {
  max-width: 1184px;
  margin: 0 auto;
  container-type: inline-size;
  container-name: collectionlist;
  resize: horizontal;
}
.collectionList__nav {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  max-width: 960px;
  height: 50px;
  margin: 49px auto 0;
  border-bottom: 4px solid #c1bcdfe5;
}
@media screen and (max-width: 767px) {
  .collectionList__nav {
    gap: 0;
    width: 100vw;
    margin-top: 46px;
    margin-left: -20px;
  }
}
.collectionList__navButton {
  position: relative;
  width: 100%;
  height: 100%;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.4444444444;
  color: #574198;
  text-align: center;
  cursor: pointer;
  background-color: transparent;
  border: none;
}
.collectionList__navButton::after {
  position: absolute;
  bottom: -15px;
  display: block;
  width: 100%;
  height: 15px;
  content: "";
  background-image: url("/award/images2025/styleCollection/nav-arrow.png");
  background-repeat: no-repeat;
  background-position: center 0;
  background-size: contain;
  opacity: 0;
  transition: all 0.3s;
}
@media screen and (max-width: 767px) {
  .collectionList__navButton::after {
    background-size: auto 15px;
  }
}
.collectionList__navButton:hover::after {
  opacity: 1;
}
.collectionList__navButton[data-tab-collection-active]::after {
  opacity: 1;
}
.collectionList__list {
  display: none;
  flex-wrap: wrap;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  margin-top: 36px;
}
.collectionList__list--mens {
  display: grid;
}
@container collectionList (max-width: 903px) {
  .collectionList__list {
    grid-template-columns: repeat(6, 1fr);
  }
}
@container collectionList (max-width: 738px) {
  .collectionList__list {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .collectionList__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 32px;
  }
}
.collectionList__list[data-tab-collection-active] {
  display: grid;
}
.collectionList__link {
  display: block;
  overflow: hidden;
  visibility: hidden;
  opacity: 0;
  animation-name: fade-in;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}
.collectionList__link--1 {
  animation-delay: 0.01s;
}
.collectionList__link--2 {
  animation-delay: 0.02s;
}
.collectionList__link--3 {
  animation-delay: 0.03s;
}
.collectionList__link--4 {
  animation-delay: 0.04s;
}
.collectionList__link--5 {
  animation-delay: 0.05s;
}
.collectionList__link--6 {
  animation-delay: 0.06s;
}
.collectionList__link--7 {
  animation-delay: 0.07s;
}
.collectionList__link--8 {
  animation-delay: 0.08s;
}
.collectionList__link--9 {
  animation-delay: 0.09s;
}
.collectionList__link--10 {
  animation-delay: 0.1s;
}
.collectionList__link--11 {
  animation-delay: 0.11s;
}
.collectionList__link--12 {
  animation-delay: 0.12s;
}
.collectionList__link--13 {
  animation-delay: 0.13s;
}
.collectionList__link--14 {
  animation-delay: 0.14s;
}
.collectionList__link--15 {
  animation-delay: 0.15s;
}
.collectionList__link--16 {
  animation-delay: 0.16s;
}
.collectionList__link--17 {
  animation-delay: 0.17s;
}
.collectionList__link--18 {
  animation-delay: 0.18s;
}
.collectionList__link--19 {
  animation-delay: 0.19s;
}
.collectionList__link--20 {
  animation-delay: 0.2s;
}
.collectionList__link--21 {
  animation-delay: 0.21s;
}
.collectionList__link--22 {
  animation-delay: 0.22s;
}
.collectionList__link--23 {
  animation-delay: 0.23s;
}
.collectionList__link--24 {
  animation-delay: 0.24s;
}
.collectionList__link--25 {
  animation-delay: 0.25s;
}
.collectionList__link--26 {
  animation-delay: 0.26s;
}
.collectionList__link--27 {
  animation-delay: 0.27s;
}
.collectionList__link--28 {
  animation-delay: 0.28s;
}
.collectionList__link--29 {
  animation-delay: 0.29s;
}
.collectionList__link--30 {
  animation-delay: 0.3s;
}
.collectionList__link--31 {
  animation-delay: 0.31s;
}
.collectionList__link--32 {
  animation-delay: 0.32s;
}
.collectionList__link--33 {
  animation-delay: 0.33s;
}
.collectionList__link--34 {
  animation-delay: 0.34s;
}
.collectionList__link--35 {
  animation-delay: 0.35s;
}
.collectionList__link--36 {
  animation-delay: 0.36s;
}
.collectionList__link--37 {
  animation-delay: 0.37s;
}
.collectionList__link--38 {
  animation-delay: 0.38s;
}
.collectionList__link--39 {
  animation-delay: 0.39s;
}
.collectionList__link--40 {
  animation-delay: 0.4s;
}
.collectionList__link--41 {
  animation-delay: 0.41s;
}
.collectionList__link--42 {
  animation-delay: 0.42s;
}
.collectionList__link--43 {
  animation-delay: 0.43s;
}
.collectionList__link--44 {
  animation-delay: 0.44s;
}
.collectionList__link--45 {
  animation-delay: 0.45s;
}
.collectionList__link--46 {
  animation-delay: 0.46s;
}
.collectionList__link--47 {
  animation-delay: 0.47s;
}
.collectionList__link--48 {
  animation-delay: 0.48s;
}
.collectionList__link--49 {
  animation-delay: 0.49s;
}
.collectionList__link--50 {
  animation-delay: 0.5s;
}
.collectionList__link--51 {
  animation-delay: 0.51s;
}
.collectionList__link--52 {
  animation-delay: 0.52s;
}
.collectionList__link--53 {
  animation-delay: 0.53s;
}
.collectionList__link--54 {
  animation-delay: 0.54s;
}
.collectionList__link--55 {
  animation-delay: 0.55s;
}
.collectionList__link--56 {
  animation-delay: 0.56s;
}
.collectionList__link--57 {
  animation-delay: 0.57s;
}
.collectionList__link--58 {
  animation-delay: 0.58s;
}
.collectionList__link--59 {
  animation-delay: 0.59s;
}
.collectionList__link--60 {
  animation-delay: 0.6s;
}
.collectionList__link--61 {
  animation-delay: 0.61s;
}
.collectionList__link--62 {
  animation-delay: 0.62s;
}
.collectionList__link--63 {
  animation-delay: 0.63s;
}
.collectionList__link--64 {
  animation-delay: 0.64s;
}
.collectionList__link--65 {
  animation-delay: 0.65s;
}
.collectionList__link--66 {
  animation-delay: 0.66s;
}
.collectionList__link--67 {
  animation-delay: 0.67s;
}
.collectionList__link--68 {
  animation-delay: 0.68s;
}
.collectionList__link--69 {
  animation-delay: 0.69s;
}
.collectionList__link--70 {
  animation-delay: 0.7s;
}
.collectionList__link--71 {
  animation-delay: 0.71s;
}
.collectionList__link--72 {
  animation-delay: 0.72s;
}
.collectionList__link--73 {
  animation-delay: 0.73s;
}
.collectionList__link--74 {
  animation-delay: 0.74s;
}
.collectionList__link--75 {
  animation-delay: 0.75s;
}
.collectionList__link--76 {
  animation-delay: 0.76s;
}
.collectionList__link--77 {
  animation-delay: 0.77s;
}
.collectionList__link--78 {
  animation-delay: 0.78s;
}
.collectionList__link--79 {
  animation-delay: 0.79s;
}
.collectionList__link--80 {
  animation-delay: 0.8s;
}
.collectionList__link--81 {
  animation-delay: 0.81s;
}
.collectionList__link--82 {
  animation-delay: 0.82s;
}
.collectionList__link--83 {
  animation-delay: 0.83s;
}
.collectionList__link--84 {
  animation-delay: 0.84s;
}
.collectionList__link--85 {
  animation-delay: 0.85s;
}
.collectionList__link--86 {
  animation-delay: 0.86s;
}
.collectionList__link--87 {
  animation-delay: 0.87s;
}
.collectionList__link--88 {
  animation-delay: 0.88s;
}
.collectionList__link--89 {
  animation-delay: 0.89s;
}
.collectionList__link--90 {
  animation-delay: 0.9s;
}
.collectionList__link--91 {
  animation-delay: 0.91s;
}
.collectionList__link--92 {
  animation-delay: 0.92s;
}
.collectionList__link--93 {
  animation-delay: 0.93s;
}
.collectionList__link--94 {
  animation-delay: 0.94s;
}
.collectionList__link--95 {
  animation-delay: 0.95s;
}
.collectionList__link--96 {
  animation-delay: 0.96s;
}
.collectionList__link--97 {
  animation-delay: 0.97s;
}
.collectionList__link--98 {
  animation-delay: 0.98s;
}
.collectionList__link--99 {
  animation-delay: 0.99s;
}
.collectionList__link--100 {
  animation-delay: 1s;
}
.collectionList__link:hover {
  background-color: #000000;
}
.collectionList__image {
  width: 100%;
  height: auto;
  transition: 0.3s ease-in-out;
}
.collectionList__image[class]:hover {
  opacity: 0.6;
  transform: scale(1.05);
}
.collectionList__bannerArea {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .collectionList__bannerArea {
    margin-top: 80px;
  }
}
.collectionList__banner {
  display: block;
  width: 100%;
  max-width: 752px;
  margin: 0 auto;
  text-align: center;
}
.collectionList__bannerImage {
  margin: 0 auto;
}
.collectionList__topLink {
  margin: 64px auto 0;
}
@media screen and (max-width: 767px) {
  .collectionList__topLink {
    width: 100%;
    margin-top: 40px;
  }
}

@keyframes fade-in {
  0% {
    visibility: hidden;
    opacity: 0;
  }
  1% {
    visibility: visible;
    opacity: 0;
  }
  100% {
    visibility: visible;
    opacity: unset;
  }
}
.salon {
  /* stylelint-disable-next-line scss/at-extend-no-missing-placeholder */
}
.salon__content {
  padding: 60px 48px 64px;
}
@media screen and (max-width: 767px) {
  .salon__content {
    padding: 48px 20px 80px;
  }
}
.salon__bestSalon {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .salon__bestSalon {
    margin-top: 70px;
  }
}

.salonLinkArea {
  width: fit-content;
  padding-top: 160px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .salonLinkArea {
    padding-top: 100px;
  }
}
.salonLinkArea__caution {
  font-size: 14px;
  line-height: 1.4285714286;
  color: #001a57;
}
.salonLinkArea__awardTop {
  width: 292px;
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .salonLinkArea__awardTop {
    width: 100%;
    margin-top: 40px;
  }
}

.bestSalon__prize:not(:first-of-type) {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .bestSalon__prize:not(:first-of-type) {
    margin-top: 100px;
  }
}

.prize {
  max-width: 1184px;
  margin-inline: auto;
}
.prize__list {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .prize__list {
    margin-top: 40px;
  }
}

.prizeArea {
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .prizeArea {
    padding-top: 30px;
  }
}
.prizeArea:not(:first-of-type) {
  margin-top: 20px;
}
.prizeArea__list {
  margin-top: 40px;
}

.prizeHead {
  position: relative;
  padding: 13px 0 12px;
  text-align: center;
  background-color: rgba(255, 249, 234, 0.6);
}
.prizeHead__item {
  font-size: 36px;
  line-height: 1.1666666667;
  color: transparent;
  background: linear-gradient(180deg, #605103 27.23%, #c6a806 80.36%);
  background-clip: text;
}
@media screen and (max-width: 767px) {
  .prizeHead__item {
    font-size: 26px;
    line-height: 1.1538461538;
  }
}
.prizeHead::before {
  position: absolute;
  top: 2px;
  left: 0;
  display: block;
  width: 100%;
  height: 4px;
  content: "";
  background: linear-gradient(-90deg, #e6dfd3 14.07%, #ceae66 58.51%);
}
@media screen and (max-width: 767px) {
  .prizeHead::before {
    height: 2px;
  }
}
.prizeHead::after {
  position: absolute;
  bottom: 2px;
  left: 0;
  display: block;
  width: 100%;
  height: 4px;
  content: "";
  background: linear-gradient(90deg, #e6dfd3 14.07%, #ceae66 58.51%);
}
@media screen and (max-width: 767px) {
  .prizeHead::after {
    height: 2px;
  }
}
.prizeHead--silver {
  background-color: rgba(241, 250, 255, 0.6);
}
.prizeHead--silver::before {
  background: linear-gradient(-90deg, #b9cacd 14.07%, #8c9fbf 58.51%);
}
.prizeHead--silver::after {
  background: linear-gradient(90deg, #b9cacd 14.07%, #8c9fbf 58.51%);
}
.prizeHead--silver .prizeHead__item {
  background: linear-gradient(180deg, #6789a7 27.23%, #53606c 80.36%);
  background-clip: text;
}

.areaHead {
  padding: 6px 0 8px;
  text-align: center;
  background-color: #ffffff;
}
.areaHead__item {
  font-size: 18px;
  line-height: 1.4444444444;
  color: transparent;
  letter-spacing: 0.06em;
  background: linear-gradient(180deg, #4d4298 27.23%, #b13ea5 80.36%);
  background-clip: text;
}

.salonList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px 24px;
}
@media screen and (max-width: 767px) {
  .salonList {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
.salonList__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  row-gap: 12px;
  align-items: end;
}
.salonList__header {
  display: flex;
  gap: 28px;
  align-items: flex-end;
  padding-bottom: 5px;
  font-weight: 500;
  color: #574198;
  border-bottom: 3px solid transparent;
  border-image-source: linear-gradient(306.39deg, #f1bcdb 14.07%, #9969b7 58.51%);
  border-image-slice: 1;
}
@media screen and (max-width: 767px) {
  .salonList__header {
    padding-bottom: 3px;
  }
}
.salonList__name {
  flex-shrink: 1;
  font-size: 18px;
  line-height: 1.4444444444;
  white-space: pre-wrap;
}
.salonList__area {
  flex-shrink: 0;
  font-size: 14px;
  line-height: 1.4285714286;
}
.salonList__area::before {
  margin-right: 1em;
  content: "/";
}
.salonList__thumb {
  display: block;
  overflow: hidden;
  background-color: #000000;
}
@media screen and (max-width: 767px) {
  .salonList__thumb {
    margin-top: 10px;
  }
}
.salonList__thumbItem {
  width: 100%;
  height: auto;
  transition: 0.3s all;
}
.salonList__thumbItem:hover {
  opacity: 0.6;
  transform: scale(1.05);
}
@media screen and (max-width: 767px) {
  .salonList__thumbItem:hover {
    opacity: 1;
    transform: unset;
  }
}
.salonList--silver {
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 40px 24px;
}
@media screen and (max-width: 767px) {
  .salonList--silver {
    grid-template-columns: 1fr 1fr;
    gap: 40px 23px;
  }
}
.salonList--silver .salonList__name {
  font-size: 14px;
  line-height: 1.4285714286;
}

.ceremonyPage {
  padding-bottom: 80px;
  color: #001a57;
  background: linear-gradient(79.9deg, #fffbf5 14.07%, #fff2fd 70.57%);
}
.ceremonyPage__top {
  display: flex;
  flex-direction: column;
  gap: 40px;
  align-items: center;
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__top {
    margin-top: 48px;
  }
}
.ceremonyPage__title {
  max-width: 1224px;
  padding-inline: 20px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__title {
    gap: 40px;
  }
}
.ceremonyPage__titleDesc {
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__titleDesc {
    text-align: start;
  }
}
.ceremonyPage__movie {
  position: relative;
  width: 100%;
  max-width: 1184px;
  margin-inline: auto;
  overflow: hidden;
  cursor: pointer;
  background: transparent;
  border: none;
}
.ceremonyPage__movie::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 80px;
  height: 80px;
  pointer-events: none;
  content: "";
  background-image: url("/award/images2025/ceremony/play.svg");
  background-size: contain;
  translate: -50% -50%;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__movie::after {
    width: 60px;
    height: 60px;
  }
}
.ceremonyPage__movieThumbnail {
  width: 100%;
  height: 400px;
  object-fit: cover;
  transition-duration: 0.3s;
  transition-property: transform, opacity;
}
.ceremonyPage__movieThumbnail:hover {
  opacity: 0.8;
  transform: scale(1.1);
}
@media screen and (max-width: 767px) {
  .ceremonyPage__movieThumbnail {
    height: 200px;
  }
}
.ceremonyPage__movieModalWrapper {
  width: 100%;
  max-width: 748px;
  aspect-ratio: 1280/720;
  background: transparent;
  border: none;
}
.ceremonyPage__movieModalContent {
  width: 100%;
  height: 100%;
  pointer-events: auto;
  border: none;
}
.ceremonyPage__intro {
  max-width: 1224px;
  padding-inline: 20px;
  margin-inline: auto;
}
.ceremonyPage__introTitle {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.1666666667;
  text-align: center;
  word-break: keep-all;
  overflow-wrap: break-word;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__introTitle {
    font-size: 20px;
    line-height: 1.4;
  }
}
.ceremonyPage__introTitle::after {
  position: relative;
  display: block;
  width: 40px;
  height: 2px;
  margin-inline: auto;
  margin-top: 22px;
  content: "";
  background-color: #001a57;
}
.ceremonyPage__introDesc {
  margin-top: 24px;
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__introDesc {
    text-align: start;
  }
}
.ceremonyPage__reports {
  display: flex;
  flex-direction: column;
  gap: 80px;
  max-width: 1224px;
  padding-inline: 20px;
  margin-inline: auto;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__reports {
    margin-top: 100px;
  }
}
.ceremonyPage__reportsItem {
  display: grid;
  grid-template-areas: "title images" "desc images";
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: auto;
  gap: 24px 64px;
}
@media screen and (min-width: 768px) {
  .ceremonyPage__reportsItem:nth-child(even) {
    grid-template-areas: "images title" "images desc";
  }
}
@media screen and (max-width: 767px) {
  .ceremonyPage__reportsItem {
    grid-template-areas: "title" "images" "desc";
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.ceremonyPage__reportsTitle {
  grid-area: title;
  font-size: 24px;
  font-style: normal;
  font-weight: 500;
  line-height: 1.7083333333;
  color: #001a57;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__reportsTitle {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.4444444444;
  }
}
.ceremonyPage__reportsImages {
  grid-area: images;
}
.ceremonyPage__reportsImage {
  width: 100%;
  height: auto;
  aspect-ratio: 1120/704;
}
.ceremonyPage__reportsDesc {
  display: flex;
  flex-direction: column;
  grid-area: desc;
  gap: 24px;
}
.ceremonyPage__reportsDescText {
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 2;
  color: #001a57;
}
.ceremonyPage__voice {
  margin-top: 144px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voice {
    margin-top: 100px;
  }
}
.ceremonyPage__voiceGroups {
  display: flex;
  flex-direction: column;
  gap: 64px;
  margin-top: 36px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceGroups {
    gap: 56px;
    margin-top: 40px;
  }
}
.ceremonyPage__voiceTitle {
  width: 100%;
  padding-block: 6px 10px;
  font-size: 24px;
  font-weight: 500;
  color: #574198;
  text-align: center;
  letter-spacing: 0.02em;
  background: #f4daf7;
}
@media screen and (min-width: 768px) {
  .ceremonyPage__voiceTitle {
    max-width: 1184px;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceTitle {
    padding-block: 4px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.ceremonyPage__voiceList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: max-content;
  gap: 38px 40px;
  max-width: 1224px;
  padding-inline: 20px;
  margin-inline: auto;
  margin-top: 36px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceList {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 22px;
  }
}
.ceremonyPage__voiceCard {
  position: relative;
}
.ceremonyPage__voiceCard::before {
  position: relative;
  display: block;
  width: 100%;
  height: 4px;
  content: "";
  background: linear-gradient(90deg, #f1bcdb 0%, #8251c6 100%);
  opacity: 0.6;
}
.ceremonyPage__voiceCardInner {
  display: grid;
  grid-template: "image info" minmax(160px, auto) "desc desc" 1fr/160px 1fr;
  gap: 24px;
  height: calc(100% - 14px);
  padding: 32px;
  margin-top: 10px;
  background: #ffffff;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceCardInner {
    grid-template: "image info" minmax(120px, auto) "desc desc" 1fr/120px 1fr;
    gap: 16px;
    height: calc(100% - 16px);
    padding: 16px;
    margin-top: 12px;
  }
}
.ceremonyPage__voiceCardImage {
  grid-area: image;
}
.ceremonyPage__voiceCardInfo {
  grid-area: info;
}
.ceremonyPage__voiceCardCategory {
  width: fit-content;
  padding: 4px 16px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4285714286;
  color: #ffffff;
  background: #74409d;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceCardCategory {
    font-size: 12px;
    line-height: 1.4166666667;
  }
}
.ceremonyPage__voiceCardShop {
  margin-top: 12px;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4583333333;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceCardShop {
    margin-top: 11px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.ceremonyPage__voiceCardName {
  margin-top: 7px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4375;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__voiceCardName {
    margin-top: 8px;
    line-height: 1.4375;
  }
}
.ceremonyPage__voiceCardDesc {
  grid-area: desc;
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  color: #001a57;
}
.ceremonyPage__gallery {
  position: relative;
  margin-top: 144px;
  max-width: 1224px;
  padding-inline: 20px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__gallery {
    margin-top: 100px;
  }
}
.ceremonyPage__galleryList {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: auto;
  gap: 16px;
  width: 100%;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__galleryList {
    grid-template-columns: repeat(4, 1fr);
  }
}
.ceremonyPage__galleryListItem {
  position: relative;
  width: 100%;
}
.ceremonyPage__galleryBtn {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  appearance: none;
  background: none;
  border: none;
}
.ceremonyPage__galleryBtn:hover {
  cursor: pointer;
}
.ceremonyPage__galleryImage {
  width: 100%;
  aspect-ratio: 1/1;
  background-color: #ffffff;
  transition: opacity 0.3s, transform 0.3s;
}
.ceremonyPage__galleryImage:hover {
  opacity: 0.8;
  transform: scale(1.1);
}
.ceremonyPage__awardTop {
  margin-inline: auto;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .ceremonyPage__awardTop {
    width: calc(100% - 40px);
  }
}
.ceremonyPage__galleryModalWrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  margin-inline: auto;
}