/*
Theme Name: Ioki Io Official
Theme URI: https://example.com/ioki-io-official
Author: ChatGPT
Description: 五百木いお公式サイト用のスマホファーストWordPressテーマ。出演スケジュールを管理画面から編集できる、パステル紫×白の公式サイトデザイン。
Version: 6.70.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ioki-io-official
*/

:root {
  --io-purple: #9b5ce8;
  --io-purple-2: #b47bf1;
  --io-purple-dark: #50257e;
  --io-purple-soft: #e8d8ff;
  --io-pink: #f4a9df;
  --io-blue: #77a8f8;
  --io-green: #61c896;
  --io-orange: #ffa94d;
  --io-white: #ffffff;
  --io-bg: #fffaff;
  --io-text: #4d2874;
  --io-muted: #82639f;
  --io-line: #eadcf9;
  --io-serif: "Noto Serif JP", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  --io-sans: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "YuGothic", system-ui, sans-serif;
  --io-script: "Parisienne", "Brush Script MT", cursive;
  --io-shadow: 0 18px 50px rgba(115, 56, 181, .16);
  --io-max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--io-text);
  background: radial-gradient(circle at 14% 8%, rgba(232,216,255,.82), transparent 22rem), radial-gradient(circle at 88% 36%, rgba(255,255,255,.95), transparent 26rem), var(--io-bg);
  font-family: var(--io-sans);
  font-weight: 700;
  line-height: 1.72;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button, input, textarea { font: inherit; }
.io-container { width: min(var(--io-max), calc(100% - 44px)); margin-inline: auto; }

.io-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding-top: 0;
}
.admin-bar .io-header { top: 32px; }
.io-header-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  min-height: 82px;
}
.io-brand {
  display: flex;
  align-items: center;
  padding-top: 34px;
  min-width: 230px;
  text-shadow: 0 2px 18px rgba(255,255,255,.75);
}
.io-logo-name,
.io-hero-logo-name,
.io-footer-name {
  display: block;
  font-family: var(--io-serif);
  font-weight: 700;
  letter-spacing: .06em;
  line-height: 1;
  color: #8c4bd6;
}
.io-logo-name { font-size: 34px; }
.io-logo-script,
.io-hero-logo-script,
.io-profile-script {
  display: block;
  font-family: var(--io-script);
  font-weight: 400;
  color: rgba(143,86,213,.62);
  transform: rotate(-4deg);
}
.io-logo-script { margin-top: -2px; font-size: 26px; }
.io-logo-label,
.io-hero-logo-label {
  display: block;
  color: #a46fe4;
  font-size: 11px;
  letter-spacing: .18em;
  font-weight: 900;
}
.io-site-logo img { width: auto; max-height: 70px; }

.io-mobile-menu-button {
  display: none;
  align-items: center;
  gap: 9px;
  min-height: 48px;
  padding: 0 15px;
  border: 1px solid rgba(232,216,255,.95);
  border-radius: 999px;
  color: #733bb2;
  background: rgba(255,255,255,.9);
  box-shadow: 0 14px 36px rgba(109,62,167,.14);
  cursor: pointer;
  backdrop-filter: blur(18px);
  -webkit-tap-highlight-color: transparent;
}
.io-mobile-menu-icon {
  display: grid;
  gap: 4px;
  width: 19px;
}
.io-mobile-menu-icon i {
  display: block;
  width: 19px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform .22s ease, opacity .22s ease;
}
.io-mobile-menu-text {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
}
.io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(2) { opacity: 0; }
.io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.io-nav {
  display: flex;
  align-items: stretch;
  overflow: hidden;
  border-radius: 0 0 18px 18px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(232,216,255,.88);
  border-top: 0;
  box-shadow: 0 18px 45px rgba(109,62,167,.14);
  backdrop-filter: blur(18px);
}
.io-menu { display: flex; list-style: none; margin: 0; padding: 0; }
.io-nav a,
.io-menu a {
  display: grid;
  place-items: center;
  min-width: 94px;
  min-height: 82px;
  padding: 12px 14px 10px;
  color: #6e39a8;
  border-left: 1px solid rgba(232,216,255,.8);
  line-height: 1.1;
  transition: background .22s ease, color .22s ease;
}
.io-nav a:first-child { border-left: 0; }
.io-nav a span { font-size: 18px; color: #c392fb; }
.io-nav a strong { display: block; margin-top: 4px; font-size: 12px; letter-spacing: .08em; font-weight: 900; }
.io-nav a small { display: block; margin-top: 3px; font-size: 8px; font-weight: 900; color: #9d75ca; }
.io-nav a:hover { background: #f7efff; color: #8d46d8; }

.io-hero {
  position: relative;
  min-height: 760px;
  padding: 118px 0 120px;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(135deg, #fff, #f5e9ff 48%, #fff);
}
.io-hero-slider {
  position: absolute;
  inset: 0;
  z-index: -3;
  overflow: hidden;
  background: linear-gradient(135deg, #fff, #f5e9ff 48%, #fff);
}
.io-hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.05s ease;
}
.io-hero-slide.is-active { opacity: 1; }
.io-hero-bg,
.io-hero-media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 26%;
  filter: saturate(1.04) contrast(1.03) brightness(1.04);
}
video.io-hero-media { background: #efe1ff; }
.io-hero:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: linear-gradient(90deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.74) 26%, rgba(255,255,255,.16) 48%, rgba(139,80,209,.24) 68%, rgba(255,255,255,.58) 100%), radial-gradient(circle at 18% 40%, rgba(255,255,255,.95), transparent 15rem), radial-gradient(circle at 80% 12%, rgba(233,212,255,.58), transparent 20rem);
}
.io-hero:after {
  content: "";
  position: absolute;
  left: -5vw;
  right: -5vw;
  bottom: -72px;
  height: 160px;
  z-index: 0;
  background: #fff;
  border-radius: 50% 50% 0 0 / 70% 70% 0 0;
}
.io-hero-haze {
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image: radial-gradient(circle at 7% 18%, rgba(255,255,255,.9) 0 2px, transparent 4px), radial-gradient(circle at 22% 62%, rgba(255,255,255,.78) 0 2px, transparent 5px), radial-gradient(circle at 55% 30%, rgba(255,255,255,.68) 0 2px, transparent 5px), radial-gradient(circle at 90% 58%, rgba(255,255,255,.86) 0 2px, transparent 5px);
}
.io-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(330px, 370px);
  align-items: center;
  gap: 44px;
}
.io-hero-copy { max-width: 560px; padding-top: 12px; }
.io-hero-logo-block { margin-bottom: 42px; }
.io-hero-logo-name { font-size: clamp(44px, 6vw, 72px); }
.io-hero-logo-script { margin: -8px 0 2px 70px; font-size: clamp(32px, 4vw, 54px); }
.io-hero-title {
  margin: 0;
  color: #8c4bd6;
  font-family: var(--io-serif);
  font-size: clamp(38px, 5.4vw, 64px);
  line-height: 1.55;
  letter-spacing: .04em;
  font-weight: 900;
  text-shadow: 0 5px 26px rgba(255,255,255,.9);
}
.io-hero-subtitle {
  max-width: 500px;
  margin: 28px 0 0;
  color: #6e4f8d;
  font-size: 15px;
  line-height: 2;
  font-weight: 900;
  text-shadow: 0 4px 18px rgba(255,255,255,.88);
}
.io-hashtag {
  margin-top: 26px;
  color: #a65ded;
  font-size: 24px;
  letter-spacing: .06em;
  font-family: var(--io-serif);
  font-weight: 700;
}
.io-next-panel {
  justify-self: end;
  width: min(100%, 360px);
  margin-top: 34px;
  padding: 30px 34px 34px;
  border-radius: 22px;
  color: #5d2e88;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(255,255,255,.95);
  box-shadow: 0 26px 70px rgba(76,31,125,.2);
  backdrop-filter: blur(18px);
  position: relative;
}
.io-next-panel:before,
.io-next-panel:after { content: "✦"; position: absolute; color: #d4b1fb; font-size: 22px; }
.io-next-panel:before { left: 20px; top: 24px; }
.io-next-panel:after { right: 22px; top: 24px; }
.io-next-head { text-align: center; padding-bottom: 14px; border-bottom: 1px solid #e5d6f5; }
.io-next-head span { display: block; color: #8e4bd5; font-family: var(--io-serif); font-size: 24px; letter-spacing: .04em; font-weight: 900; }
.io-next-head small { display: block; color: #b180eb; font-size: 11px; font-weight: 900; }
.io-next-date-big { display: flex; align-items: center; gap: 12px; margin-top: 26px; color: #5b2a87; }
.io-next-date-big span { font-family: var(--io-serif); font-size: 72px; line-height: 1; font-weight: 600; letter-spacing: .08em; }
.io-next-date-big em { display: grid; place-items: center; width: 36px; height: 36px; border: 2px solid #8d5cc7; border-radius: 50%; font-style: normal; font-weight: 900; }
.io-next-badge { display: inline-flex; margin: 12px 0 8px; padding: 4px 12px; border-radius: 6px; color: white; background: linear-gradient(135deg, var(--io-cat-color, #9b5ce8), #c387f3); font-size: 12px; font-weight: 900; }
.io-next-title { margin: 4px 0 10px; color: #51277c; font-size: 20px; line-height: 1.55; font-weight: 900; }
.io-next-meta { margin: 6px 0 0; color: #75559a; font-size: 12px; line-height: 1.45; font-weight: 900; text-transform: uppercase; }
.io-next-meta:before { content: "◎"; margin-right: 6px; color: #a867e7; }
.io-next-button,
.io-contact-button,
.io-more-button,
.io-button-fill,
.io-button-line {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 38px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.io-next-button { width: 100%; min-height: 56px; margin-top: 24px; color: #fff; background: linear-gradient(135deg, #a95bed, #8c4bd6); box-shadow: 0 14px 28px rgba(147,83,222,.27); }
.io-next-button span,
.io-contact-button span,
.io-more-button span { margin-left: auto; }
.io-next-button:hover,
.io-contact-button:hover,
.io-more-button:hover,
.io-button-fill:hover,
.io-button-line:hover { transform: translateY(-2px); }

.io-section { position: relative; padding: 54px 0; background: #fff; }
.io-schedule-section { margin-top: -70px; padding-top: 0; position: relative; z-index: 4; }
.io-section-center { text-align: center; margin-bottom: 20px; }
.io-section-label,
.io-box-head span {
  display: block;
  color: #8d4ed6;
  font-family: var(--io-serif);
  font-size: 28px;
  line-height: 1.1;
  letter-spacing: .08em;
  font-weight: 900;
}
.io-section-title { margin: 4px 0 0; color: #8d4ed6; font-family: var(--io-serif); font-size: 18px; font-weight: 700; letter-spacing: .12em; }
.io-section-desc { margin: 12px auto 0; max-width: 660px; color: var(--io-muted); font-size: 13px; font-weight: 900; }
.io-filter {
  display: flex;
  justify-content: center;
  gap: 20px;
  overflow-x: auto;
  padding: 14px 0 26px;
}
.io-filter-button {
  flex: 0 0 auto;
  min-width: 124px;
  min-height: 36px;
  border: 2px solid var(--io-cat-color, #e1cbf9);
  border-radius: 999px;
  background: #fff;
  color: var(--io-cat-color, #a06dda);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(129,69,191,.05);
}
.io-filter-button[data-filter="all"] { border-color: #e1cbf9; color: #a06dda; }
.io-filter-button.is-active {
  color: white;
  border-color: transparent;
  background: linear-gradient(135deg, var(--io-cat-color, #b96bf1), #9455df);
  box-shadow: 0 12px 22px rgba(146,77,219,.26);
}
.io-schedule-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 20px; }
.io-schedule-card {
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid #eadcf9;
  border-top: 4px solid var(--io-cat-color, #eadcf9);
  background: white;
  box-shadow: 0 14px 36px rgba(128,65,194,.12);
  transition: transform .22s ease, box-shadow .22s ease;
}
.io-schedule-card.is-live { --io-cat-color: var(--io-purple); }
.io-schedule-card.is-gravure { --io-cat-color: var(--io-pink); }
.io-schedule-card.is-event { --io-cat-color: var(--io-green); }
.io-schedule-card.is-web { --io-cat-color: var(--io-blue); }
.io-schedule-card.is-goods { --io-cat-color: var(--io-orange); }
.io-schedule-card:hover { transform: translateY(-5px); box-shadow: 0 24px 52px rgba(128,65,194,.18); }
.io-card-date-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; padding: 18px 18px 10px; }
.io-card-date { color: #6b33a0; font-family: var(--io-serif); font-size: 34px; line-height: .9; font-weight: 600; letter-spacing: .02em; }
.io-card-dow { display: inline-grid; place-items: center; width: 24px; height: 24px; margin-left: 5px; border: 1px solid #9e69db; border-radius: 50%; color: #7c49b1; font-size: 11px; vertical-align: 7px; }
.io-card-dow.is-saturday { border-color: #54c7ff; color: #159fe3; background: #eaf8ff; }
.io-card-dow.is-sunday { border-color: #ff55c8; color: #e4009a; background: #fff0fb; }
.io-card-badge { margin-top: 1px; padding: 4px 10px; border-radius: 5px; color: white; background: var(--io-cat-color, var(--io-purple)); font-size: 10px; font-weight: 900; }
.io-thumb { display: block; position: relative; aspect-ratio: 16/10; margin: 0 16px; overflow: hidden; border-radius: 4px; background: linear-gradient(135deg, #e8d8ff, #fff); }
.io-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .35s ease; }
.io-schedule-card:hover .io-thumb img { transform: scale(1.045); }
.io-schedule-body { padding: 14px 18px 18px; }
.io-schedule-title { margin: 0; min-height: 3.1em; color: #5a2c82; font-size: 15px; line-height: 1.55; font-weight: 900; text-align: center; }
.io-schedule-meta { display: grid; gap: 4px; margin: 12px 0 0; color: #785a97; font-size: 11px; line-height: 1.45; font-weight: 900; }
.io-schedule-meta span { display: inline-flex; align-items: center; gap: 5px; min-width: 0; }
.io-schedule-meta span:before { content: ""; display: inline-block; flex: 0 0 auto; width: 1.08em; height: 1.08em; background: var(--io-cat-color, #a867e7); -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain; }
.io-schedule-meta span:first-child:before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 21V4c0-.56.04-1 1-1h10c.55 0 1 .45 1 1v17h3V10h-2V8h3c.55 0 1 .45 1 1v12h1v2H2v-2h2Zm3-14v2h2V7H7Zm4 0v2h2V7h-2Zm-4 4v2h2v-2H7Zm4 0v2h2v-2h-2Zm-4 4v2h2v-2H7Zm4 0v2h2v-2h-2Z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 21V4c0-.56.04-1 1-1h10c.55 0 1 .45 1 1v17h3V10h-2V8h3c.55 0 1 .45 1 1v12h1v2H2v-2h2Zm3-14v2h2V7H7Zm4 0v2h2V7h-2Zm-4 4v2h2v-2H7Zm4 0v2h2v-2h-2Zm-4 4v2h2v-2H7Zm4 0v2h2v-2h-2Z'/%3E%3C/svg%3E"); }
.io-schedule-meta span:nth-child(2):before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm0 2a8 8 0 1 1 0 16 8 8 0 0 1 0-16Zm1 3h-2v6.1l5.2 3.1 1-1.7-4.2-2.5V7Z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm0 2a8 8 0 1 1 0 16 8 8 0 0 1 0-16Zm1 3h-2v6.1l5.2 3.1 1-1.7-4.2-2.5V7Z'/%3E%3C/svg%3E"); }
.io-card-actions { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 14px; }
.io-button-line { color: #9761d6; background: #fff; border: 2px solid #eadcf9; }
.io-button-fill { color: #fff; background: linear-gradient(135deg, #bfc0c8, #8f909a); box-shadow: 0 8px 18px rgba(90,90,100,.16); }
.io-button-fill:hover,
.io-button-fill:focus-visible { color: #fff; background: linear-gradient(135deg, #b96bf1, #8c4bd6); box-shadow: 0 12px 24px rgba(146,77,219,.28); }
.io-more { text-align: center; margin-top: 30px; }
.io-more-button { min-width: 310px; min-height: 48px; padding: 0 22px; border: 2px solid #e1cbf9; color: #9b5ce8; background: #fff; }

.io-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.io-box { border: 1px solid #eadcf9; border-radius: 8px; background: white; box-shadow: 0 14px 36px rgba(128,65,194,.1); padding: 26px; }
.io-box-head { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.io-box-head small { margin-right: auto; color: #a06dda; font-size: 12px; font-weight: 900; }
.io-box-head a { min-width: 94px; text-align: center; padding: 6px 14px; border: 2px solid #eadcf9; border-radius: 999px; color: #9b5ce8; font-size: 12px; font-weight: 900; }
.io-news-list { display: grid; }
.io-news-row { display: grid; grid-template-columns: 100px 70px minmax(0,1fr) 18px; gap: 12px; align-items: center; min-height: 58px; border-top: 1px solid #eadcf9; color: #654383; font-size: 12px; font-weight: 900; }
.io-news-row:last-child { border-bottom: 1px solid #eadcf9; }
.io-news-row time { color: #806098; }
.io-news-row em { display: inline-flex; justify-content: center; border-radius: 5px; padding: 3px 7px; color: white; background: #a36be6; font-style: normal; font-size: 10px; }
.io-news-row b { color: #a36be6; font-size: 22px; }
.io-profile-layout { display: grid; grid-template-columns: 46% minmax(0,1fr); gap: 24px; align-items: center; }
.io-profile-photo { overflow: hidden; aspect-ratio: 4/5; background: #f3eef8; }
.io-profile-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.io-profile-text h2 { margin: 0; color: #8d4ed6; font-family: var(--io-serif); font-size: 34px; font-weight: 700; letter-spacing: .08em; }
.io-profile-script { margin-top: -5px; font-size: 27px; }
.io-profile-lead { margin: 16px 0 0; color: #6b348f; font-family: var(--io-serif); font-size: 17px; line-height: 1.8; font-weight: 900; }
.io-profile-text p { margin: 12px 0 0; color: #71518f; font-size: 12px; font-weight: 900; }
.io-profile-data { display: grid; gap: 5px; margin-top: 14px; color: #71518f; font-size: 12px; font-weight: 900; }
.io-profile-data span:before { content: "✦"; margin-right: 6px; color: #bf97f2; }


.io-release-section {
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 8%, rgba(232,216,255,.72), transparent 24rem),
    radial-gradient(circle at 92% 18%, rgba(244,169,223,.28), transparent 20rem),
    linear-gradient(180deg, #fff 0%, #fffaff 100%);
}
.io-release-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding: 8px 14px;
  border: 1px solid rgba(180,123,241,.34);
  border-radius: 999px;
  color: #7a35bb;
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 24px rgba(128,65,194,.08);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
}
.io-release-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 22px;
  margin-top: 28px;
}
.io-release-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(234,220,249,.92);
  border-radius: 26px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 24px 56px rgba(128,65,194,.14);
  transform: translateZ(0);
}
.io-release-card:before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,.28), transparent 44%, rgba(232,216,255,.28));
  z-index: 2;
}
.io-release-visual {
  position: relative;
  display: block;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: linear-gradient(135deg, #f3eaff, #fff);
}
.io-release-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform .42s ease;
}
.io-release-card:hover .io-release-visual img { transform: scale(1.045); }
.io-release-type {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, #a85dec, #8d4ed6);
  box-shadow: 0 10px 24px rgba(80,37,126,.18);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}
.io-release-type.is-dvd { background: linear-gradient(135deg, #77a8f8, #9b5ce8); }
.io-release-body {
  position: relative;
  z-index: 3;
  display: grid;
  gap: 10px;
  padding: 20px 20px 22px;
}
.io-release-catch {
  color: #a05be2;
  font-family: var(--io-serif);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .05em;
}
.io-release-title {
  margin: 0;
  color: #552a82;
  font-family: var(--io-serif);
  font-size: 22px;
  line-height: 1.45;
  font-weight: 900;
  letter-spacing: .04em;
}
.io-release-meta {
  display: grid;
  gap: 5px;
  margin: 0;
  color: #765395;
  font-size: 12px;
  font-weight: 900;
}
.io-release-meta span {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  border-top: 1px solid rgba(234,220,249,.78);
  padding-top: 7px;
}
.io-release-meta b { color: #8d4ed6; font-size: 10px; letter-spacing: .1em; }
.io-release-excerpt {
  margin: 0;
  color: #71518f;
  font-size: 12px;
  line-height: 1.75;
  font-weight: 900;
}
.io-release-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 4px;
}
.io-release-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  transition: transform .2s ease, box-shadow .2s ease;
}
.io-release-button-primary {
  color: #fff;
  background: linear-gradient(135deg, #b96bf1, #8c4bd6);
  box-shadow: 0 12px 24px rgba(146,77,219,.24);
}
.io-release-button-secondary {
  color: #8d4ed6;
  border: 2px solid #eadcf9;
  background: rgba(255,255,255,.78);
}
.io-release-button:hover { transform: translateY(-2px); }
.io-release-empty {
  margin-top: 28px;
  padding: 28px;
  border: 1px solid rgba(234,220,249,.9);
  border-radius: 24px;
  color: #6d438f;
  background: rgba(255,255,255,.86);
  text-align: center;
  font-weight: 900;
  box-shadow: 0 18px 42px rgba(128,65,194,.08);
}
.io-release-detail {
  background: linear-gradient(180deg,#fff 0%,#fffaff 100%);
}
.io-release-detail-grid {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(0,1fr);
  gap: 36px;
  align-items: start;
}
.io-release-detail-cover {
  overflow: hidden;
  border-radius: 28px;
  background: #f3eaff;
  box-shadow: 0 24px 60px rgba(128,65,194,.16);
}
.io-release-detail-cover img {
  width: 100%;
  height: auto;
}
.io-release-detail-copy {
  padding: 10px 0;
}
.io-release-detail-copy h1 {
  margin: 12px 0 0;
  color: #552a82;
  font-family: var(--io-serif);
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.35;
  letter-spacing: .05em;
}
.io-release-detail-lead {
  color: #a05be2;
  font-family: var(--io-serif);
  font-size: 18px;
  font-weight: 900;
}
.io-release-detail-body {
  margin-top: 22px;
  color: #61427f;
  font-size: 14px;
  font-weight: 800;
  line-height: 2;
}
.io-release-detail-spec {
  display: grid;
  gap: 8px;
  margin: 24px 0 0;
  padding: 18px;
  border: 1px solid #eadcf9;
  border-radius: 18px;
  background: rgba(255,255,255,.82);
}
.io-release-detail-spec div {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: #725293;
  font-size: 13px;
  font-weight: 900;
}
.io-release-detail-spec b { color: #8d4ed6; }
@media (max-width: 900px) {
  .io-release-grid { grid-template-columns: 1fr 1fr; }
  .io-release-detail-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .io-release-grid { grid-template-columns: 1fr; gap: 16px; }
  .io-release-card { border-radius: 22px; }
  .io-release-visual { aspect-ratio: 16/11; }
  .io-release-actions { grid-template-columns: 1fr; }
  .io-release-title { font-size: 20px; }
}

.io-banner-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }
.io-promo-banner {
  min-height: 116px;
  overflow: hidden;
  position: relative;
  padding: 22px 24px;
  border-radius: 12px;
  color: #6a3498;
  background: linear-gradient(135deg, rgba(219,196,255,.92), rgba(255,255,255,.74)), url('assets/images/hero-default.jpg') center 28% / cover;
  box-shadow: 0 16px 40px rgba(128,65,194,.12);
}
.io-promo-banner:after { content: "✦"; position: absolute; right: 18px; top: 8px; color: rgba(255,255,255,.68); font-size: 54px; }
.io-promo-banner span { display: block; color: #8a4cd1; font-family: var(--io-serif); font-size: 15px; font-weight: 900; }
.io-promo-banner strong { display: block; margin-top: 4px; color: #7a35bb; font-size: 28px; line-height: 1.1; font-weight: 900; text-shadow: 0 2px 16px rgba(255,255,255,.9); }
.io-promo-banner.has-custom-image { min-height: auto; padding: 0; background: #fff; }
.io-promo-banner.has-custom-image:after { display: none; }
.io-promo-banner-image { width: 100%; aspect-ratio: 16 / 7; height: auto; object-fit: cover; object-position: center; transition: transform .24s ease; }
.io-promo-banner.has-custom-image:hover .io-promo-banner-image { transform: scale(1.025); }
.io-sns-inline { display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 12px; }
.io-sns-inline img { display: block; width: 34px; height: 34px; border-radius: 10px; object-fit: contain; filter: drop-shadow(0 5px 10px rgba(75,27,122,.14)); }
.io-contact-strip { display: flex; align-items: center; justify-content: space-between; gap: 22px; margin-top: 30px; padding: 22px 26px; border: 1px solid #eadcf9; border-radius: 8px; background: white; box-shadow: 0 14px 36px rgba(128,65,194,.1); }
.io-contact-strip h2 { margin: 0; color: #8d4ed6; font-family: var(--io-serif); font-size: 20px; font-weight: 900; }
.io-contact-strip p { margin: 4px 0 0; color: #806098; font-size: 12px; font-weight: 900; }
.io-contact-button { min-width: 240px; min-height: 48px; padding: 0 22px; color: #fff; background: linear-gradient(135deg, #c074ef, #9853df); box-shadow: 0 12px 22px rgba(152,83,223,.2); }
.io-section#goods { padding-bottom: 20px; }

.io-footer { padding: 22px 0 50px; color: #9a78bb; text-align: center; background: #fff; }
.io-footer-name { font-size: 32px; }
.io-sns { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 16px; }
.io-sns a { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 15px; background: rgba(255,255,255,.95); box-shadow: 0 10px 26px rgba(83,35,128,.14); transition: transform .22s ease, box-shadow .22s ease; }
.io-sns a:hover { transform: translateY(-3px) scale(1.04); box-shadow: 0 15px 34px rgba(83,35,128,.2); }
.io-sns img { display: block; width: 42px; height: 42px; object-fit: contain; border-radius: 13px; }
.io-copyright { margin: 16px 0 0; font-size: 11px; letter-spacing: .08em; }

.io-single { padding: 124px 0 70px; background: #fff; }
.io-single-box { max-width: 920px; margin: auto; padding: 34px; border: 1px solid #eadcf9; border-radius: 12px; box-shadow: var(--io-shadow); }
.io-single-title { margin: 12px 0 10px; color: #7a35bb; font-family: var(--io-serif); font-size: clamp(34px, 5vw, 58px); line-height: 1.22; font-weight: 900; }
.io-single-meta { color: #806098; font-weight: 900; }
.io-content { margin-top: 24px; color: #4d3768; font-size: 16px; }
.io-content p { margin: 0 0 1.2em; }
.io-content a { color: var(--io-purple); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 4px; }

@media (max-width: 1060px) {
  .io-brand { min-width: 180px; }
  .io-logo-name { font-size: 28px; }
  .io-nav a, .io-menu a { min-width: 78px; padding-inline: 10px; }
  .io-schedule-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 900px) {
  .io-header { position: absolute; }
  .io-header-inner { align-items: center; position: relative; min-height: 72px; padding-top: 10px; }
  .io-brand { padding-top: 0; min-width: 0; }
  .io-mobile-menu-button {
    display: inline-flex;
    flex: 0 0 auto;
    position: fixed;
    top: calc(14px + env(safe-area-inset-top));
    right: calc(12px + env(safe-area-inset-right));
    z-index: 1001;
  }
  .admin-bar .io-mobile-menu-button {
    top: calc(58px + env(safe-area-inset-top));
  }
  .io-nav {
    display: none;
    position: fixed;
    top: calc(74px + env(safe-area-inset-top));
    left: 12px;
    right: 12px;
    z-index: 1000;
    max-height: calc(100vh - 92px - env(safe-area-inset-top));
    border-radius: 24px;
    border: 1px solid rgba(232,216,255,.95);
    background: rgba(255,255,255,.96);
    box-shadow: 0 22px 60px rgba(109,62,167,.22);
    backdrop-filter: blur(20px);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  .admin-bar .io-nav {
    top: calc(118px + env(safe-area-inset-top));
    max-height: calc(100vh - 136px - env(safe-area-inset-top));
  }
  .io-nav.is-open { display: block; }
  .io-menu { display: block; width: 100%; }
  .io-menu li { margin: 0; }
  .io-nav a, .io-menu a {
    display: grid;
    grid-template-columns: 28px 1fr;
    grid-template-rows: auto auto;
    align-items: center;
    justify-items: start;
    place-items: initial;
    width: 100%;
    min-width: 0;
    min-height: 58px;
    padding: 10px 18px;
    border-left: 0;
    border-bottom: 1px solid rgba(232,216,255,.72);
    text-align: left;
  }
  .io-nav a:last-child, .io-menu li:last-child a { border-bottom: 0; }
  .io-nav a span { grid-row: 1 / span 2; font-size: 16px; align-self: center; }
  .io-nav a strong { margin-top: 0; font-size: 12px; line-height: 1.2; }
  .io-nav a small { margin-top: 2px; font-size: 9px; line-height: 1.2; }
  .io-menu a { display: flex; align-items: center; justify-content: flex-start; font-size: 13px; font-weight: 900; letter-spacing: .06em; }
  .io-hero { min-height: auto; padding: 122px 0 92px; }
  .io-hero:before { background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.44) 34%, rgba(255,255,255,.9) 100%); }
  .io-hero-inner { grid-template-columns: 1fr; gap: 24px; }
  .io-hero-copy { max-width: 100%; }
  .io-next-panel { justify-self: start; width: min(100%, 420px); margin-top: 6px; }
  .io-two-col { grid-template-columns: 1fr; }
  .io-banner-row { grid-template-columns: 1fr; }
  .io-contact-strip { align-items: stretch; flex-direction: column; }
  .io-contact-button { width: 100%; }
}
@media (max-width: 720px) {
  .admin-bar .io-header { top: 0; }
  .io-container { width: min(100% - 24px, var(--io-max)); }
  .io-logo-name { font-size: 28px; }
  .io-logo-script { font-size: 23px; }
  .io-hero { padding-top: 118px; }
  .io-hero-bg, .io-hero-media { object-position: center top; }
  .io-hero:before { background: linear-gradient(180deg, rgba(255,255,255,.7) 0%, rgba(255,255,255,.2) 36%, rgba(255,255,255,.93) 68%, #fff 100%); }
  .io-hero-logo-block { margin-bottom: 300px; }
  .io-hero-logo-name { font-size: 40px; }
  .io-hero-logo-script { margin-left: 46px; font-size: 32px; }
  .io-hero-title { font-size: 31px; line-height: 1.55; }
  .io-hero-subtitle { margin-top: 18px; font-size: 13px; line-height: 1.8; }
  .io-hashtag { font-size: 18px; }
  .io-next-panel { padding: 24px 24px 28px; border-radius: 18px; }
  .io-next-date-big span { font-size: 58px; }
  .io-section { padding: 40px 0; }
  .io-section-label, .io-box-head span { font-size: 24px; }
  .io-filter { justify-content: flex-start; gap: 10px; padding-bottom: 20px; }
  .io-filter-button { min-width: 92px; }
  .io-schedule-grid { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; }
  .io-card-date-row { padding: 14px 12px 8px; }
  .io-card-date { font-size: 27px; }
  .io-card-badge { font-size: 9px; padding-inline: 7px; }
  .io-thumb { margin-inline: 12px; }
  .io-schedule-body { padding: 12px; }
  .io-schedule-title { font-size: 12px; }
  .io-schedule-meta { font-size: 10px; }
  .io-news-row { grid-template-columns: 84px 58px minmax(0,1fr) 12px; gap: 8px; font-size: 11px; }
  .io-profile-layout { grid-template-columns: 1fr; }
  .io-profile-photo { max-width: 260px; }
  .io-promo-banner strong { font-size: 24px; }
}
@media (max-width: 420px) {
  .io-schedule-grid { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
  .io-card-date-row { padding: 12px 10px 7px; gap: 6px; }
  .io-card-date { font-size: 24px; }
  .io-card-dow { width: 21px; height: 21px; font-size: 10px; margin-left: 3px; }
  .io-card-badge { font-size: 8px; padding: 3px 6px; }
  .io-thumb { margin-inline: 10px; }
  .io-schedule-body { padding: 10px; }
  .io-schedule-title { font-size: 11px; min-height: 3.2em; }
  .io-schedule-meta { font-size: 9px; }
  .io-button-fill { min-height: 34px; font-size: 11px; }
  .io-hero-logo-block { margin-bottom: 250px; }
  .io-next-date-big span { font-size: 50px; }
}

.io-schedule-detail-text{margin:22px 0;padding:22px;border:1px solid rgba(173,126,225,.28);border-radius:24px;background:linear-gradient(135deg,rgba(251,247,255,.92),rgba(255,255,255,.96));color:#4d2b73;font-weight:700;line-height:2;box-shadow:0 12px 28px rgba(123,71,183,.08)}
.io-schedule-detail-text p{margin:0 0 1em}.io-schedule-detail-text p:last-child{margin-bottom:0}


/* v2.1: SCHEDULE section adjusted 30px lower than v2.0. */
.io-schedule-section { margin-top: -70px; padding-top: 0; position: relative; z-index: 4; }

/* v2.2: On smartphones, resize the header main visual to the screen width instead of cropping both sides. */
@media (max-width: 720px) {
  .io-hero-slider {
    background: linear-gradient(180deg, #f8efff 0%, #fff 100%);
  }
  .io-hero-bg,
  .io-hero-media {
    width: 100%;
    height: auto;
    min-height: 0;
    object-fit: contain;
    object-position: top center;
  }
  video.io-hero-media {
    height: auto;
  }
}



/* v2.3: On smartphones, remove the excessive blank space created by contain-fit hero media. */
@media (max-width: 720px) {
  .io-hero {
    padding-bottom: 0;
  }
  .io-hero-logo-block {
    margin-bottom: 0;
  }
  .io-next-panel {
    margin-top: 0;
  }
}
@media (max-width: 420px) {
  .io-hero-logo-block {
    margin-bottom: 0;
  }
}

/* v2.4: Restore 80px vertical breathing room after the mobile header visual. */
@media (max-width: 720px) {
  .io-hero-logo-block {
    margin-bottom: 80px;
  }
}
@media (max-width: 420px) {
  .io-hero-logo-block {
    margin-bottom: 80px;
  }
}

/* v2.5: Saturday/Sunday colors, compact schedule heading, editable bottom image banners. */
.io-schedule-section .io-section-center { margin-bottom: 8px; }
.io-schedule-section .io-filter { padding-top: 8px; }
@media (max-width: 720px) {
  .io-schedule-section .io-section-center { margin-bottom: 6px; }
  .io-schedule-section .io-filter { padding-top: 4px; }
  .io-promo-banner-image { aspect-ratio: 16 / 7; }
}


/* v2.6: Scroll reveal and soft motion animation for schedule tiles, menus, and bottom banners. */
.io-reveal {
  opacity: 0;
  transform: translateY(26px) scale(.985);
  filter: blur(6px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .72s cubic-bezier(.22,1,.36,1),
    filter .72s cubic-bezier(.22,1,.36,1);
  transition-delay: calc(var(--io-stagger, 0) * 70ms);
  will-change: opacity, transform, filter;
}
.io-reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}
.io-schedule-card.io-reveal {
  transform: translateY(30px) scale(.965) rotate(.001deg);
}
.io-schedule-card.io-reveal.is-visible {
  transform: translateY(0) scale(1) rotate(0);
}
.io-filter-button.io-reveal {
  transform: translateY(16px) scale(.94);
}
.io-filter-button.io-reveal.is-visible {
  transform: translateY(0) scale(1);
}
.io-nav a,
.io-mobile-menu-button,
.io-brand {
  animation: ioSoftDrop .68s cubic-bezier(.22,1,.36,1) both;
}
.io-brand { animation-delay: .04s; }
.io-mobile-menu-button { animation-delay: .12s; }
.io-nav a:nth-child(1) { animation-delay: .08s; }
.io-nav a:nth-child(2) { animation-delay: .13s; }
.io-nav a:nth-child(3) { animation-delay: .18s; }
.io-nav a:nth-child(4) { animation-delay: .23s; }
.io-nav a:nth-child(5) { animation-delay: .28s; }
.io-nav a:nth-child(6) { animation-delay: .33s; }
@keyframes ioSoftDrop {
  from {
    opacity: 0;
    transform: translateY(-12px) scale(.98);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
.io-schedule-card.is-filter-animating {
  animation: ioTilePop .46s cubic-bezier(.22,1,.36,1) both;
}
@keyframes ioTilePop {
  from {
    opacity: 0;
    transform: translateY(18px) scale(.96);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
.io-thumb img,
.io-promo-banner-image,
.io-box,
.io-next-panel {
  backface-visibility: hidden;
}
.io-promo-banner:hover .io-promo-banner-image,
.io-thumb:hover img {
  transform: scale(1.045);
}
@media (max-width: 720px) {
  .io-reveal {
    transform: translateY(20px) scale(.985);
    transition-duration: .62s;
    transition-delay: calc(var(--io-stagger, 0) * 45ms);
  }
  .io-schedule-card.io-reveal {
    transform: translateY(22px) scale(.965);
  }
}
@media (prefers-reduced-motion: reduce) {
  .io-reveal,
  .io-reveal.is-visible,
  .io-nav a,
  .io-mobile-menu-button,
  .io-brand,
  .io-schedule-card.is-filter-animating {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
    animation: none !important;
  }
}

/* v2.7: Add left/right slide-in motion to schedule tiles, filter menus, banners, and content blocks. */
.io-reveal.io-slide-left {
  transform: translateX(-46px) translateY(14px) scale(.985);
}
.io-reveal.io-slide-right {
  transform: translateX(46px) translateY(14px) scale(.985);
}
.io-reveal.io-slide-up {
  transform: translateY(24px) scale(.985);
}
.io-reveal.io-slide-left.is-visible,
.io-reveal.io-slide-right.is-visible,
.io-reveal.io-slide-up.is-visible {
  transform: translateX(0) translateY(0) scale(1);
}
.io-schedule-card.io-reveal.io-slide-left {
  transform: translateX(-52px) translateY(18px) scale(.965) rotate(.001deg);
}
.io-schedule-card.io-reveal.io-slide-right {
  transform: translateX(52px) translateY(18px) scale(.965) rotate(.001deg);
}
.io-schedule-card.io-reveal.io-slide-left.is-visible,
.io-schedule-card.io-reveal.io-slide-right.is-visible {
  transform: translateX(0) translateY(0) scale(1) rotate(0);
}
.io-filter-button.io-reveal.io-slide-left {
  transform: translateX(-28px) scale(.94);
}
.io-filter-button.io-reveal.io-slide-right {
  transform: translateX(28px) scale(.94);
}
.io-filter-button.io-reveal.io-slide-left.is-visible,
.io-filter-button.io-reveal.io-slide-right.is-visible {
  transform: translateX(0) scale(1);
}
.io-promo-banner.io-reveal.io-slide-left,
.io-box.io-reveal.io-slide-left,
.io-next-panel.io-reveal.io-slide-left {
  transform: translateX(-42px) translateY(12px) scale(.985);
}
.io-promo-banner.io-reveal.io-slide-right,
.io-box.io-reveal.io-slide-right,
.io-next-panel.io-reveal.io-slide-right {
  transform: translateX(42px) translateY(12px) scale(.985);
}
.io-promo-banner.io-reveal.io-slide-left.is-visible,
.io-promo-banner.io-reveal.io-slide-right.is-visible,
.io-box.io-reveal.io-slide-left.is-visible,
.io-box.io-reveal.io-slide-right.is-visible,
.io-next-panel.io-reveal.io-slide-left.is-visible,
.io-next-panel.io-reveal.io-slide-right.is-visible {
  transform: translateX(0) translateY(0) scale(1);
}
.io-schedule-card.is-filter-animating.io-slide-left {
  animation: ioTileSlideLeft .58s cubic-bezier(.22,1,.36,1) both;
}
.io-schedule-card.is-filter-animating.io-slide-right {
  animation: ioTileSlideRight .58s cubic-bezier(.22,1,.36,1) both;
}
.io-nav.is-open a:nth-child(odd),
.io-nav.is-open .io-menu li:nth-child(odd) a {
  animation: ioMenuSlideLeft .42s cubic-bezier(.22,1,.36,1) both;
}
.io-nav.is-open a:nth-child(even),
.io-nav.is-open .io-menu li:nth-child(even) a {
  animation: ioMenuSlideRight .42s cubic-bezier(.22,1,.36,1) both;
}
.io-nav.is-open a:nth-child(1), .io-nav.is-open .io-menu li:nth-child(1) a { animation-delay: .03s; }
.io-nav.is-open a:nth-child(2), .io-nav.is-open .io-menu li:nth-child(2) a { animation-delay: .07s; }
.io-nav.is-open a:nth-child(3), .io-nav.is-open .io-menu li:nth-child(3) a { animation-delay: .11s; }
.io-nav.is-open a:nth-child(4), .io-nav.is-open .io-menu li:nth-child(4) a { animation-delay: .15s; }
.io-nav.is-open a:nth-child(5), .io-nav.is-open .io-menu li:nth-child(5) a { animation-delay: .19s; }
.io-nav.is-open a:nth-child(6), .io-nav.is-open .io-menu li:nth-child(6) a { animation-delay: .23s; }
@keyframes ioTileSlideLeft {
  from { opacity: 0; transform: translateX(-34px) translateY(12px) scale(.96); filter: blur(4px); }
  to { opacity: 1; transform: translateX(0) translateY(0) scale(1); filter: blur(0); }
}
@keyframes ioTileSlideRight {
  from { opacity: 0; transform: translateX(34px) translateY(12px) scale(.96); filter: blur(4px); }
  to { opacity: 1; transform: translateX(0) translateY(0) scale(1); filter: blur(0); }
}
@keyframes ioMenuSlideLeft {
  from { opacity: 0; transform: translateX(-18px); filter: blur(3px); }
  to { opacity: 1; transform: translateX(0); filter: blur(0); }
}
@keyframes ioMenuSlideRight {
  from { opacity: 0; transform: translateX(18px); filter: blur(3px); }
  to { opacity: 1; transform: translateX(0); filter: blur(0); }
}
@media (max-width: 720px) {
  .io-reveal.io-slide-left,
  .io-promo-banner.io-reveal.io-slide-left,
  .io-box.io-reveal.io-slide-left,
  .io-next-panel.io-reveal.io-slide-left {
    transform: translateX(-24px) translateY(10px) scale(.985);
  }
  .io-reveal.io-slide-right,
  .io-promo-banner.io-reveal.io-slide-right,
  .io-box.io-reveal.io-slide-right,
  .io-next-panel.io-reveal.io-slide-right {
    transform: translateX(24px) translateY(10px) scale(.985);
  }
  .io-schedule-card.io-reveal.io-slide-left {
    transform: translateX(-26px) translateY(12px) scale(.965);
  }
  .io-schedule-card.io-reveal.io-slide-right {
    transform: translateX(26px) translateY(12px) scale(.965);
  }
  .io-reveal.io-slide-left.is-visible,
  .io-reveal.io-slide-right.is-visible,
  .io-promo-banner.io-reveal.io-slide-left.is-visible,
  .io-promo-banner.io-reveal.io-slide-right.is-visible,
  .io-box.io-reveal.io-slide-left.is-visible,
  .io-box.io-reveal.io-slide-right.is-visible,
  .io-next-panel.io-reveal.io-slide-left.is-visible,
  .io-next-panel.io-reveal.io-slide-right.is-visible,
  .io-schedule-card.io-reveal.io-slide-left.is-visible,
  .io-schedule-card.io-reveal.io-slide-right.is-visible {
    transform: translateX(0) translateY(0) scale(1);
  }
}

/* v2.8: Remove the large Japanese name and cursive Roman-name overlay from the header visual. */
.io-hero-logo-block--minimal {
  display: inline-flex;
  align-items: center;
  margin-bottom: 42px;
}
@media (max-width: 720px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 80px;
  }
}
@media (max-width: 420px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 80px;
  }
}


/* v2.9: Restore 60px more breathing room below the mobile header visual. */
/* v3.0: Replace SNS text buttons with supplied colorful social media icons. */
@media (max-width: 720px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 140px;
  }
}
@media (max-width: 420px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 140px;
  }
}


/* v3.1: Tighten the mobile space under the header by 30px and remove the soft overlay/filter from the main visual. */
.io-hero-bg,
.io-hero-media {
  filter: none;
}
.io-hero:before,
.io-hero-haze {
  display: none;
}
@media (max-width: 720px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 110px;
  }
}
@media (max-width: 420px) {
  .io-hero-logo-block--minimal {
    margin-bottom: 110px;
  }
}


/* v3.2: Move the site logo to the top-left corner and keep the full desktop header menu visible regardless of logo image size. */
.io-header .io-container {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}
.io-header-inner {
  padding-left: 0;
  padding-right: 22px;
  gap: 10px;
}
.io-brand {
  flex: 0 1 clamp(104px, 18vw, 220px);
  min-width: 0;
  max-width: clamp(104px, 18vw, 220px);
  padding-top: 8px;
  padding-left: 8px;
  overflow: visible;
}
.io-site-logo {
  display: block;
  max-width: 100%;
}
.io-site-logo img {
  width: auto;
  max-width: 100%;
  max-height: 72px;
  object-fit: contain;
  object-position: left top;
}
.io-logo-text {
  display: block;
  max-width: 100%;
  transform-origin: left top;
}
.io-logo-name,
.io-logo-script,
.io-logo-label {
  white-space: nowrap;
}
.io-nav {
  flex: 0 0 auto;
  margin-left: auto;
  max-width: calc(100vw - clamp(126px, 21vw, 252px));
}
.io-nav a,
.io-menu a {
  min-width: clamp(76px, 7.7vw, 94px);
  padding-left: clamp(8px, 1vw, 14px);
  padding-right: clamp(8px, 1vw, 14px);
}
@media (max-width: 1060px) {
  .io-brand {
    flex-basis: clamp(96px, 16vw, 180px);
    max-width: clamp(96px, 16vw, 180px);
  }
  .io-nav {
    max-width: calc(100vw - clamp(116px, 19vw, 210px));
  }
  .io-nav a,
  .io-menu a {
    min-width: clamp(72px, 7.6vw, 82px);
    padding-left: 8px;
    padding-right: 8px;
  }
}
@media (max-width: 900px) {
  .io-header-inner {
    padding-right: 0;
  }
  .io-brand {
    flex-basis: clamp(96px, 42vw, 190px);
    max-width: clamp(96px, 42vw, 190px);
    padding-top: 8px;
    padding-left: 8px;
  }
  .io-site-logo img {
    max-height: 60px;
  }
  .io-nav {
    max-width: none;
    margin-left: 0;
  }
}


/* v3.4: Smartphone-only logo correction.
   Desktop header position and logo sizing remain the same as v3.2. */
@media (max-width: 767px) {
  .io-header .io-container,
  .io-header-inner {
    width: 100%;
    max-width: none;
    margin: 0;
  }
  .io-header-inner {
    justify-content: flex-start;
    align-items: flex-start;
    padding-left: 0;
    padding-right: 0;
  }
  .io-brand {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 60;
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    max-width: clamp(96px, 42vw, 190px);
    margin: 0 !important;
    padding-top: 8px !important;
    padding-left: 8px !important;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    transform: none !important;
  }
  .io-site-logo,
  .io-site-logo img,
  .io-brand .custom-logo {
    display: block;
    margin: 0 !important;
    object-position: left top;
  }
  .io-site-logo img,
  .io-brand .custom-logo {
    width: auto;
    max-width: 100%;
    max-height: 60px;
    object-fit: contain;
  }
  .io-logo-text {
    text-align: left;
    transform-origin: left top;
  }
}

/* v3.5: Restore desktop logo position/size to v3.2 exactly, while keeping the smartphone logo aligned to the top-left. */
.io-brand-link {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  color: inherit;
  text-decoration: none;
}
.io-brand .custom-logo-link {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
}

@media (min-width: 768px) {
  .io-header .io-container {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }
  .io-header-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    min-height: 82px;
    padding-left: 0;
    padding-right: 22px;
    padding-top: 0;
  }
  .io-brand {
    position: static !important;
    top: auto !important;
    left: auto !important;
    z-index: auto;
    display: flex;
    flex: 0 1 clamp(104px, 18vw, 220px);
    align-items: center;
    justify-content: flex-start;
    width: auto;
    min-width: 0;
    max-width: clamp(104px, 18vw, 220px);
    margin: 0 !important;
    padding-top: 8px !important;
    padding-left: 8px !important;
    padding-right: 0 !important;
    text-align: left;
    transform: none !important;
    overflow: visible;
  }
  .io-brand-link,
  .io-site-logo,
  .io-brand .custom-logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    max-width: 100%;
    margin: 0 !important;
  }
  .io-site-logo img,
  .io-brand .custom-logo {
    display: block;
    width: auto !important;
    max-width: 100%;
    max-height: 72px;
    height: auto;
    object-fit: contain;
    object-position: left top;
    margin: 0 !important;
  }
  .io-logo-text {
    display: block;
    max-width: 100%;
    text-align: left;
    transform-origin: left top;
  }
  .io-logo-name,
  .io-logo-script,
  .io-logo-label {
    white-space: nowrap;
  }
  .io-nav {
    flex: 0 0 auto;
    margin-left: auto;
    max-width: calc(100vw - clamp(126px, 21vw, 252px));
  }
  .io-nav a,
  .io-menu a {
    min-width: clamp(76px, 7.7vw, 94px);
    padding-left: clamp(8px, 1vw, 14px);
    padding-right: clamp(8px, 1vw, 14px);
  }
}

@media (min-width: 768px) and (max-width: 1060px) {
  .io-brand {
    flex-basis: clamp(96px, 16vw, 180px);
    max-width: clamp(96px, 16vw, 180px);
  }
  .io-nav {
    max-width: calc(100vw - clamp(116px, 19vw, 210px));
  }
  .io-nav a,
  .io-menu a {
    min-width: clamp(72px, 7.6vw, 82px);
    padding-left: 8px;
    padding-right: 8px;
  }
}

@media (min-width: 768px) and (max-width: 900px) {
  .io-header-inner {
    padding-right: 0;
  }
  .io-brand {
    flex-basis: clamp(96px, 42vw, 190px);
    max-width: clamp(96px, 42vw, 190px);
    padding-top: 8px !important;
    padding-left: 8px !important;
  }
  .io-site-logo img,
  .io-brand .custom-logo {
    max-height: 60px;
  }
  .io-nav {
    max-width: none;
    margin-left: 0;
  }
}

@media (max-width: 767px) {
  .io-header .io-container,
  .io-header-inner {
    width: 100%;
    max-width: none;
    margin: 0;
  }
  .io-header-inner {
    justify-content: flex-start;
    align-items: flex-start;
    padding-left: 0;
    padding-right: 0;
  }
  .io-brand {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 60;
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    max-width: clamp(96px, 42vw, 190px);
    margin: 0 !important;
    padding-top: 8px !important;
    padding-left: 8px !important;
    padding-right: 0 !important;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    transform: none !important;
  }
  .io-brand-link,
  .io-site-logo,
  .io-site-logo img,
  .io-brand .custom-logo-link,
  .io-brand .custom-logo {
    display: block;
    margin: 0 !important;
    object-position: left top;
  }
  .io-site-logo img,
  .io-brand .custom-logo {
    width: auto !important;
    max-width: 100%;
    max-height: 60px;
    height: auto;
    object-fit: contain;
  }
  .io-logo-text {
    text-align: left;
    transform-origin: left top;
  }
}


/* v3.6: Header logo control is now handled by Appearance > Customize > 五百木いお公式サイト設定 > ヘッダーロゴ調整. */


/* v3.9: YouTube slider between Profile and bottom banners. */
.io-youtube-section {
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 20%, rgba(232,216,255,.9), transparent 24rem),
    radial-gradient(circle at 86% 76%, rgba(244,169,223,.25), transparent 22rem),
    #fff;
}
.io-youtube-desc {
  max-width: 720px;
  margin: 10px auto 0;
  color: #806098;
  font-size: 13px;
  line-height: 1.8;
  font-weight: 900;
}
.io-youtube-slider {
  position: relative;
  max-width: 980px;
  margin: 24px auto 0;
  padding: 18px 72px 58px;
  border: 1px solid #eadcf9;
  border-radius: 18px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 50px rgba(128,65,194,.13);
}
.io-youtube-track {
  position: relative;
  min-height: 0;
}
.io-youtube-slide {
  display: none;
  margin: 0;
}
.io-youtube-slide.is-active {
  display: block;
  animation: ioYoutubeSlideIn .48s ease both;
}
.io-youtube-frame {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border-radius: 14px;
  background: linear-gradient(135deg, #e8d8ff, #fff);
  box-shadow: 0 14px 34px rgba(77,40,116,.16);
}
.io-youtube-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.io-youtube-slide h3 {
  margin: 16px 0 0;
  color: #6b33a0;
  font-family: var(--io-serif);
  font-size: 19px;
  line-height: 1.5;
  font-weight: 900;
  text-align: center;
}
.io-youtube-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, #c074ef, #9853df);
  box-shadow: 0 12px 22px rgba(152,83,223,.22);
  cursor: pointer;
  font-size: 32px;
  line-height: 1;
  transition: transform .22s ease, box-shadow .22s ease;
}
.io-youtube-arrow:hover {
  transform: translateY(-50%) scale(1.06);
  box-shadow: 0 16px 28px rgba(152,83,223,.28);
}
.io-youtube-prev { left: 16px; }
.io-youtube-next { right: 16px; }
.io-youtube-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 20px;
  display: flex;
  justify-content: center;
  gap: 9px;
}
.io-youtube-dots button {
  width: 10px;
  height: 10px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: #dfc9fb;
  cursor: pointer;
  transition: width .22s ease, background .22s ease;
}
.io-youtube-dots button.is-active {
  width: 28px;
  background: #9b5ce8;
}
@keyframes ioYoutubeSlideIn {
  from { opacity: 0; transform: translateX(26px); }
  to { opacity: 1; transform: translateX(0); }
}
@media (max-width: 720px) {
  .io-youtube-slider {
    width: min(100%, 520px);
    margin-top: 18px;
    padding: 12px 12px 52px;
    border-radius: 14px;
  }
  .io-youtube-frame { border-radius: 10px; }
  .io-youtube-slide h3 { font-size: 15px; }
  .io-youtube-arrow {
    top: auto;
    bottom: 12px;
    width: 38px;
    height: 38px;
    transform: none;
    font-size: 27px;
  }
  .io-youtube-arrow:hover { transform: scale(1.04); }
  .io-youtube-prev { left: 14px; }
  .io-youtube-next { right: 14px; }
  .io-youtube-dots { bottom: 25px; }
}
@media (prefers-reduced-motion: reduce) {
  .io-youtube-slide.is-active { animation: none; }
}

/* v4.0: YouTube slider shows three movies with slow auto slide. Center movie autoplays muted. */
.io-youtube-slider {
  max-width: 1120px;
  padding: 24px 72px 72px;
  overflow: hidden;
}
.io-youtube-track {
  position: relative;
  height: clamp(310px, 38vw, 510px);
  perspective: 1200px;
}
.io-youtube-slide {
  display: block !important;
  position: absolute;
  top: 0;
  left: 50%;
  width: min(58%, 660px);
  margin: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(-50%, 20px) scale(.74);
  filter: saturate(.82) blur(.2px);
  transition:
    transform 1.15s cubic-bezier(.22, .88, .24, 1),
    opacity 1.15s ease,
    filter 1.15s ease,
    visibility 0s linear 1.15s;
  z-index: 1;
  animation: none !important;
  will-change: transform, opacity;
}
.io-youtube-slide.is-center,
.io-youtube-slide.is-left,
.io-youtube-slide.is-right {
  visibility: visible;
  transition-delay: 0s;
}
.io-youtube-slide.is-center {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0) scale(1);
  filter: none;
  z-index: 4;
}
.io-youtube-slide.is-left {
  opacity: .62;
  cursor: pointer;
  transform: translate(-124%, 24px) scale(.72);
  z-index: 2;
}
.io-youtube-slide.is-right {
  opacity: .62;
  cursor: pointer;
  transform: translate(24%, 24px) scale(.72);
  z-index: 2;
}
.io-youtube-slide.is-hidden {
  transform: translate(-50%, 34px) scale(.66);
}
.io-youtube-slide:not(.is-center) iframe {
  pointer-events: none;
}
.io-youtube-slide.is-center .io-youtube-frame {
  box-shadow: 0 22px 48px rgba(77,40,116,.20);
}
.io-youtube-slide:not(.is-center) .io-youtube-frame {
  box-shadow: 0 12px 26px rgba(77,40,116,.10);
}
.io-youtube-slide:not(.is-center) h3 {
  opacity: .68;
}
.io-youtube-arrow {
  top: calc(50% - 34px);
  z-index: 8;
}
.io-youtube-dots {
  z-index: 8;
}
@media (max-width: 960px) {
  .io-youtube-slider {
    padding-left: 56px;
    padding-right: 56px;
  }
  .io-youtube-track {
    height: clamp(290px, 50vw, 460px);
  }
  .io-youtube-slide {
    width: min(70%, 620px);
  }
  .io-youtube-slide.is-left {
    transform: translate(-112%, 20px) scale(.72);
  }
  .io-youtube-slide.is-right {
    transform: translate(12%, 20px) scale(.72);
  }
}
@media (max-width: 720px) {
  .io-youtube-slider {
    padding: 12px 12px 58px;
  }
  .io-youtube-track {
    height: clamp(255px, 72vw, 365px);
  }
  .io-youtube-slide {
    width: 82%;
  }
  .io-youtube-slide.is-left {
    opacity: .48;
    transform: translate(-112%, 16px) scale(.70);
  }
  .io-youtube-slide.is-right {
    opacity: .48;
    transform: translate(12%, 16px) scale(.70);
  }
  .io-youtube-arrow {
    top: auto;
    bottom: 12px;
    z-index: 8;
  }
  .io-youtube-dots {
    bottom: 25px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .io-youtube-slide {
    transition: none !important;
  }
}

/* v4.0: Keep reveal animation from overriding the YouTube carousel positions. */
.io-youtube-slide.io-reveal.io-slide-left.is-center,
.io-youtube-slide.io-reveal.io-slide-right.is-center,
.io-youtube-slide.io-reveal.io-slide-up.is-center,
.io-youtube-slide.io-reveal.is-visible.is-center {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
  filter: none;
}
.io-youtube-slide.io-reveal.io-slide-left.is-left,
.io-youtube-slide.io-reveal.io-slide-right.is-left,
.io-youtube-slide.io-reveal.io-slide-up.is-left,
.io-youtube-slide.io-reveal.is-visible.is-left {
  opacity: .62;
  transform: translate(-124%, 24px) scale(.72);
  filter: saturate(.82) blur(.2px);
}
.io-youtube-slide.io-reveal.io-slide-left.is-right,
.io-youtube-slide.io-reveal.io-slide-right.is-right,
.io-youtube-slide.io-reveal.io-slide-up.is-right,
.io-youtube-slide.io-reveal.is-visible.is-right {
  opacity: .62;
  transform: translate(24%, 24px) scale(.72);
  filter: saturate(.82) blur(.2px);
}
.io-youtube-slide.io-reveal.io-slide-left.is-hidden,
.io-youtube-slide.io-reveal.io-slide-right.is-hidden,
.io-youtube-slide.io-reveal.io-slide-up.is-hidden,
.io-youtube-slide.io-reveal.is-visible.is-hidden {
  opacity: 0;
  transform: translate(-50%, 34px) scale(.66);
}
@media (max-width: 960px) {
  .io-youtube-slide.io-reveal.io-slide-left.is-left,
  .io-youtube-slide.io-reveal.io-slide-right.is-left,
  .io-youtube-slide.io-reveal.io-slide-up.is-left,
  .io-youtube-slide.io-reveal.is-visible.is-left {
    transform: translate(-112%, 20px) scale(.72);
  }
  .io-youtube-slide.io-reveal.io-slide-left.is-right,
  .io-youtube-slide.io-reveal.io-slide-right.is-right,
  .io-youtube-slide.io-reveal.io-slide-up.is-right,
  .io-youtube-slide.io-reveal.is-visible.is-right {
    transform: translate(12%, 20px) scale(.72);
  }
}
@media (max-width: 720px) {
  .io-youtube-slide.io-reveal.io-slide-left.is-left,
  .io-youtube-slide.io-reveal.io-slide-right.is-left,
  .io-youtube-slide.io-reveal.io-slide-up.is-left,
  .io-youtube-slide.io-reveal.is-visible.is-left {
    opacity: .48;
    transform: translate(-112%, 16px) scale(.70);
  }
  .io-youtube-slide.io-reveal.io-slide-left.is-right,
  .io-youtube-slide.io-reveal.io-slide-right.is-right,
  .io-youtube-slide.io-reveal.io-slide-up.is-right,
  .io-youtube-slide.io-reveal.is-visible.is-right {
    opacity: .48;
    transform: translate(12%, 16px) scale(.70);
  }
}


/* v4.1: Tighten the YouTube carousel spacing after reducing thumbnail size. */
.io-youtube-section .io-section-center {
  margin-bottom: 10px;
}
.io-youtube-slider {
  margin-top: 12px;
  padding-top: 14px;
  padding-bottom: 52px;
}
.io-youtube-track {
  height: clamp(250px, 30vw, 415px);
}
.io-youtube-slide h3 {
  margin-top: 10px;
}
.io-youtube-dots {
  bottom: 17px;
}
@media (max-width: 960px) {
  .io-youtube-track {
    height: clamp(240px, 44vw, 390px);
  }
}
@media (max-width: 720px) {
  .io-youtube-section .io-section-center {
    margin-bottom: 8px;
  }
  .io-youtube-slider {
    margin-top: 10px;
    padding-top: 10px;
    padding-bottom: 48px;
  }
  .io-youtube-track {
    height: clamp(205px, 60vw, 300px);
  }
  .io-youtube-slide h3 {
    margin-top: 8px;
    line-height: 1.35;
  }
  .io-youtube-dots {
    bottom: 20px;
  }
}


/* v4.3: Robust YouTube popup modal and double-click playback fix. */
.io-youtube-frame {
  position: relative;
}
.io-youtube-frame iframe {
  pointer-events: none;
}
.io-youtube-open {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: inherit;
  background: transparent;
  color: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.io-youtube-open:focus-visible {
  outline: 3px solid rgba(180, 123, 241, .9);
  outline-offset: 4px;
}
.io-youtube-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 24px;
  overscroll-behavior: contain;
}
.io-youtube-modal.is-open {
  display: flex;
}
.io-youtube-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(24, 10, 38, .78);
  backdrop-filter: blur(12px);
}
.io-youtube-modal-panel {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  width: min(1080px, 94vw);
  max-height: calc(100vh - 48px);
  max-height: calc(100dvh - 48px);
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 28px;
  background: rgba(255,255,255,.14);
  box-shadow: 0 30px 90px rgba(20, 8, 36, .42);
  overflow: hidden;
}
.io-youtube-modal-toolbar {
  position: relative;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 56px;
  padding: 10px 16px 10px 20px;
  background: rgba(255,255,255,.96);
  color: var(--io-purple-dark);
}
.io-youtube-modal-label {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .12em;
  line-height: 1;
}
.io-youtube-modal-close-text {
  display: inline-grid;
  place-items: center;
  min-width: 92px;
  min-height: 38px;
  padding: 9px 18px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #b47bf1, #f2b9f7);
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .08em;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(112, 58, 166, .24);
  touch-action: manipulation;
}
.io-youtube-modal-close-text:hover,
.io-youtube-modal-close-text:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.03);
}
.io-youtube-modal-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}
.io-youtube-modal-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.io-youtube-modal-close {
  position: absolute;
  top: 70px;
  right: 14px;
  z-index: 6;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: var(--io-purple-dark);
  font-size: 28px;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(25, 10, 40, .25);
}
.io-youtube-modal-close:hover,
.io-youtube-modal-close:focus-visible {
  background: #fff;
  transform: scale(1.04);
}
body.io-youtube-modal-open {
  overflow: hidden;
}
@media (max-width: 720px) {
  .io-youtube-modal {
    padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  }
  .io-youtube-modal-panel {
    width: 96vw;
    max-height: calc(100dvh - 20px);
    border-radius: 18px;
  }
  .io-youtube-modal-toolbar {
    min-height: 54px;
    padding: 9px 12px 9px 14px;
  }
  .io-youtube-modal-label {
    font-size: 12px;
  }
  .io-youtube-modal-close-text {
    min-width: 86px;
    min-height: 40px;
    padding: 9px 15px;
    font-size: 13px;
  }
  .io-youtube-modal-close {
    top: 66px;
    right: 10px;
    width: 40px;
    height: 40px;
    font-size: 24px;
  }
}


/* v4.5: Schedule reserve buttons default to gray and turn purple on hover. */
.io-schedule-card .io-button-fill {
  color: #fff;
  background: linear-gradient(135deg, #bfc0c8, #8f909a);
  box-shadow: 0 8px 18px rgba(90,90,100,.16);
}
.io-schedule-card .io-button-fill:hover,
.io-schedule-card .io-button-fill:focus-visible {
  color: #fff;
  background: linear-gradient(135deg, #b96bf1, #8c4bd6);
  box-shadow: 0 12px 24px rgba(146,77,219,.28);
}

/* v4.7: Movie heading layout and transparent YouTube carousel background. */
.io-youtube-heading {
  margin-bottom: 4px;
}
.io-youtube-heading-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
.io-youtube-heading-row .io-section-label {
  margin: 0;
}
.io-youtube-heading-row .io-section-title {
  margin: 0;
  font-size: clamp(18px, 2.2vw, 30px);
  line-height: 1.15;
  letter-spacing: .04em;
}
.io-youtube-section .io-youtube-desc {
  margin-top: 8px;
}
.io-youtube-section .io-youtube-slider {
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0;
}
@media (max-width: 720px) {
  .io-youtube-heading-row {
    gap: 8px;
  }
  .io-youtube-heading-row .io-section-title {
    font-size: clamp(16px, 4.4vw, 22px);
  }
  .io-youtube-section .io-youtube-desc {
    margin-top: 6px;
  }
}


/* v4.8: Make the SCHEDULE heading smaller. */
.io-schedule-section .io-section-label {
  font-size: clamp(20px, 2.4vw, 24px);
  line-height: 1.08;
}
.io-schedule-section .io-section-title {
  font-size: clamp(13px, 1.55vw, 16px);
  line-height: 1.2;
  margin-top: 2px;
}
@media (max-width: 720px) {
  .io-schedule-section .io-section-label {
    font-size: 20px;
  }
  .io-schedule-section .io-section-title {
    font-size: 11px;
    letter-spacing: .1em;
    margin-top: 1px;
  }
  .io-schedule-section .io-section-center {
    margin-bottom: 12px;
  }
}

/* v5.6 写真集・DVD表示調整：登録表紙を優先し、トップカードを約半分サイズへ */
.io-release-grid {
  grid-template-columns: repeat(auto-fit, minmax(170px, 220px));
  justify-content: center;
  align-items: start;
  gap: 18px;
}
.io-release-card {
  width: 100%;
  max-width: 220px;
  border-radius: 20px;
  box-shadow: 0 16px 34px rgba(128,65,194,.12);
}
.io-release-visual {
  aspect-ratio: 3/4;
}
.io-release-body {
  gap: 7px;
  padding: 13px 13px 15px;
}
.io-release-type {
  top: 10px;
  left: 10px;
  min-height: 24px;
  padding: 0 9px;
  font-size: 9px;
}
.io-release-catch {
  font-size: 10px;
}
.io-release-title {
  font-size: 15px;
  line-height: 1.45;
}
.io-release-meta {
  gap: 3px;
  font-size: 10px;
}
.io-release-meta span {
  gap: 8px;
  padding-top: 5px;
}
.io-release-meta b {
  font-size: 8px;
}
.io-release-excerpt {
  font-size: 10px;
  line-height: 1.65;
}
.io-release-actions {
  grid-template-columns: 1fr;
  gap: 7px;
}
.io-release-button {
  min-height: 34px;
  padding: 0 10px;
  font-size: 10px;
}
.io-release-no-cover {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  min-height: 180px;
  padding: 18px;
  color: #8d4ed6;
  background:
    radial-gradient(circle at 20% 20%, rgba(244,169,223,.18), transparent 8rem),
    linear-gradient(135deg, #f3eaff 0%, #fffaff 100%);
  font-family: var(--io-serif);
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  letter-spacing: .08em;
}
.io-release-detail-cover .io-release-no-cover {
  min-height: 420px;
}
@media (max-width: 900px) {
  .io-release-grid {
    grid-template-columns: repeat(auto-fit, minmax(160px, 210px));
  }
}
@media (max-width: 720px) {
  .io-release-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }
  .io-release-card {
    max-width: none;
    border-radius: 18px;
  }
  .io-release-visual {
    aspect-ratio: 3/4;
  }
  .io-release-body {
    padding: 12px;
  }
  .io-release-title {
    font-size: 14px;
  }
}
@media (max-width: 360px) {
  .io-release-grid {
    grid-template-columns: 1fr;
  }
  .io-release-card {
    max-width: 220px;
    margin: 0 auto;
  }
}


/* v5.8 写真集・DVD見出し下の説明文・カテゴリラベル削除に伴う余白調整 */
.io-release-section .io-section-center {
  margin-bottom: 8px;
}
.io-release-section .io-release-grid {
  margin-top: 10px;
}
@media (max-width: 720px) {
  .io-release-section .io-section-center {
    margin-bottom: 6px;
  }
  .io-release-section .io-release-grid {
    margin-top: 8px;
  }
}


/* v5.9 WORKS heading inline layout and jacket purchase link affordance */
.io-release-heading {
  margin-bottom: 4px;
}
.io-release-heading-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 12px;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.io-release-heading-row .io-section-label {
  display: inline-block;
  margin: 0;
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1.05;
}
.io-release-heading-row .io-section-title,
.io-release-heading-row .io-single-title {
  display: inline-block;
  margin: 0;
  color: #8d4ed6;
  font-family: var(--io-serif);
  font-size: clamp(13px, 1.5vw, 17px);
  line-height: 1.2;
  letter-spacing: .1em;
  font-weight: 800;
}
.io-release-visual[href] {
  cursor: pointer;
}
.io-release-visual[href]:focus-visible {
  outline: 3px solid rgba(180,123,241,.9);
  outline-offset: 4px;
}
@media (max-width: 720px) {
  .io-release-heading-row {
    gap: 8px;
  }
  .io-release-heading-row .io-section-label {
    font-size: 22px;
  }
  .io-release-heading-row .io-section-title,
  .io-release-heading-row .io-single-title {
    font-size: 12px;
    letter-spacing: .08em;
  }
}

/* v5.10 写真集・DVD：ゆっくり横スクロールするスライダー表示 */
.io-release-section {
  overflow: hidden;
}
.io-release-slider {
  position: relative;
  width: 100%;
  margin-top: 10px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.io-release-slider::before,
.io-release-slider::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 3;
  width: min(8vw, 72px);
  pointer-events: none;
}
.io-release-slider::before {
  left: 0;
  background: linear-gradient(90deg, #fffaff 0%, rgba(255,250,255,0) 100%);
}
.io-release-slider::after {
  right: 0;
  background: linear-gradient(270deg, #fffaff 0%, rgba(255,250,255,0) 100%);
}
.io-release-track {
  --release-gap: 18px;
  display: flex;
  align-items: stretch;
  width: max-content;
  animation: ioki-release-marquee 58s linear infinite;
  will-change: transform;
}
.io-release-loop {
  display: flex;
  align-items: stretch;
  gap: var(--release-gap);
  flex: 0 0 auto;
  padding-right: var(--release-gap);
}
.io-release-loop .io-release-card {
  flex: 0 0 clamp(156px, 18vw, 220px);
  max-width: none;
}
.io-release-slider:hover .io-release-track,
.io-release-slider:focus-within .io-release-track {
  animation-play-state: paused;
}
.io-release-card.is-clone {
  pointer-events: none;
}
@keyframes ioki-release-marquee {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}
@media (max-width: 720px) {
  .io-release-slider {
    margin-top: 8px;
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
  }
  .io-release-track {
    --release-gap: 12px;
    animation-duration: 46s;
  }
  .io-release-loop .io-release-card {
    flex-basis: clamp(146px, 44vw, 190px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .io-release-track {
    animation: none;
  }
  .io-release-slider {
    overflow-x: auto;
    -webkit-mask-image: none;
    mask-image: none;
    scrollbar-width: thin;
  }
}

/* v5.12: WORKS / MOVIE sliders support touch swipe and mouse drag. WORKS loops endlessly and shows about 3 covers on smartphones. */
.io-release-slider {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-y;
  cursor: grab;
  user-select: none;
  scrollbar-width: none;
}
.io-release-slider::-webkit-scrollbar {
  display: none;
}
.io-release-slider.is-dragging {
  cursor: grabbing;
}
.io-release-slider.is-dragging .io-release-track,
.io-release-slider.is-dragging .io-release-card,
.io-release-slider.is-dragging .io-release-visual img {
  transition: none !important;
}
.io-release-track {
  animation: none !important;
  transform: none !important;
}
.io-release-card.is-clone {
  pointer-events: auto;
}
.io-youtube-slider {
  --io-yt-drag-x: 0px;
  touch-action: pan-y;
  cursor: grab;
  user-select: none;
}
.io-youtube-slider.is-dragging {
  cursor: grabbing;
}
.io-youtube-slider.is-dragging .io-youtube-slide {
  transition-duration: .18s !important;
}
.io-youtube-slider.is-dragging .io-youtube-slide.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-center {
  transform: translate(calc(-50% + var(--io-yt-drag-x)), 0) scale(1);
}
.io-youtube-slider.is-dragging .io-youtube-slide.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-left {
  transform: translate(calc(-124% + var(--io-yt-drag-x)), 24px) scale(.72);
}
.io-youtube-slider.is-dragging .io-youtube-slide.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-right {
  transform: translate(calc(24% + var(--io-yt-drag-x)), 24px) scale(.72);
}
@media (max-width: 960px) {
  .io-youtube-slider.is-dragging .io-youtube-slide.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-left {
    transform: translate(calc(-112% + var(--io-yt-drag-x)), 20px) scale(.72);
  }
  .io-youtube-slider.is-dragging .io-youtube-slide.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-right {
    transform: translate(calc(12% + var(--io-yt-drag-x)), 20px) scale(.72);
  }
}
@media (max-width: 720px) {
  .io-release-track {
    --release-gap: 8px;
  }
  .io-release-loop {
    gap: var(--release-gap);
    padding-right: var(--release-gap);
  }
  .io-release-loop .io-release-card {
    flex: 0 0 clamp(94px, calc((100vw - 52px) / 3), 122px);
    border-radius: 15px;
  }
  .io-release-visual {
    aspect-ratio: 4 / 5;
  }
  .io-release-type {
    top: 7px;
    left: 7px;
    min-height: 19px;
    padding: 0 7px;
    font-size: 7px;
    letter-spacing: .04em;
  }
  .io-release-body {
    gap: 5px;
    padding: 8px 8px 9px;
  }
  .io-release-catch,
  .io-release-excerpt {
    display: none;
  }
  .io-release-title {
    font-size: 11px;
    line-height: 1.32;
    letter-spacing: .02em;
  }
  .io-release-meta {
    gap: 3px;
    font-size: 9px;
  }
  .io-release-meta span {
    display: block;
    padding-top: 4px;
  }
  .io-release-meta b {
    display: block;
    margin-bottom: 1px;
    font-size: 7px;
  }
  .io-release-actions {
    margin-top: 1px;
  }
  .io-release-button {
    min-height: 26px;
    padding: 0 7px;
    font-size: 8px;
  }
  .io-youtube-slider.is-dragging .io-youtube-slide.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-left,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-left {
    transform: translate(calc(-112% + var(--io-yt-drag-x)), 16px) scale(.70);
  }
  .io-youtube-slider.is-dragging .io-youtube-slide.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-right,
  .io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-right {
    transform: translate(calc(12% + var(--io-yt-drag-x)), 16px) scale(.70);
  }
}

/* v5.12: スマホ指スワイプの追従性改善。WORKSはネイティブ慣性スクロール、MOVIEは遅延のないドラッグ追従に調整。 */
.io-release-slider {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x pan-y;
  scroll-behavior: auto;
  scroll-snap-type: none;
  contain: layout paint;
  will-change: scroll-position;
  -webkit-tap-highlight-color: transparent;
}
.io-release-track,
.io-release-loop,
.io-release-card,
.io-release-visual,
.io-release-cover,
.io-youtube-slider,
.io-youtube-track,
.io-youtube-slide,
.io-youtube-frame,
.io-youtube-open {
  -webkit-user-select: none;
  user-select: none;
}
.io-release-cover,
.io-youtube-frame iframe {
  -webkit-user-drag: none;
  user-drag: none;
}
.io-release-slider.is-dragging {
  scroll-snap-type: none;
}
.io-youtube-slider {
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.io-youtube-slider.is-dragging .io-youtube-slide,
.io-youtube-slider.is-dragging .io-youtube-slide.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-center,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-left,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-left.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-right.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.io-slide-up.is-right,
.io-youtube-slider.is-dragging .io-youtube-slide.io-reveal.is-visible.is-right {
  transition: none !important;
}

/* v5.13: WORKS loop seam fix and tablet visibility fix. */
.io-release-section,
.io-release-section .io-container,
.io-release-heading,
.io-release-slider,
.io-release-track,
.io-release-loop,
.io-release-loop .io-release-card {
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-slider {
  display: block !important;
  position: relative;
  min-height: 1px;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  contain: content;
}
.io-release-track {
  display: flex !important;
  align-items: stretch !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: none !important;
  animation: none !important;
}
.io-release-loop {
  display: flex !important;
  align-items: stretch !important;
  flex: 0 0 auto !important;
  min-width: max-content;
}
.io-release-loop .io-release-card {
  display: block !important;
  flex-shrink: 0 !important;
}
.io-release-card.is-clone {
  pointer-events: auto !important;
}
@media (min-width: 768px) and (max-width: 1180px) {
  .io-release-slider {
    margin-top: 10px;
    padding: 0 2px;
  }
  .io-release-track {
    --release-gap: 14px;
  }
  .io-release-loop {
    gap: var(--release-gap);
    padding-right: var(--release-gap);
  }
  .io-release-loop .io-release-card {
    flex-basis: clamp(132px, 17vw, 176px) !important;
    border-radius: 20px;
  }
  .io-release-body {
    padding: 14px 14px 16px;
  }
  .io-release-title {
    font-size: 16px;
  }
  .io-release-meta {
    font-size: 10px;
  }
  .io-release-button {
    min-height: 34px;
    font-size: 10px;
  }
}
@media (max-width: 767px) {
  .io-release-slider {
    display: block !important;
    margin-top: 8px;
    padding: 0 1px;
  }
  .io-release-track {
    --release-gap: 8px;
  }
  .io-release-loop {
    gap: var(--release-gap);
    padding-right: var(--release-gap);
  }
  .io-release-loop .io-release-card {
    flex-basis: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
  }
}

/* v5.14: WORKS auto scroll restore. JS-driven loop, touch-native swipe, tablet-safe visibility. */
.io-release-slider {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scroll-behavior: auto !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x pan-y;
}
.io-release-track {
  display: flex !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: none !important;
  animation: none !important;
  will-change: auto;
}
.io-release-loop {
  flex: 0 0 auto !important;
}
.io-release-slider.is-dragging {
  cursor: grabbing;
}


/* v5.15: compact contact-to-footer spacing. */
.io-section#goods { padding-bottom: 20px !important; }
.io-footer { padding-top: 22px !important; }
@media (max-width: 767px) {
  .io-section#goods { padding-bottom: 18px !important; }
  .io-footer { padding-top: 18px !important; }
}


/* v5.16: WORKS slider seam/autoplay stabilization. JS controls motion; CSS keeps every clone visible and prevents tablet hiding. */
.io-release-slider {
  display: block !important;
  position: relative !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior-x: contain !important;
  touch-action: pan-x pan-y !important;
  scroll-behavior: auto !important;
  scroll-snap-type: none !important;
  scrollbar-width: none !important;
  cursor: grab;
  contain: layout paint !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-slider::-webkit-scrollbar { display: none !important; }
.io-release-slider.is-dragging { cursor: grabbing; }
.io-release-track {
  --release-gap: 14px;
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: none !important;
  animation: none !important;
  will-change: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop {
  display: flex !important;
  align-items: stretch !important;
  flex: 0 0 auto !important;
  gap: var(--release-gap) !important;
  padding-right: var(--release-gap) !important;
  min-width: max-content !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop .io-release-card {
  display: block !important;
  flex: 0 0 clamp(132px, 15vw, 190px) !important;
  max-width: none !important;
  flex-shrink: 0 !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-card.is-clone,
.io-release-loop.is-clone-loop {
  visibility: visible !important;
  opacity: 1 !important;
}
@media (min-width: 768px) and (max-width: 1180px) {
  .io-release-track { --release-gap: 12px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(122px, 16vw, 168px) !important;
    border-radius: 20px;
  }
}
@media (max-width: 767px) {
  .io-release-track { --release-gap: 8px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
    border-radius: 15px;
  }
}

/* v5.17: WORKS slider final loop/autoplay fix. Transform-driven infinite marquee removes seam blanks and keeps drag/swipe smooth. */
.io-release-slider {
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
  -webkit-overflow-scrolling: auto !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
  cursor: grab !important;
  user-select: none !important;
  contain: layout paint !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-slider.is-dragging {
  cursor: grabbing !important;
}
.io-release-track {
  --release-gap: 14px;
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  transform: translate3d(0, 0, 0);
  animation: none !important;
  transition: none !important;
  will-change: transform !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop {
  display: flex !important;
  align-items: stretch !important;
  flex: 0 0 auto !important;
  gap: var(--release-gap) !important;
  padding-right: var(--release-gap) !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop .io-release-card {
  display: block !important;
  flex: 0 0 clamp(132px, 15vw, 190px) !important;
  width: clamp(132px, 15vw, 190px) !important;
  max-width: none !important;
  flex-shrink: 0 !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop.is-clone-loop,
.io-release-card.is-clone {
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-card.is-clone {
  pointer-events: auto !important;
}
.io-release-slider::before,
.io-release-slider::after {
  display: none !important;
}
.io-release-cover,
.io-release-visual img {
  -webkit-user-drag: none !important;
  user-drag: none !important;
  pointer-events: none;
}
.io-release-visual {
  pointer-events: auto;
}
@media (min-width: 768px) and (max-width: 1180px) {
  .io-release-track { --release-gap: 12px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(122px, 16vw, 168px) !important;
    width: clamp(122px, 16vw, 168px) !important;
    border-radius: 20px;
  }
}
@media (max-width: 767px) {
  .io-release-track { --release-gap: 8px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
    width: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
    border-radius: 15px;
  }
}


/* v5.18: WORKS slider emergency repair.
   Root cause: older rules kept .io-release-track at transform:none!important, so JS transform could not move it.
   This block restores movement, removes unwanted blur/fade, and keeps touch/mouse drag available. */
.io-release-section .io-release-card.io-reveal,
.io-release-section .io-release-card.io-reveal.is-visible,
.io-release-section .io-release-card.io-reveal.io-slide-left,
.io-release-section .io-release-card.io-reveal.io-slide-right,
.io-release-section .io-release-card.io-reveal.io-slide-up,
.io-release-section .io-release-card.io-reveal.is-visible.io-slide-left,
.io-release-section .io-release-card.io-reveal.is-visible.io-slide-right,
.io-release-section .io-release-card.io-reveal.is-visible.io-slide-up {
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
  animation: none !important;
}
.io-release-slider {
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  touch-action: pan-y !important;
  cursor: grab !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-slider.is-dragging {
  cursor: grabbing !important;
}
.io-release-slider::before,
.io-release-slider::after {
  display: none !important;
  content: none !important;
  opacity: 0 !important;
}
.io-release-track {
  --io-release-translate-x: 0px;
  --release-gap: 14px;
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  animation: none !important;
  transition: none !important;
  transform: translate3d(var(--io-release-translate-x), 0, 0) !important;
  will-change: transform !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop {
  display: flex !important;
  align-items: stretch !important;
  flex: 0 0 auto !important;
  gap: var(--release-gap) !important;
  padding-right: var(--release-gap) !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop .io-release-card {
  display: block !important;
  flex: 0 0 clamp(132px, 15vw, 190px) !important;
  width: clamp(132px, 15vw, 190px) !important;
  max-width: none !important;
  flex-shrink: 0 !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-loop.is-clone-loop,
.io-release-card.is-clone {
  visibility: visible !important;
  opacity: 1 !important;
}
.io-release-card.is-clone {
  pointer-events: auto !important;
}
.io-release-cover,
.io-release-visual img {
  -webkit-user-drag: none !important;
  user-drag: none !important;
  pointer-events: none !important;
}
.io-release-visual,
.io-release-title a,
.io-release-button {
  pointer-events: auto !important;
}
@media (min-width: 768px) and (max-width: 1180px) {
  .io-release-track { --release-gap: 12px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(122px, 16vw, 168px) !important;
    width: clamp(122px, 16vw, 168px) !important;
    border-radius: 20px;
  }
}
@media (max-width: 767px) {
  .io-release-track { --release-gap: 8px; }
  .io-release-loop .io-release-card {
    flex-basis: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
    width: clamp(94px, calc((100vw - 52px) / 3), 122px) !important;
    border-radius: 15px;
  }
}


/* v5.19: WORKS card overflow repair for tablet/small-card widths.
   Long product names and CTA buttons are now constrained inside each card. */
.io-release-loop .io-release-card,
.io-release-card {
  overflow: hidden !important;
  box-sizing: border-box !important;
}
.io-release-body {
  min-width: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.io-release-title,
.io-release-title a {
  display: block !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-break: anywhere !important;
  box-sizing: border-box !important;
}
.io-release-title a {
  color: inherit !important;
  text-decoration: none !important;
}
.io-release-meta,
.io-release-meta span {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow-wrap: anywhere !important;
}
.io-release-actions {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.io-release-button {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
@media (min-width: 768px) and (max-width: 1180px) {
  .io-release-body {
    padding: 12px 11px 14px !important;
    gap: 6px !important;
  }
  .io-release-title {
    font-size: 14px !important;
    line-height: 1.38 !important;
    letter-spacing: .015em !important;
  }
  .io-release-meta {
    font-size: 9px !important;
    gap: 3px !important;
  }
  .io-release-meta span {
    gap: 5px !important;
  }
  .io-release-button {
    min-height: 31px !important;
    padding: 0 8px !important;
    font-size: 9px !important;
  }
}
@media (max-width: 767px) {
  .io-release-body {
    padding: 10px 8px 12px !important;
    gap: 5px !important;
  }
  .io-release-title {
    font-size: 11px !important;
    line-height: 1.35 !important;
    letter-spacing: 0 !important;
  }
  .io-release-meta {
    font-size: 8px !important;
    gap: 2px !important;
  }
  .io-release-meta span {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 2px !important;
    justify-content: start !important;
  }
  .io-release-meta b {
    font-size: 7px !important;
  }
  .io-release-button {
    min-height: 28px !important;
    padding: 0 6px !important;
    font-size: 8px !important;
  }
}

/* v5.23: lightweight paper-frame top-page loader and safe YouTube carousel.
   Loader uses animated WebP/GIF plus stepped CSS motion so the chibi visibly moves like kamishibai. */
.io-page-loader {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at 50% 38%, rgba(255,255,255,.88), rgba(244,232,255,.84) 34%, rgba(238,224,255,.96) 72%),
    linear-gradient(135deg, #f7edff, #fff7fb);
  opacity: 1;
  visibility: visible;
  transition: opacity .48s ease, visibility .48s ease;
}
.io-page-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.io-page-loader-card {
  position: relative;
  width: min(58vw, 360px);
  max-width: 360px;
  transform-origin: 50% 68%;
  animation: io-loader-kamishibai 1.12s steps(1, end) infinite;
  filter: drop-shadow(0 18px 36px rgba(133, 84, 166, .18));
  will-change: transform;
}
.io-page-loader-card::before,
.io-page-loader-card::after {
  content: '';
  position: absolute;
  z-index: 2;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,.96) 0 26%, rgba(180,123,241,.62) 28% 35%, transparent 38%);
  pointer-events: none;
  animation: io-loader-sparkle 1.12s steps(1, end) infinite;
}
.io-page-loader-card::before {
  left: 18%;
  top: 27%;
}
.io-page-loader-card::after {
  right: 15%;
  top: 18%;
  animation-delay: .28s;
}
.io-page-loader-card picture,
.io-page-loader-card img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  -webkit-user-drag: none;
}
@keyframes io-loader-kamishibai {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg) scale(1); }
  12.5% { transform: translate3d(-3px, -7px, 0) rotate(-1.4deg) scale(1.012); }
  25% { transform: translate3d(-5px, -12px, 0) rotate(-2.4deg) scale(1.018); }
  37.5% { transform: translate3d(-2px, -8px, 0) rotate(-1deg) scale(1.01); }
  50% { transform: translate3d(0, 0, 0) rotate(0deg) scale(1); }
  62.5% { transform: translate3d(3px, -7px, 0) rotate(1.4deg) scale(1.012); }
  75% { transform: translate3d(5px, -12px, 0) rotate(2.4deg) scale(1.018); }
  87.5% { transform: translate3d(2px, -8px, 0) rotate(1deg) scale(1.01); }
}
@keyframes io-loader-sparkle {
  0%, 100% { opacity: .28; transform: scale(.76) rotate(0deg); }
  25% { opacity: .95; transform: scale(1.16) rotate(18deg); }
  50% { opacity: .42; transform: scale(.86) rotate(0deg); }
  75% { opacity: .88; transform: scale(1.04) rotate(-18deg); }
}
.io-youtube-thumb,
.io-youtube-preview {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
  transform: scale(1.01);
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}
.io-youtube-preview {
  display: block;
  background: #efe1ff;
}
.io-youtube-frame::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.08), transparent 28%),
    linear-gradient(180deg, rgba(48, 20, 70, .08), rgba(48, 20, 70, .18));
  pointer-events: none;
}
.io-youtube-open::before {
  content: '▶';
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 6;
  display: grid;
  place-items: center;
  width: clamp(52px, 8vw, 78px);
  height: clamp(52px, 8vw, 78px);
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, #ff6b8a, #b05ff1);
  box-shadow: 0 14px 34px rgba(118, 54, 160, .32);
  font-size: clamp(21px, 3vw, 31px);
  text-indent: .12em;
  transform: translate(-50%, -50%);
  transition: transform .22s ease, box-shadow .22s ease;
}
.io-youtube-open:hover::before,
.io-youtube-open:focus-visible::before {
  transform: translate(-50%, -50%) scale(1.06);
  box-shadow: 0 18px 42px rgba(118, 54, 160, .38);
}
.io-youtube-slide:not(.is-center) .io-youtube-open::before {
  transform: translate(-50%, -50%) scale(.82);
  opacity: .86;
}
.io-youtube-slide:not(.is-center) .io-youtube-open:hover::before,
.io-youtube-slide:not(.is-center) .io-youtube-open:focus-visible::before {
  transform: translate(-50%, -50%) scale(.9);
}
@media (max-width: 767px) {
  .io-page-loader-card {
    width: min(74vw, 300px);
  }
  .io-youtube-open::before {
    width: 54px;
    height: 54px;
    font-size: 22px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .io-page-loader-card,
  .io-page-loader-card::before,
  .io-page-loader-card::after { animation: none; }
}


/* v5.24: PC playback click fix for MOVIE.  Keep the play layer above preview video and outside drag interference. */
.io-youtube-open {
  z-index: 12 !important;
  pointer-events: auto !important;
  touch-action: manipulation;
}
.io-youtube-frame::after {
  z-index: 3;
}
.io-youtube-thumb,
.io-youtube-preview {
  z-index: 1;
}
.io-youtube-slide.is-center .io-youtube-open {
  cursor: pointer;
}

/* v5.25: Mobile/tablet YouTube modal close fix. Keep a visible close bar outside the iframe and prevent iframe fullscreen lock. */

/* v5.26: Fix MOVIE popup viewport positioning and use the real animated loader frames. */
.io-page-loader-card {
  animation: none !important;
}
.io-page-loader-card picture,
.io-page-loader-card img {
  transform: none !important;
}

html.io-youtube-modal-open,
body.io-youtube-modal-open {
  overflow: hidden !important;
  overscroll-behavior: none;
}
.io-youtube-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483000 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(16px, 3vw, 32px) !important;
  transform: none !important;
  filter: none !important;
  opacity: 1 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  touch-action: none;
}
.io-youtube-modal.is-open {
  display: flex !important;
}
.io-youtube-modal-backdrop {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(24, 10, 38, .82) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.io-youtube-modal-panel {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  width: min(960px, calc(100vw - 48px)) !important;
  max-width: 960px !important;
  max-height: calc(100vh - 48px) !important;
  max-height: calc(100dvh - 48px) !important;
  margin: 0 !important;
  transform: none !important;
  filter: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  overflow: hidden !important;
  background: rgba(255,255,255,.98) !important;
  border: 1px solid rgba(255,255,255,.52) !important;
  border-radius: 24px !important;
  box-shadow: 0 30px 90px rgba(20, 8, 36, .44) !important;
}
.io-youtube-modal-toolbar {
  flex: 0 0 auto !important;
  position: relative !important;
  z-index: 4 !important;
  background: rgba(255,255,255,.98) !important;
}
.io-youtube-modal-frame {
  flex: 0 1 auto !important;
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  max-height: calc(100dvh - 116px) !important;
  background: #000 !important;
  overflow: hidden !important;
}
.io-youtube-modal-frame iframe {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
}
.io-youtube-modal-close {
  z-index: 5 !important;
}
@media (max-width: 720px) {
  .io-youtube-modal {
    align-items: center !important;
    justify-content: center !important;
    padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left)) !important;
  }
  .io-youtube-modal-panel {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    border-radius: 18px !important;
  }
  .io-youtube-modal-frame {
    max-height: calc(100dvh - 92px) !important;
  }
  .io-youtube-modal-close {
    top: 62px !important;
    right: 8px !important;
  }
}


/* v5.27: Admin-selectable full-screen loading GIF. */
.io-page-loader {
  padding: 0 !important;
  overflow: hidden !important;
  background: #f3e8ff !important;
}
.io-page-loader-card {
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  max-width: none !important;
  display: block !important;
  filter: none !important;
  border-radius: 0 !important;
  animation: none !important;
}
.io-page-loader-card img,
.io-page-loader-card picture {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: var(--io-loader-fit, cover) !important;
  object-position: center center !important;
  transform: none !important;
  user-select: none;
  -webkit-user-drag: none;
}
.io-page-loader-card::before,
.io-page-loader-card::after {
  display: none !important;
}


/* v5.29: PC click repair for WORKS purchase links.
   Some desktop browsers can treat a click inside the transformed drag slider as drag/slider interaction.
   Keep the normal anchor hrefs, but force purchase links to open reliably when the pointer did not move. */
.io-release-slider a.io-release-visual[href],
.io-release-slider .io-release-title a[href],
.io-release-slider .io-release-button[href] {
  pointer-events: auto !important;
  cursor: pointer !important;
}
.io-release-slider.is-dragging a.io-release-visual[href],
.io-release-slider.is-dragging .io-release-title a[href],
.io-release-slider.is-dragging .io-release-button[href] {
  cursor: grabbing !important;
}


/* v5.30: WORKS purchase links must remain native clickable on desktop.
   Navigation is handled by each anchor href; JS only suppresses clicks after real drag. */
.io-release-slider a.io-release-visual[href],
.io-release-slider .io-release-title a[href],
.io-release-slider .io-release-button[href] {
  position: relative !important;
  z-index: 6 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
  touch-action: manipulation !important;
}
.io-release-slider .io-release-visual img,
.io-release-slider .io-release-cover {
  pointer-events: none !important;
}


/* v5.32: WORKS mobile/tablet swipe repair.
   Touch devices use browser-native horizontal scrolling, so finger swipe regains iOS/Android inertia.
   Desktop keeps the transform marquee for stable autoplay and reliable purchase-link clicks. */
@media (hover: none), (pointer: coarse) {
  .io-release-slider,
  .io-release-slider.is-native-scroll {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: contain !important;
    touch-action: pan-x pan-y !important;
    scroll-behavior: auto !important;
    cursor: default !important;
    contain: layout paint !important;
  }
  .io-release-slider.is-native-scroll .io-release-track {
    transform: translate3d(0, 0, 0) !important;
    will-change: auto !important;
  }
  .io-release-slider.is-native-scroll .io-release-loop,
  .io-release-slider.is-native-scroll .io-release-card,
  .io-release-slider.is-native-scroll .io-release-visual,
  .io-release-slider.is-native-scroll .io-release-title a,
  .io-release-slider.is-native-scroll .io-release-button {
    touch-action: manipulation !important;
  }
}


/* v5.34: schedule reservation start / sold out button states, sold-out links stay active */
.io-button-fill.is-before-reserve,
.io-next-button.is-before-reserve,
.io-contact-button.is-before-reserve {
  color: #e6002d !important;
  background: #fff !important;
  border: 2px solid #ff9caf !important;
  box-shadow: 0 8px 18px rgba(230, 0, 45, .10) !important;
  cursor: default;
  pointer-events: none;
  line-height: 1.35;
  text-align: center;
}
.io-button-fill.is-sold-out,
.io-next-button.is-sold-out,
.io-contact-button.is-sold-out {
  color: #fff !important;
  background: linear-gradient(135deg, #f04444, #c8192e) !important;
  border: 2px solid #c8192e !important;
  box-shadow: 0 10px 22px rgba(200, 25, 46, .24) !important;
  cursor: pointer;
}
.io-button-fill.is-sold-out.is-disabled,
.io-next-button.is-sold-out.is-disabled,
.io-contact-button.is-sold-out.is-disabled {
  cursor: default;
  pointer-events: none;
}
.io-button-fill.is-disabled,
.io-next-button.is-disabled,
.io-contact-button.is-disabled {
  text-decoration: none;
}
.io-schedule-card .io-button-fill.is-before-reserve {
  min-height: 40px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: 12px;
  white-space: normal;
}
.io-next-button.is-before-reserve,
.io-next-button.is-sold-out {
  margin-top: 24px;
}
.ioki-admin-reserve-start-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-top: 8px;
}
.ioki-admin-reserve-start-grid input {
  width: 100%;
  min-width: 0;
}
.ioki-admin-checkbox-field label {
  display: flex;
  gap: 7px;
  align-items: flex-start;
}
.ioki-admin-checkbox-field input[type="checkbox"] {
  margin-top: 2px;
}

/* v5.36: Official news detail/archive display fix. */
.io-news-detail-box { max-width: 900px; }
.io-news-detail-head { text-align: center; }
.io-news-detail-meta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; margin-top: 8px; color: #806098; font-weight: 900; }
.io-news-detail-meta em { display: inline-flex; align-items: center; justify-content: center; min-height: 22px; padding: 3px 9px; border-radius: 999px; color: #fff; background: linear-gradient(135deg, #a36be6, #c08af4); font-size: 11px; font-style: normal; letter-spacing: .06em; }
.io-news-detail-image { margin: 28px auto 0; overflow: hidden; border-radius: 12px; border: 1px solid #eadcf9; box-shadow: 0 18px 44px rgba(128,65,194,.16); }
.io-news-detail-image img { display: block; width: 100%; height: auto; }
.io-news-detail-content { max-width: 760px; margin: 30px auto 0; line-height: 2; }
.io-news-detail-content img { max-width: 100%; height: auto; border-radius: 10px; }
.io-news-detail-content h2,
.io-news-detail-content h3 { color: #7336ac; font-family: var(--io-serif); line-height: 1.5; }
.io-single-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 34px; }
.io-single-actions .io-button-line,
.io-single-actions .io-button-fill { min-width: 180px; padding: 0 22px; text-decoration: none; }
.io-archive-lead { margin: 10px 0 26px; color: #806098; font-size: 14px; font-weight: 900; line-height: 1.8; }
.io-news-archive-list { margin-top: 18px; }
.io-pagination { margin-top: 28px; text-align: center; }
.io-pagination .nav-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.io-pagination a,
.io-pagination span { display: inline-grid; place-items: center; min-width: 34px; min-height: 34px; padding: 0 12px; border: 1px solid #eadcf9; border-radius: 999px; color: #8d4ed6; background: #fff; font-weight: 900; text-decoration: none; }
.io-pagination .current { color: #fff; background: linear-gradient(135deg, #a36be6, #c08af4); }
@media (max-width: 720px) {
  .io-news-detail-meta { flex-wrap: wrap; }
  .io-news-detail-content { font-size: 15px; line-height: 1.9; }
  .io-single-actions { display: grid; grid-template-columns: 1fr; }
  .io-single-actions .io-button-line,
  .io-single-actions .io-button-fill { width: 100%; }
}


/* v5.37: Detail pages refined after major-idol news layout reference. */
.io-detail-page {
  padding: 118px 0 76px;
  background:
    radial-gradient(circle at top left, rgba(231,209,255,.42), transparent 32%),
    linear-gradient(180deg, #fff 0%, #fff 64%, #fbf7ff 100%);
}
.io-detail-container {
  width: min(860px, calc(100% - 38px));
  margin: 0 auto;
  color: #2e2440;
}
.io-detail-header {
  text-align: left;
  margin: 0 0 30px;
}
.io-detail-date {
  display: block;
  color: #7b3cc4;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(17px, 2.2vw, 22px);
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.35;
}
.io-detail-category {
  margin-top: 13px;
  color: #8f7c9e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .16em;
  line-height: 1;
  text-transform: uppercase;
}
.io-detail-title {
  margin: 24px 0 0;
  color: #24172f;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(27px, 4.2vw, 45px);
  font-weight: 900;
  line-height: 1.38;
  letter-spacing: .02em;
  word-break: auto-phrase;
  overflow-wrap: anywhere;
}
.io-detail-lead {
  margin: 18px 0 0;
  color: #6f577e;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.9;
}
.io-detail-visual {
  margin: 0 0 36px;
  padding: 0;
  overflow: hidden;
  border-radius: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}
.io-detail-visual img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0;
}
.io-detail-release-cover {
  width: min(520px, 100%);
  margin-inline: auto;
}
.io-detail-content {
  max-width: 760px;
  margin: 0;
  color: #30263c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 2.05;
  letter-spacing: .02em;
}
.io-detail-content p {
  margin: 0 0 1.28em;
}
.io-detail-content a {
  color: #7d36c2;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}
.io-detail-content img {
  max-width: 100%;
  height: auto;
  margin: 10px 0;
}
.io-detail-content h2,
.io-detail-content h3 {
  margin: 2em 0 .8em;
  color: #24172f;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  line-height: 1.5;
}
.io-detail-data {
  margin: 0 0 28px;
  border-top: 1px solid rgba(134,92,174,.18);
  border-bottom: 1px solid rgba(134,92,174,.18);
}
.io-detail-data div {
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 18px;
  padding: 15px 0;
  border-bottom: 1px solid rgba(134,92,174,.12);
}
.io-detail-data div:last-child { border-bottom: none; }
.io-detail-data dt {
  color: #9a67d2;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .14em;
}
.io-detail-data dd {
  margin: 0;
  color: #2f2638;
  font-weight: 700;
}
.io-detail-note {
  margin: 0 0 26px;
  padding: 0;
  border: none;
  background: transparent;
  color: #30263c;
  font-weight: 500;
  line-height: 2.05;
  box-shadow: none;
}
.io-detail-cta-wrap {
  margin-top: 30px;
}
.io-detail-cta,
.io-detail-content .io-detail-cta,
.io-detail-content .io-contact-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-width: 220px;
  min-height: 52px;
  padding: 0 26px;
  border-radius: 999px;
  border: 1px solid #d7c2ec;
  color: #fff;
  background: linear-gradient(135deg, #a467e6, #7d3bc4);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .08em;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(126,58,195,.18);
}
.io-detail-cta span,
.io-detail-content .io-contact-button span { margin-left: 8px; }
.io-detail-share {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 46px 0 0;
  padding-top: 22px;
  border-top: 1px solid rgba(134,92,174,.18);
  color: #24172f;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
}
.io-detail-share a {
  display: inline-grid;
  place-items: center;
  min-width: 42px;
  min-height: 30px;
  padding: 0 12px;
  border: 1px solid rgba(134,92,174,.22);
  border-radius: 999px;
  color: #7b3cc4;
  background: #fff;
  font-size: 11px;
  font-weight: 900;
  text-decoration: none;
  letter-spacing: .05em;
}
.io-detail-back {
  margin-top: 44px;
}
.io-detail-back a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 138px;
  min-height: 44px;
  padding: 0 25px;
  border: 1px solid rgba(134,92,174,.24);
  border-radius: 999px;
  color: #5b3b75;
  background: #fff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .18em;
  text-decoration: none;
}
.io-detail-back a::before {
  content: "‹";
  margin-right: 9px;
  font-size: 18px;
  line-height: 1;
}
.io-detail-news .io-single-box,
.io-detail-schedule .io-single-box,
.io-detail-release .io-single-box { box-shadow: none; }
@media (max-width: 720px) {
  .io-detail-page {
    padding: 96px 0 58px;
  }
  .io-detail-container {
    width: min(100% - 28px, 860px);
  }
  .io-detail-header {
    margin-bottom: 24px;
  }
  .io-detail-category {
    margin-top: 10px;
    font-size: 12px;
  }
  .io-detail-title {
    margin-top: 18px;
    font-size: clamp(24px, 7.4vw, 34px);
    line-height: 1.42;
  }
  .io-detail-visual {
    margin-bottom: 28px;
  }
  .io-detail-content {
    font-size: 15px;
    line-height: 1.95;
  }
  .io-detail-data div {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 14px 0;
  }
  .io-detail-cta,
  .io-detail-content .io-detail-cta,
  .io-detail-content .io-contact-button {
    width: 100%;
    min-width: 0;
  }
  .io-detail-share {
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 38px;
  }
  .io-detail-back a {
    width: 100%;
  }
}

/* v5.39: Tighten the NEWS date-to-category spacing on the top page. */
.io-news-row {
  grid-template-columns: 88px 70px minmax(0, 1fr) 18px;
  column-gap: 8px;
}
@media (max-width: 720px) {
  .io-news-row {
    grid-template-columns: 72px 58px minmax(0, 1fr) 12px;
    column-gap: 6px;
  }
  .io-news-row time {
    letter-spacing: -0.02em;
  }
}
@media (max-width: 420px) {
  .io-news-row {
    grid-template-columns: 70px 56px minmax(0, 1fr) 10px;
    column-gap: 5px;
  }
  .io-news-row em {
    padding-inline: 6px;
  }
}

/* v6.04: Aggressively tighten NEWS date-to-category spacing on the top page. */
.io-news-row {
  grid-template-columns: 82px 64px minmax(0, 1fr) 16px !important;
  column-gap: 4px !important;
}
.io-news-row time {
  white-space: nowrap;
  letter-spacing: -0.04em;
}
.io-news-row em {
  min-width: 0;
  width: auto;
  justify-self: start;
  padding-inline: 6px;
}
@media (max-width: 720px) {
  .io-news-row {
    grid-template-columns: 66px 52px minmax(0, 1fr) 10px !important;
    column-gap: 3px !important;
  }
  .io-news-row time {
    letter-spacing: -0.06em;
  }
  .io-news-row em {
    padding-inline: 5px;
  }
}
@media (max-width: 420px) {
  .io-news-row {
    grid-template-columns: 64px 50px minmax(0, 1fr) 8px !important;
    column-gap: 2px !important;
  }
  .io-news-row em {
    padding-inline: 5px;
  }
}
@media (max-width: 380px) {
  .io-news-row {
    grid-template-columns: 61px 48px minmax(0, 1fr) 8px !important;
    column-gap: 2px !important;
  }
}

/* v6.04: Restore v5.40 schedule card design and show portrait thumbnails from the top. */
.io-schedule-card:not(.io-schedule-card-overlay) .io-thumb img,
.io-schedule-card .io-thumb img {
  object-position: center top !important;
}
.io-schedule-card:not(.io-schedule-card-overlay) .io-thumb {
  background-position: center top !important;
}

/* v6.04: Site-wide constellation background, based on stable v5.45 design. */
body {
  background-color: #fffafe !important;
  background-image:
    image-set(
      url("assets/images/site-bg-constellation.webp") type("image/webp"),
      url("assets/images/site-bg-constellation.png") type("image/png")
    ) !important;
  background-repeat: repeat-y !important;
  background-position: center top !important;
  background-size: 100% auto !important;
}

/* Keep page sections visually connected so WORKS and MOVIE do not split harshly. */
.io-section,
.io-single,
.io-archive,
.io-main {
  background-color: transparent !important;
}

.io-works-section,
.io-movie-section {
  background: transparent !important;
}

/* Add a soft bridge between WORKS and MOVIE without changing card layouts. */
.io-works-section {
  position: relative;
  padding-bottom: clamp(28px, 4vw, 58px) !important;
}

.io-movie-section {
  position: relative;
  padding-top: clamp(28px, 4vw, 58px) !important;
}

.io-works-section::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -34px;
  width: min(760px, 86vw);
  height: 78px;
  transform: translateX(-50%);
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, rgba(210, 183, 250, .28) 0%, rgba(210, 183, 250, .12) 42%, rgba(210, 183, 250, 0) 74%);
  z-index: 0;
}

.io-works-section > *,
.io-movie-section > * {
  position: relative;
  z-index: 1;
}

/* Keep cards readable over the decorative background. */
.io-box,
.io-profile-card,
.io-contact-card,
.io-detail-card,
.io-schedule-card,
.io-release-card {
  background-color: rgba(255, 255, 255, .94) !important;
}

/* Mobile: avoid oversized background texture and keep performance stable. */
@media (max-width: 720px) {
  body {
    background-size: auto 980px !important;
    background-position: center top !important;
  }

  .io-works-section {
    padding-bottom: 26px !important;
  }

  .io-movie-section {
    padding-top: 26px !important;
  }
}

/* v6.04: Seamless bridge between WORKS and MOVIE.
   The previous boundary looked hard because the two sections had separate vertical spacing.
   This creates one continuous constellation panel behind both sections. */
.io-works-section {
  position: relative;
  margin-bottom: 0 !important;
  padding-bottom: clamp(54px, 7vw, 104px) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(246,238,255,.54) 54%, rgba(246,238,255,.78) 100%) !important;
  overflow: visible !important;
}

.io-movie-section {
  position: relative;
  margin-top: 0 !important;
  padding-top: clamp(54px, 7vw, 104px) !important;
  background:
    linear-gradient(180deg, rgba(246,238,255,.78) 0%, rgba(255,255,255,.72) 52%, rgba(255,255,255,0) 100%) !important;
  overflow: visible !important;
}

/* Large soft connector that visually merges both sections. */
.io-works-section::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: clamp(-78px, -5vw, -42px);
  width: min(1180px, 94vw);
  height: clamp(128px, 14vw, 220px);
  transform: translateX(-50%);
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(178,136,235,.22) 0%, rgba(213,190,249,.16) 34%, rgba(255,255,255,0) 72%),
    linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.56), rgba(255,255,255,0));
  filter: blur(.2px);
}

.io-movie-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: clamp(-82px, -6vw, -42px);
  width: min(1040px, 92vw);
  height: clamp(116px, 13vw, 190px);
  transform: translateX(-50%);
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse at 50% 48%, rgba(255,255,255,.82) 0%, rgba(245,236,255,.42) 42%, rgba(255,255,255,0) 74%);
}

/* Delicate constellation line between the two titles. */
.io-movie-section .io-container::before {
  content: "✦  ⋆  ─────  ♡  ─────  ⋆  ✦";
  position: absolute;
  left: 50%;
  top: calc(clamp(-72px, -5vw, -36px));
  transform: translateX(-50%);
  width: min(680px, 82vw);
  text-align: center;
  color: rgba(151,95,218,.32);
  font-size: 14px;
  letter-spacing: .42em;
  line-height: 1;
  pointer-events: none;
  z-index: 1;
  white-space: nowrap;
}

.io-works-section > .io-container,
.io-movie-section > .io-container {
  position: relative;
  z-index: 2;
}

/* Make slider/card areas sit naturally on the shared background. */
.io-works-section .io-release-carousel,
.io-works-section .io-release-marquee,
.io-works-section .io-works-slider,
.io-movie-section .io-movie-slider,
.io-movie-section .io-movie-wrap {
  position: relative;
  z-index: 2;
}

/* Remove any hard separator effect around the movie block. */
.io-movie-section {
  border-top: 0 !important;
}

.io-works-section + .io-movie-section {
  margin-top: 0 !important;
}

/* Subtle floating stars around the bridge, without affecting click areas. */
.io-works-section .io-container::after {
  content: "✧";
  position: absolute;
  right: min(5vw, 58px);
  bottom: clamp(-26px, -2.5vw, -10px);
  color: rgba(166,104,229,.34);
  font-size: clamp(20px, 2.6vw, 34px);
  line-height: 1;
  pointer-events: none;
  z-index: 1;
  text-shadow:
    -120px -28px 0 rgba(197,151,244,.18),
    -58px 42px 0 rgba(166,104,229,.20),
    64px 34px 0 rgba(229,183,255,.22);
}

@media (max-width: 720px) {
  .io-works-section {
    padding-bottom: 44px !important;
  }

  .io-movie-section {
    padding-top: 44px !important;
  }

  .io-works-section::after {
    bottom: -54px;
    width: 96vw;
    height: 120px;
  }

  .io-movie-section::before {
    top: -54px;
    height: 108px;
  }

  .io-movie-section .io-container::before {
    top: -34px;
    width: 88vw;
    font-size: 10px;
    letter-spacing: .24em;
  }

  .io-works-section .io-container::after {
    right: 16px;
    bottom: -18px;
    font-size: 20px;
  }
}

/* v6.04: Allow safe line breaks in post titles. */
.io-schedule-title br,
.io-release-title br,
.io-detail-title br,
.io-single-title br,
.io-news-row span br,
.io-next-title br {
  display: block;
}

.io-schedule-title span,
.io-release-title span,
.io-detail-title span,
.io-single-title span,
.io-news-row span span,
.io-next-title span {
  display: inline;
}

/* v6.04: Load more schedules in-place on the top page. */
.io-more-button[hidden] {
  display: none !important;
}
button.io-more-button {
  cursor: pointer;
  font-family: inherit;
  appearance: none;
  -webkit-appearance: none;
}
button.io-more-button:focus-visible {
  outline: 3px solid rgba(157, 91, 223, .28);
  outline-offset: 4px;
}

/* v6.04: Display-title line breaks. */
.io-schedule-title br,
.io-release-title br,
.io-detail-title br,
.io-single-title br,
.io-news-row span br,
.io-next-title br {
  display: block;
}

/* v6.04: Mobile horizontal-drift stabilization. */
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden !important;
  overscroll-behavior-x: none;
}

body {
  position: relative;
}

@supports (overflow: clip) {
  html,
  body {
    overflow-x: clip !important;
  }
}

.io-header,
.io-hero,
.io-section,
.io-footer,
.io-single,
.io-detail-page,
.io-page-loader {
  max-width: 100%;
}

.io-section,
.io-single,
.io-detail-page {
  overflow-x: clip;
}

.io-release-section,
.io-movie-section {
  overflow-x: hidden !important;
}

.io-container {
  max-width: calc(100% - 44px);
}

.io-filter,
.io-release-slider,
.io-youtube-slider {
  max-width: 100%;
  overscroll-behavior-x: contain;
}

.io-schedule-section,
.io-schedule-section .io-container,
.io-schedule-grid,
.io-schedule-card {
  min-width: 0;
  max-width: 100%;
}

.io-schedule-grid.is-schedule-updating {
  contain: layout paint;
}

.io-more {
  max-width: 100%;
  overflow: hidden;
}

.io-more-button {
  max-width: 100%;
  touch-action: manipulation;
}

@media (max-width: 720px) {
  .io-container {
    width: min(var(--io-max), calc(100% - 28px));
    max-width: calc(100% - 28px);
  }

  .io-schedule-section {
    touch-action: pan-y;
  }

  .io-schedule-grid {
    width: 100%;
    overflow-x: clip;
  }

  .io-schedule-card {
    transform: translateZ(0);
    backface-visibility: hidden;
  }

  .io-more-button {
    width: min(310px, 100%);
    min-width: 0;
  }
}

@supports not (overflow: clip) {
  .io-section,
  .io-single,
  .io-detail-page,
  .io-schedule-grid {
    overflow-x: hidden;
  }
}

/* v6.04: Robust MOVIE controls and swipe handling. */
.io-youtube-slider {
  touch-action: pan-y pinch-zoom;
}

.io-youtube-track {
  touch-action: pan-y pinch-zoom;
}

.io-youtube-arrow {
  z-index: 30 !important;
  pointer-events: auto !important;
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
}

.io-youtube-dots {
  z-index: 29 !important;
  pointer-events: auto !important;
}

.io-youtube-slide {
  touch-action: pan-y pinch-zoom;
}

.io-youtube-frame,
.io-youtube-open,
.io-youtube-preview,
.io-youtube-thumb {
  -webkit-user-drag: none;
  user-select: none;
  -webkit-user-select: none;
}

.io-youtube-open {
  touch-action: pan-y pinch-zoom;
}

.io-youtube-slider.is-dragging .io-youtube-open {
  pointer-events: none;
}

@media (max-width: 720px) {
  .io-youtube-arrow {
    z-index: 32 !important;
  }
}

/* v6.04: Make entire MOVIE thumbnail/card click-to-play while preserving swipe. */
.io-youtube-slide,
.io-youtube-frame,
.io-youtube-thumb,
.io-youtube-preview {
  cursor: pointer;
}

.io-youtube-slide.is-left,
.io-youtube-slide.is-right,
.io-youtube-slide.is-center {
  pointer-events: auto !important;
}

.io-youtube-slider.is-dragging .io-youtube-slide,
.io-youtube-slider.is-dragging .io-youtube-frame {
  cursor: grabbing;
}

/* v6.04: MOVIE thumbnail/card click priority for desktop playback. */
.io-youtube-slide,
.io-youtube-frame,
.io-youtube-open {
  cursor: pointer !important;
}

.io-youtube-open {
  z-index: 12 !important;
}

.io-youtube-arrow,
.io-youtube-dots,
.io-youtube-dots button {
  cursor: pointer !important;
}

/* v6.04: Mobile/tablet MOVIE tap-to-play. */
.io-youtube-slide,
.io-youtube-frame,
.io-youtube-open,
.io-youtube-thumb,
.io-youtube-preview {
  cursor: pointer !important;
}

.io-youtube-slider.is-dragging .io-youtube-slide,
.io-youtube-slider.is-dragging .io-youtube-frame {
  cursor: grabbing !important;
}

/* v6.04: Reliable MOVIE instant playback across desktop/mobile. */
.io-youtube-slide,
.io-youtube-frame,
.io-youtube-open,
.io-youtube-thumb,
.io-youtube-preview {
  cursor: pointer !important;
}

.io-youtube-slider {
  -webkit-tap-highlight-color: transparent;
}

.io-youtube-slider.is-dragging .io-youtube-open {
  pointer-events: none !important;
}

/* v6.04: Audio-first MOVIE playback gate. */
.io-youtube-audio-gate {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 220px;
  overflow: hidden;
  border-radius: inherit;
  background:
    radial-gradient(circle at 50% 42%, rgba(209, 177, 250, .32), transparent 42%),
    linear-gradient(135deg, #efe1ff, #fff);
}

.io-youtube-audio-gate-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(.95) brightness(.82);
}

.io-youtube-audio-gate-shade {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 46%, rgba(255,255,255,.06), rgba(26,10,46,.36) 54%, rgba(26,10,46,.64) 100%),
    linear-gradient(180deg, rgba(26,10,46,.12), rgba(26,10,46,.56));
}

.io-youtube-audio-play {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-height: 62px;
  padding: 0 28px;
  border: 2px solid rgba(255,255,255,.84);
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, rgba(166,91,232,.96), rgba(218,128,240,.96));
  box-shadow: 0 18px 42px rgba(63, 27, 102, .34);
  cursor: pointer;
  font-weight: 900;
  letter-spacing: .08em;
}

.io-youtube-audio-play-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  color: #9c55de;
  background: #fff;
  font-size: 14px;
  line-height: 1;
  padding-left: 2px;
}

.io-youtube-audio-play-text {
  font-size: 14px;
}

.io-youtube-audio-play:hover,
.io-youtube-audio-play:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 22px 48px rgba(63, 27, 102, .42);
}

@media (max-width: 720px) {
  .io-youtube-audio-gate {
    min-height: 190px;
  }

  .io-youtube-audio-play {
    min-height: 54px;
    padding: 0 20px;
    gap: 10px;
  }

  .io-youtube-audio-play-icon {
    width: 30px;
    height: 30px;
    font-size: 12px;
  }

  .io-youtube-audio-play-text {
    font-size: 12px;
  }
}

/* v6.04: Mobile/tablet YouTube player direct display for reliable playback. */
@media (max-width: 1024px) {
  .io-youtube-modal-frame iframe {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: min(56.29vw, 520px);
    border: 0 !important;
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
  }
}

/* v6.04: Fix mobile/tablet YouTube iframe tapability.
   Older modal CSS used touch-action:none on the full modal; this can prevent the YouTube iframe controls from receiving touch correctly. */
.io-youtube-modal.is-mobile-player,
.io-youtube-modal.is-mobile-player .io-youtube-modal-panel,
.io-youtube-modal.is-mobile-player .io-youtube-modal-frame,
.io-youtube-modal.is-mobile-player .io-youtube-modal-frame iframe,
.io-youtube-modal.is-mobile-player .io-youtube-modal-player {
  pointer-events: auto !important;
  touch-action: auto !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-frame {
  position: relative !important;
  z-index: 20 !important;
  isolation: isolate;
  overflow: hidden !important;
  background: #000 !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-frame iframe,
.io-youtube-modal.is-mobile-player .io-youtube-modal-player {
  position: absolute !important;
  inset: 0 !important;
  z-index: 30 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  border: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  filter: none !important;
  pointer-events: auto !important;
  touch-action: auto !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-toolbar {
  position: relative !important;
  z-index: 40 !important;
  pointer-events: auto !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-close,
.io-youtube-modal.is-mobile-player .io-youtube-modal-close-text {
  z-index: 50 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-backdrop {
  z-index: 1 !important;
}

.io-youtube-modal.is-mobile-player .io-youtube-modal-panel {
  z-index: 10 !important;
}

@media (max-width: 1024px) {
  .io-youtube-modal.is-mobile-player .io-youtube-modal-frame {
    flex: 0 0 auto !important;
    aspect-ratio: 16 / 9 !important;
    height: auto !important;
    max-height: calc(100dvh - 92px) !important;
  }
}

/* v6.04: Mobile/tablet MOVIE uses YouTube official page/app for reliable playback. */
@media (max-width: 1024px), (pointer: coarse) {
  .io-youtube-slide,
  .io-youtube-frame,
  .io-youtube-open {
    cursor: pointer !important;
  }
}

/* v6.04: Remove the mobile YouTube direct button and restore swipe-first MOVIE controls. */
.io-youtube-mobile-direct {
  display: none !important;
}

@media (max-width: 1024px), (pointer: coarse) {
  .io-youtube-slider,
  .io-youtube-track,
  .io-youtube-slide,
  .io-youtube-frame,
  .io-youtube-open {
    touch-action: pan-y pinch-zoom !important;
  }

  .io-youtube-open {
    display: block !important;
    pointer-events: auto !important;
    z-index: 12 !important;
    background: transparent !important;
  }

  .io-youtube-slider.is-dragging .io-youtube-open {
    pointer-events: none !important;
  }

  .io-youtube-slide,
  .io-youtube-frame {
    cursor: grab !important;
  }

  .io-youtube-slider.is-dragging .io-youtube-slide,
  .io-youtube-slider.is-dragging .io-youtube-frame {
    cursor: grabbing !important;
  }
}

/* v6.04: Keep MOVIE mobile/tablet tap-to-YouTube while preserving swipe. */
.io-youtube-mobile-direct {
  display: none !important;
}

@media (max-width: 1024px), (pointer: coarse) {
  .io-youtube-open {
    pointer-events: auto !important;
    touch-action: pan-y pinch-zoom !important;
  }

  .io-youtube-slider.is-dragging .io-youtube-open {
    pointer-events: none !important;
  }
}

/* v6.04: Hide MOVIE play mark only on mobile/tablet while keeping tap and swipe behavior. */
@media (max-width: 1024px), (pointer: coarse) {
  .io-youtube-open::before,
  .io-youtube-open::after,
  .io-youtube-frame::before,
  .io-youtube-frame::after {
    display: none !important;
    content: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
  }

  .io-youtube-open {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    color: transparent !important;
    font-size: 0 !important;
  }

  .io-youtube-open span,
  .io-youtube-open i,
  .io-youtube-open svg {
    display: none !important;
  }
}


/* v6.04 schedule mascot category menu */
.io-filter-menu-shell {
  position: relative;
}
.io-filter-mascot-stage {
  position: relative;
  height: 122px;
  margin: 0 auto -6px;
  pointer-events: none;
  overflow: hidden;
}
.io-filter-mascot-stage::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 14px;
  width: min(940px, calc(100% - 48px));
  height: 16px;
  transform: translateX(-50%);
  border-radius: 999px;
  background:
    radial-gradient(circle at 12px 8px, rgba(180,136,235,.38) 0 2px, transparent 2.2px) 0 0 / 28px 16px repeat-x,
    linear-gradient(90deg, rgba(226,205,255,.06), rgba(226,205,255,.6), rgba(226,205,255,.06));
  opacity: .9;
}
.io-filter-mascot {
  --io-mascot-x: 0px;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 92px;
  transform: translate3d(var(--io-mascot-x), 0, 0);
  transition: transform .78s cubic-bezier(.22,.61,.36,1), filter .24s ease;
  transform-origin: center bottom;
  filter: drop-shadow(0 12px 24px rgba(139, 90, 201, .18));
  z-index: 2;
}
.io-filter-mascot.is-no-transition {
  transition: none !important;
}
.io-filter-mascot img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  -webkit-user-drag: none;
}
.io-filter-mascot.is-walking img {
  animation: ioMascotWalkBounce .28s ease-in-out infinite alternate;
}
.io-filter-mascot.is-sitting {
  transform: translate3d(var(--io-mascot-x), 8px, 0) scale(.98);
}
.io-filter-mascot-bubble {
  position: absolute;
  left: 50%;
  top: -10px;
  transform: translate(-50%, 0);
  padding: 8px 12px;
  min-width: 110px;
  border: 1px solid rgba(190,155,244,.64);
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  color: #8d4ed6;
  box-shadow: 0 12px 26px rgba(159, 111, 224, .16);
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
  white-space: nowrap;
}
.io-filter-mascot-bubble::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  width: 14px;
  height: 14px;
  transform: translateX(-50%) rotate(45deg);
  border-right: 1px solid rgba(190,155,244,.64);
  border-bottom: 1px solid rgba(190,155,244,.64);
  background: rgba(255,255,255,.94);
}
.io-filter {
  position: relative;
  z-index: 3;
}
.io-filter-button {
  position: relative;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease, color .24s ease;
}
.io-filter-button.is-mascot-current,
.io-filter-button.is-active {
  transform: translateY(2px);
  box-shadow: 0 14px 28px rgba(150, 104, 216, .16);
}
.io-filter-button.is-mascot-current::after {
  content: "";
  position: absolute;
  top: -7px;
  left: 50%;
  width: 10px;
  height: 10px;
  transform: translateX(-50%) rotate(45deg);
  background: linear-gradient(135deg, #f6efff, #ead8ff);
  border-top: 1px solid rgba(188, 149, 244, .7);
  border-left: 1px solid rgba(188, 149, 244, .7);
  border-radius: 2px;
}
@keyframes ioMascotWalkBounce {
  0% { transform: translateY(0) rotate(-2deg); }
  100% { transform: translateY(-6px) rotate(2deg); }
}
@media (max-width: 1024px) {
  .io-filter-mascot-stage {
    height: 104px;
    margin-bottom: -4px;
  }
  .io-filter-mascot {
    width: 82px;
  }
  .io-filter-mascot-bubble {
    font-size: 10px;
    min-width: 98px;
    padding: 7px 10px;
  }
}
@media (max-width: 767px) {
  .io-filter-mascot-stage {
    height: 94px;
  }
  .io-filter-mascot-stage::after {
    width: calc(100% - 24px);
    bottom: 10px;
  }
  .io-filter-mascot {
    width: 76px;
  }
  .io-filter-mascot-bubble {
    top: -4px;
    min-width: 90px;
    font-size: 9px;
    padding: 7px 9px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .io-filter-mascot,
  .io-filter-button {
    transition: none !important;
  }
  .io-filter-mascot.is-walking img {
    animation: none !important;
  }
}

/* v6.04: remove mascot label completely and prevent menu-height expansion */
.io-filter-mascot-bubble {
  display: none !important;
  content: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
}

.io-filter-menu-shell {
  position: relative !important;
  z-index: 6 !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.io-filter-mascot-stage {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: -104px !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  pointer-events: none !important;
  z-index: 10 !important;
}

.io-filter-mascot-stage::after {
  bottom: -104px !important;
}

.io-filter-mascot {
  bottom: -104px !important;
  z-index: 11 !important;
}

.io-filter {
  margin-top: 0 !important;
  padding-top: 14px !important;
}

.io-schedule-section .io-section-center {
  position: relative;
  z-index: 1;
}

@media (max-width: 1024px) {
  .io-filter-mascot-stage {
    top: -88px !important;
    height: 0 !important;
    min-height: 0 !important;
  }

  .io-filter-mascot-stage::after {
    bottom: -88px !important;
  }

  .io-filter-mascot {
    bottom: -88px !important;
  }
}

@media (max-width: 767px) {
  .io-filter-mascot-stage {
    top: -74px !important;
    height: 0 !important;
    min-height: 0 !important;
  }

  .io-filter-mascot-stage::after {
    bottom: -74px !important;
  }

  .io-filter-mascot {
    bottom: -74px !important;
  }
}

/* v6.04: refine schedule mascot animation */
.io-filter-mascot-stage::after {
  display: none !important;
  content: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  background: none !important;
}

/* Move mascot 15px lower than v5.68. */
.io-filter-mascot {
  bottom: -119px !important;
  --io-mascot-face: 1;
}

.io-filter-mascot.is-facing-right {
  --io-mascot-face: -1;
}

.io-filter-mascot.is-facing-left {
  --io-mascot-face: 1;
}

.io-filter-mascot img {
  transform: scaleX(var(--io-mascot-face, 1));
  transform-origin: center bottom;
}

/* Override prior bounce so left/right direction is preserved while walking. */
@keyframes ioMascotWalkBounce {
  0% {
    transform: scaleX(var(--io-mascot-face, 1)) translateY(0) rotate(-2deg);
  }
  100% {
    transform: scaleX(var(--io-mascot-face, 1)) translateY(-6px) rotate(2deg);
  }
}

@media (max-width: 1024px) {
  .io-filter-mascot {
    bottom: -103px !important;
  }
}

@media (max-width: 767px) {
  .io-filter-mascot {
    bottom: -89px !important;
  }
}

/* v6.04: correct mascot facing direction and improve walking motion */
.io-filter-mascot {
  --io-mascot-face: 1;
  transition: transform .92s cubic-bezier(.32,.04,.18,1), filter .24s ease !important;
}

/* Source image orientation required inversion from v5.69. */
.io-filter-mascot.is-facing-right {
  --io-mascot-face: -1 !important;
}

.io-filter-mascot.is-facing-left {
  --io-mascot-face: 1 !important;
}

.io-filter-mascot.is-walking {
  filter: drop-shadow(0 14px 22px rgba(139, 90, 201, .16));
}

.io-filter-mascot img {
  transform: scaleX(var(--io-mascot-face, 1));
  transform-origin: center 88%;
  will-change: transform;
}

.io-filter-mascot.is-walking img {
  animation: ioMascotRealWalk .46s steps(2, end) infinite !important;
}

.io-filter-mascot.is-sitting img {
  animation: ioMascotSitSettle .36s ease-out 1 both;
}

/* A small moving shadow helps the static character read as walking. */
.io-filter-mascot::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 4px;
  width: 54%;
  height: 11px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: rgba(112, 69, 162, .10);
  filter: blur(2px);
  opacity: .72;
  z-index: -1;
}

.io-filter-mascot.is-walking::after {
  animation: ioMascotWalkShadow .46s steps(2, end) infinite;
}

@keyframes ioMascotRealWalk {
  0% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-3deg) skewX(-1.2deg);
  }
  25% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(1px, -5px, 0) rotate(2deg) skewX(1.1deg);
  }
  50% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -1px, 0) rotate(3deg) skewX(1.3deg);
  }
  75% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(-1px, -6px, 0) rotate(-2deg) skewX(-1.1deg);
  }
  100% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-3deg) skewX(-1.2deg);
  }
}

@keyframes ioMascotWalkShadow {
  0%, 50%, 100% {
    transform: translateX(-50%) scaleX(.92);
    opacity: .56;
  }
  25%, 75% {
    transform: translateX(-50%) scaleX(1.12);
    opacity: .28;
  }
}

@keyframes ioMascotSitSettle {
  0% {
    transform: scaleX(var(--io-mascot-face, 1)) translateY(-4px) rotate(2deg);
  }
  65% {
    transform: scaleX(var(--io-mascot-face, 1)) translateY(2px) rotate(-1deg);
  }
  100% {
    transform: scaleX(var(--io-mascot-face, 1)) translateY(0) rotate(0deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .io-filter-mascot.is-walking img,
  .io-filter-mascot.is-walking::after,
  .io-filter-mascot.is-sitting img {
    animation: none !important;
  }
}

/* v6.04: correct requested reverse-facing direction and add arm/foot walking motion */
.io-filter-mascot.is-facing-right {
  --io-mascot-face: -1 !important;
}

.io-filter-mascot.is-facing-left {
  --io-mascot-face: 1 !important;
}

.io-filter-mascot {
  --io-walk-swing: 1;
}

.io-filter-mascot img {
  position: relative;
  z-index: 3;
}

.io-mascot-arm,
.io-mascot-foot {
  position: absolute;
  display: block;
  pointer-events: none;
  opacity: 0;
  z-index: 4;
  transform-origin: center center;
  will-change: transform, opacity;
}

/* Subtle decorative pseudo limbs: they make the single PNG read as walking without changing the original asset. */
.io-mascot-arm {
  top: 48%;
  width: 24px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 170, 214, .95), rgba(255, 225, 243, .9));
  box-shadow: 0 2px 6px rgba(155, 90, 184, .12);
}

.io-mascot-arm-left {
  left: 5%;
}

.io-mascot-arm-right {
  right: 5%;
}

.io-mascot-foot {
  bottom: 7px;
  width: 22px;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(130, 86, 190, .82), rgba(218, 189, 246, .78));
  box-shadow: 0 2px 5px rgba(95, 58, 142, .12);
  z-index: 2;
}

.io-mascot-foot-left {
  left: 28%;
}

.io-mascot-foot-right {
  right: 28%;
}

.io-filter-mascot.is-walking .io-mascot-arm,
.io-filter-mascot.is-walking .io-mascot-foot {
  opacity: .82;
}

.io-filter-mascot.is-walking .io-mascot-arm-left {
  animation: ioMascotArmLeft .46s ease-in-out infinite alternate;
}

.io-filter-mascot.is-walking .io-mascot-arm-right {
  animation: ioMascotArmRight .46s ease-in-out infinite alternate;
}

.io-filter-mascot.is-walking .io-mascot-foot-left {
  animation: ioMascotFootLeft .46s ease-in-out infinite alternate;
}

.io-filter-mascot.is-walking .io-mascot-foot-right {
  animation: ioMascotFootRight .46s ease-in-out infinite alternate;
}

.io-filter-mascot.is-walking img {
  animation: ioMascotBetterWalk .46s ease-in-out infinite !important;
}

@keyframes ioMascotBetterWalk {
  0% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-2.5deg);
  }
  25% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -5px, 0) rotate(2deg);
  }
  50% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -1px, 0) rotate(2.8deg);
  }
  75% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -6px, 0) rotate(-2deg);
  }
  100% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-2.5deg);
  }
}

@keyframes ioMascotArmLeft {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -4px)) translateY(0) rotate(calc(var(--io-mascot-face, 1) * -22deg));
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 8px)) translateY(2px) rotate(calc(var(--io-mascot-face, 1) * 22deg));
  }
}

@keyframes ioMascotArmRight {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 8px)) translateY(2px) rotate(calc(var(--io-mascot-face, 1) * 22deg));
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -4px)) translateY(0) rotate(calc(var(--io-mascot-face, 1) * -22deg));
  }
}

@keyframes ioMascotFootLeft {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -8px)) translateY(0) rotate(calc(var(--io-mascot-face, 1) * -8deg));
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 9px)) translateY(-2px) rotate(calc(var(--io-mascot-face, 1) * 10deg));
  }
}

@keyframes ioMascotFootRight {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 9px)) translateY(-2px) rotate(calc(var(--io-mascot-face, 1) * 10deg));
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -8px)) translateY(0) rotate(calc(var(--io-mascot-face, 1) * -8deg));
  }
}

.io-filter-mascot.is-sitting .io-mascot-arm,
.io-filter-mascot.is-sitting .io-mascot-foot {
  opacity: 0;
  animation: none !important;
}

@media (max-width: 767px) {
  .io-mascot-arm {
    width: 18px;
    height: 6px;
  }

  .io-mascot-foot {
    width: 17px;
    height: 6px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .io-filter-mascot.is-walking img,
  .io-filter-mascot.is-walking .io-mascot-arm,
  .io-filter-mascot.is-walking .io-mascot-foot {
    animation: none !important;
  }
}

/* v6.04: hide the pink arm bars shown during mascot walking */
.io-mascot-arm,
.io-mascot-arm-left,
.io-mascot-arm-right,
.io-filter-mascot.is-walking .io-mascot-arm,
.io-filter-mascot.is-walking .io-mascot-arm-left,
.io-filter-mascot.is-walking .io-mascot-arm-right {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  animation: none !important;
  background: none !important;
  box-shadow: none !important;
}

/* v6.04: Move SCHEDULE category buttons 15px upward */
.io-schedule-section .io-filter-menu-shell {
  transform: translateY(-15px) !important;
  margin-bottom: -15px !important;
}

.io-schedule-section .io-filter {
  transform: translateY(-15px) !important;
  margin-bottom: -15px !important;
}

/* Keep mascot alignment with the raised category buttons. */
.io-schedule-section .io-filter-mascot-stage {
  transform: translateY(-15px) !important;
}

/* v6.04: Return SCHEDULE category buttons 10px downward from v5.74 */
.io-schedule-section .io-filter-menu-shell {
  transform: translateY(-5px) !important;
  margin-bottom: -5px !important;
}

.io-schedule-section .io-filter {
  transform: translateY(-5px) !important;
  margin-bottom: -5px !important;
}

.io-schedule-section .io-filter-mascot-stage {
  transform: translateY(-5px) !important;
}


/* v6.04: stronger walking motion with non-bar hand/foot swing */
.io-mascot-arm,
.io-mascot-arm-left,
.io-mascot-arm-right {
  display: block !important;
  visibility: visible !important;
  opacity: 0 !important;
  animation: none !important;
  background: radial-gradient(circle at 35% 35%, rgba(255,245,252,.98) 0 28%, rgba(255,198,230,.96) 32%, rgba(244,148,204,.94) 74%, rgba(214,116,177,.9) 100%) !important;
  box-shadow: 0 2px 7px rgba(169, 94, 174, .18) !important;
  width: 14px !important;
  height: 14px !important;
  border-radius: 999px !important;
  top: 46% !important;
  z-index: 5 !important;
}

.io-mascot-arm-left {
  left: 9% !important;
}

.io-mascot-arm-right {
  right: 9% !important;
}

.io-mascot-foot,
.io-mascot-foot-left,
.io-mascot-foot-right {
  width: 19px !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(193,161,236,.92), rgba(129,95,197,.96)) !important;
  box-shadow: 0 2px 6px rgba(95, 58, 142, .16) !important;
  bottom: 6px !important;
}

.io-mascot-foot-left {
  left: 24% !important;
}

.io-mascot-foot-right {
  right: 24% !important;
}

.io-filter-mascot.is-walking .io-mascot-arm,
.io-filter-mascot.is-walking .io-mascot-foot {
  opacity: .96 !important;
}

.io-filter-mascot.is-walking .io-mascot-arm-left {
  animation: ioMascotArmLeftStrong .38s ease-in-out infinite alternate !important;
}

.io-filter-mascot.is-walking .io-mascot-arm-right {
  animation: ioMascotArmRightStrong .38s ease-in-out infinite alternate !important;
}

.io-filter-mascot.is-walking .io-mascot-foot-left {
  animation: ioMascotFootLeftStrong .38s ease-in-out infinite alternate !important;
}

.io-filter-mascot.is-walking .io-mascot-foot-right {
  animation: ioMascotFootRightStrong .38s ease-in-out infinite alternate !important;
}

.io-filter-mascot.is-walking img {
  animation: ioMascotBetterWalkStrong .38s ease-in-out infinite !important;
}

@keyframes ioMascotBetterWalkStrong {
  0% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-4deg);
  }
  25% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -6px, 0) rotate(4deg);
  }
  50% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -1px, 0) rotate(5deg);
  }
  75% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, -7px, 0) rotate(-4deg);
  }
  100% {
    transform: scaleX(var(--io-mascot-face, 1)) translate3d(0, 0, 0) rotate(-4deg);
  }
}

@keyframes ioMascotArmLeftStrong {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -10px)) translateY(-2px) rotate(calc(var(--io-mascot-face, 1) * -48deg)) scale(1.0);
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 14px)) translateY(3px) rotate(calc(var(--io-mascot-face, 1) * 50deg)) scale(1.08);
  }
}

@keyframes ioMascotArmRightStrong {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 14px)) translateY(3px) rotate(calc(var(--io-mascot-face, 1) * 50deg)) scale(1.08);
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -10px)) translateY(-2px) rotate(calc(var(--io-mascot-face, 1) * -48deg)) scale(1.0);
  }
}

@keyframes ioMascotFootLeftStrong {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -12px)) translateY(1px) rotate(calc(var(--io-mascot-face, 1) * -14deg)) scaleX(.98);
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 14px)) translateY(-3px) rotate(calc(var(--io-mascot-face, 1) * 16deg)) scaleX(1.05);
  }
}

@keyframes ioMascotFootRightStrong {
  0% {
    transform: translateX(calc(var(--io-mascot-face, 1) * 14px)) translateY(-3px) rotate(calc(var(--io-mascot-face, 1) * 16deg)) scaleX(1.05);
  }
  100% {
    transform: translateX(calc(var(--io-mascot-face, 1) * -12px)) translateY(1px) rotate(calc(var(--io-mascot-face, 1) * -14deg)) scaleX(.98);
  }
}

.io-filter-mascot.is-sitting .io-mascot-arm,
.io-filter-mascot.is-sitting .io-mascot-foot {
  opacity: 0 !important;
  animation: none !important;
}

@media (max-width: 767px) {
  .io-mascot-arm,
  .io-mascot-arm-left,
  .io-mascot-arm-right {
    width: 11px !important;
    height: 11px !important;
  }

  .io-mascot-foot,
  .io-mascot-foot-left,
  .io-mascot-foot-right {
    width: 15px !important;
    height: 8px !important;
  }
}


/* v6.04: Ioki Io vertical battle mini game */
.io-battle-game-section{background:radial-gradient(circle at 15% 18%,rgba(218,199,255,.46),transparent 34%),radial-gradient(circle at 82% 18%,rgba(255,205,239,.45),transparent 34%),linear-gradient(180deg,#fff,#faf5ff)}
.io-battle-game{overflow:hidden;border:1px solid rgba(226,207,250,.9);border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(247,241,255,.96));box-shadow:0 28px 70px rgba(120,66,182,.14)}
.io-battle-game-head{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:24px 26px 16px;border-bottom:1px solid rgba(234,220,249,.86)}
.io-battle-kicker{display:block;color:#b266ee;font-size:11px;font-weight:900;letter-spacing:.13em;text-transform:uppercase}.io-battle-game-head h3{margin:7px 0 0;color:#653094;font-size:20px;line-height:1.45;font-weight:900}
.io-battle-best{display:grid;place-items:center;min-width:92px;min-height:70px;border-radius:20px;background:linear-gradient(135deg,#f2e8ff,#fff);box-shadow:inset 0 0 0 1px rgba(201,174,239,.85)}.io-battle-best span{color:#a66bea;font-size:10px;font-weight:900;letter-spacing:.12em}.io-battle-best strong{color:#6b33a0;font-size:25px;line-height:1}
.io-battle-board{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.78fr);gap:24px;padding:26px}.io-battle-stage{position:relative;overflow:hidden;min-height:540px;border:10px solid #fff;border-radius:26px;background-image:linear-gradient(180deg,rgba(109,63,177,.16),rgba(255,255,255,.42)),url("assets/images/io-battle-ui-bg.jpg");background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(196,162,240,.42),0 18px 42px rgba(130,70,190,.12);touch-action:none}
.io-battle-stage:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.15),rgba(119,70,176,.34) 58%,rgba(255,255,255,.2));pointer-events:none}.io-battle-scroll-bg{position:absolute;inset:-40% 0 0;background:repeating-linear-gradient(180deg,rgba(255,255,255,.18) 0 12px,transparent 12px 82px);animation:ioBattleScroll 3.2s linear infinite;opacity:.42}@keyframes ioBattleScroll{to{transform:translateY(82px)}}
.io-battle-player{position:absolute;z-index:5;width:104px;transform:translate(-50%,-50%) translateY(var(--battle-dance,0));transition:filter .16s ease;filter:drop-shadow(0 16px 20px rgba(81,39,129,.25))}.io-battle-player img{display:block;width:100%;height:auto;border-radius:24px}.io-battle-aura{position:absolute;left:50%;top:54%;width:88%;height:72%;transform:translate(-50%,-50%);border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.7),rgba(205,155,255,.22) 44%,transparent 70%);z-index:-1;animation:ioBattleAura 1.2s ease-in-out infinite alternate}@keyframes ioBattleAura{to{transform:translate(-50%,-50%) scale(1.12);opacity:.7}}
.io-battle-enemy{position:absolute;z-index:4;display:grid;place-items:center;width:76px;height:76px;margin:-38px 0 0 -38px;border:2px solid rgba(255,255,255,.78);border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(236,218,255,.8));box-shadow:0 12px 24px rgba(80,37,124,.18);transition:transform .12s ease,filter .12s ease}.io-battle-enemy b{font-size:27px;line-height:1}.io-battle-enemy span{color:#6e3c99;font-size:10px;font-weight:900;line-height:1}.io-battle-enemy.is-damaged{transform:scale(1.16) rotate(-4deg);filter:brightness(1.25)}
.io-battle-effects{position:absolute;inset:0;pointer-events:none;z-index:9}.io-battle-pop{position:absolute;transform:translate(-50%,-50%);color:#fff;background:linear-gradient(135deg,#b661ee,#ff84ce);padding:7px 11px;border-radius:999px;font-size:12px;font-weight:900;box-shadow:0 12px 22px rgba(118,54,178,.22);animation:ioBattlePop .62s ease-out both}@keyframes ioBattlePop{to{transform:translate(-50%,-95%);opacity:0}}
.io-battle-start-screen{position:absolute;inset:0;z-index:10;display:grid;place-items:center;align-content:center;gap:10px;background:rgba(255,255,255,.58);backdrop-filter:blur(3px);color:#69349a;text-align:center}.io-battle-start-screen[hidden]{display:none}.io-battle-start-screen strong{font-size:32px;letter-spacing:.12em}.io-battle-start-screen span{font-weight:900}
.io-battle-ui{display:flex;flex-direction:column;justify-content:center;min-width:0}.io-battle-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.io-battle-stats div{display:grid;place-items:center;min-height:72px;border:1px solid rgba(225,203,249,.9);border-radius:16px;background:#fff}.io-battle-stats span,.io-battle-howto{color:#9a70b9;font-size:10px;font-weight:900;letter-spacing:.08em}.io-battle-stats strong{color:#6a3396;font-size:22px;line-height:1}
.io-battle-message{min-height:56px;margin:18px 0 0;padding:14px 16px;border-radius:16px;background:#fff;color:#6c438b;font-size:13px;line-height:1.65;font-weight:900}.io-battle-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.io-battle-actions button,.io-battle-controls button{border:0;border-radius:999px;cursor:pointer;font-weight:900;letter-spacing:.08em}.io-battle-actions button{min-height:50px;color:#fff;background:linear-gradient(135deg,#b565ee,#ff89cf);box-shadow:0 12px 24px rgba(190,91,215,.22)}.io-battle-actions button:disabled{opacity:.45;box-shadow:none}
.io-battle-controls{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}.io-battle-controls button{min-height:48px;color:#7f43bd;background:#fff;box-shadow:inset 0 0 0 2px #e6d1ff}.io-battle-controls .io-battle-attack{grid-column:1/-1;color:#fff;background:linear-gradient(135deg,#9d55e5,#ff80cc);box-shadow:none}.io-battle-howto{margin:12px 0 0;line-height:1.6}.io-battle-game.is-attacking .io-battle-player{animation:ioBattleAttack .28s ease-out both}@keyframes ioBattleAttack{50%{transform:translate(-50%,-50%) translateY(var(--battle-dance,0)) scale(1.13) rotate(-5deg)}}@media(max-width:980px){.io-battle-board{grid-template-columns:1fr}.io-battle-stage{min-height:480px}}@media(max-width:640px){.io-battle-game-head,.io-battle-board{padding:18px}.io-battle-game-head h3{font-size:16px}.io-battle-stage{min-height:430px;border-width:7px}.io-battle-player{width:82px}.io-battle-enemy{width:64px;height:64px;margin:-32px 0 0 -32px}.io-battle-actions{grid-template-columns:1fr}.io-battle-controls{position:sticky;bottom:10px;z-index:20}}

/* v6.04: verified mobile-first battle game controls and transparent characters */
.io-battle-stage {
  cursor: grab;
}

.io-battle-stage.is-player-dragging {
  cursor: grabbing;
}

.io-battle-player {
  width: 118px !important;
  touch-action: none !important;
  user-select: none !important;
  background: transparent !important;
}

.io-battle-player img {
  border-radius: 0 !important;
  background: transparent !important;
}

.io-battle-enemy {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.io-battle-enemy b {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  background: rgba(255,255,255,.62);
  box-shadow: 0 8px 18px rgba(84, 40, 130, .14);
}

.io-battle-enemy span {
  margin-top: 2px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.68);
}

.io-battle-controls-simple {
  grid-template-columns: 1fr !important;
}

.io-battle-controls-simple .io-battle-attack {
  min-height: 64px !important;
  font-size: 18px !important;
  letter-spacing: .12em;
  box-shadow: 0 14px 28px rgba(190,91,215,.24) !important;
}

.io-battle-howto {
  text-align: center;
}

@media (max-width: 980px) {
  .io-battle-game {
    border-radius: 22px;
  }

  .io-battle-game-board {
    gap: 14px !important;
  }

  .io-battle-stage {
    min-height: min(68vh, 560px) !important;
    border-width: 7px !important;
    border-radius: 22px !important;
  }

  .io-battle-ui {
    padding-bottom: env(safe-area-inset-bottom);
  }

  .io-battle-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .io-battle-stats div {
    min-height: 58px !important;
    border-radius: 14px;
  }

  .io-battle-message {
    min-height: auto !important;
    margin-top: 12px !important;
    padding: 12px 14px !important;
    font-size: 12px !important;
  }

  .io-battle-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    margin-top: 12px !important;
  }

  .io-battle-actions button {
    min-height: 46px !important;
  }

  .io-battle-controls {
    position: sticky;
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
    z-index: 30 !important;
    margin-top: 12px !important;
    padding: 8px;
    border: 1px solid rgba(226,207,250,.86);
    border-radius: 22px;
    background: rgba(255,255,255,.82);
    backdrop-filter: blur(10px);
    box-shadow: 0 14px 32px rgba(108, 55, 170, .16);
  }

  .io-battle-controls-simple .io-battle-attack {
    min-height: 68px !important;
    border-radius: 18px !important;
  }

  .io-battle-player {
    width: 98px !important;
  }
}

@media (max-width: 640px) {
  .io-battle-game-head {
    padding: 16px 16px 10px !important;
  }

  .io-battle-game-board {
    padding: 14px !important;
  }

  .io-battle-game-head h3 {
    font-size: 15px !important;
  }

  .io-battle-best {
    min-width: 70px !important;
    min-height: 54px !important;
  }

  .io-battle-stage {
    min-height: 62vh !important;
  }

  .io-battle-player {
    width: 86px !important;
  }

  .io-battle-enemy {
    width: 56px !important;
    height: 56px !important;
    margin: -28px 0 0 -28px !important;
  }

  .io-battle-enemy b {
    width: 38px;
    height: 38px;
    font-size: 23px !important;
  }

  .io-battle-enemy span {
    font-size: 9px !important;
  }
}

/* v6.04: one-screen mobile battle controls */
.io-battle-dance-cell {
  display: grid !important;
  place-items: center !important;
  min-height: 72px;
  padding: 0 !important;
}

.io-battle-dance-button {
  width: 100%;
  height: 100%;
  min-height: 72px;
  border: 0;
  border-radius: 16px;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(135deg, #b565ee, #ff89cf);
  box-shadow: 0 12px 24px rgba(190, 91, 215, .24), inset 0 0 0 1px rgba(255,255,255,.42);
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .12em;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.io-battle-dance-button:active {
  transform: translateY(2px) scale(.98);
  filter: brightness(1.08);
}

.io-battle-controls,
.io-battle-controls-simple {
  display: none !important;
}

.io-battle-enemy span {
  display: none !important;
}

.io-battle-enemy b {
  background: rgba(255,255,255,.46) !important;
}

.io-battle-stage,
.io-battle-player,
.io-battle-dance-button {
  touch-action: none;
}

.io-battle-game.is-attacking .io-battle-dance-button {
  animation: ioBattleDanceButton .28s ease-out both;
}

@keyframes ioBattleDanceButton {
  50% {
    transform: scale(1.08);
    filter: brightness(1.12);
  }
}

@media (max-width: 980px) {
  .io-battle-board {
    gap: 10px !important;
  }

  .io-battle-stats {
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 8px !important;
  }

  .io-battle-dance-cell,
  .io-battle-dance-button {
    min-height: 58px !important;
    border-radius: 14px !important;
  }

  .io-battle-dance-button {
    font-size: 18px !important;
  }

  .io-battle-message {
    margin-top: 10px !important;
  }

  .io-battle-actions {
    margin-top: 10px !important;
  }
}

@media (max-width: 640px) {
  .io-battle-stage {
    min-height: 56vh !important;
  }

  .io-battle-dance-cell,
  .io-battle-dance-button {
    min-height: 56px !important;
  }

  .io-battle-dance-button {
    font-size: 17px !important;
  }

  .io-battle-message {
    font-size: 11px !important;
    padding: 11px 12px !important;
  }

  .io-battle-actions button {
    min-height: 42px !important;
  }
}

/* v6.04: HP gauge and vertical shooting game tuning */
.io-battle-hp-gauge {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
  padding: 12px 14px;
  border: 1px solid rgba(225,203,249,.9);
  border-radius: 18px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 24px rgba(130,70,190,.08);
}

.io-battle-hp-gauge span,
.io-battle-hp-gauge strong {
  color: #7b43aa;
  font-weight: 900;
  letter-spacing: .08em;
}

.io-battle-hp-gauge span {
  font-size: 11px;
}

.io-battle-hp-gauge strong {
  min-width: 34px;
  text-align: right;
  font-size: 18px;
}

.io-battle-hp-gauge i {
  display: block;
  overflow: hidden;
  height: 12px;
  border-radius: 999px;
  background: #f0e2ff;
}

.io-battle-hp-gauge b {
  display: block;
  height: 100%;
  width: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #b565ee, #ff89cf);
  transition: width .16s linear, background .16s linear;
}

.io-battle-hp-gauge b.is-danger {
  background: linear-gradient(90deg, #ff4c7f, #ff9a9a);
}

.io-battle-bullet {
  position: absolute;
  z-index: 7;
  width: 30px;
  height: 30px;
  margin: -15px 0 0 -15px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  background: radial-gradient(circle, #fff 0 20%, #d59cff 38%, rgba(255,137,207,.78) 72%, transparent 73%);
  box-shadow: 0 0 14px rgba(218,146,255,.72);
  font-size: 18px;
  font-weight: 900;
  pointer-events: none;
  animation: ioBattleBulletSpin .34s linear infinite;
}

@keyframes ioBattleBulletSpin {
  to {
    transform: rotate(360deg);
  }
}

.io-battle-item {
  position: absolute;
  z-index: 6;
  width: 38px;
  height: 38px;
  margin: -19px 0 0 -19px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  box-shadow: 0 8px 18px rgba(130,70,190,.12);
  font-size: 21px;
  pointer-events: none;
}

.io-battle-game.is-shooting .io-battle-player {
  animation: ioBattleShootDance .22s ease-out both;
}

@keyframes ioBattleShootDance {
  50% {
    transform: translate(-50%,-50%) translateY(var(--battle-dance,0)) scale(1.08) rotate(-4deg);
  }
}

.io-battle-enemy span {
  display: none !important;
}

.io-battle-dance-button {
  touch-action: none !important;
}

.io-battle-stage {
  touch-action: none !important;
}

@media (max-width: 980px) {
  .io-battle-hp-gauge {
    padding: 10px 12px;
    margin-bottom: 8px;
  }
}

@media (max-width: 640px) {
  .io-battle-hp-gauge {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 8px;
    padding: 9px 10px;
    border-radius: 14px;
  }

  .io-battle-hp-gauge span {
    font-size: 10px;
  }

  .io-battle-hp-gauge strong {
    font-size: 16px;
  }

  .io-battle-hp-gauge i {
    height: 10px;
  }

  .io-battle-stage {
    min-height: 54vh !important;
  }
}

/* v6.04: mobile-only mini game opened from MENU */
.io-battle-game-section[hidden] {
  display: none !important;
}

.io-game-menu-link,
.io-game-menu-item {
  display: none !important;
}

@media (max-width: 980px), (pointer: coarse) {
  .io-game-menu-link {
    display: grid !important;
  }

  .io-game-menu-item {
    display: list-item !important;
  }

  .io-battle-game-section.is-game-open {
    display: block;
  }
}

@media (min-width: 981px) and (hover: hover) and (pointer: fine) {
  .io-battle-game-section {
    display: none !important;
  }
}
/* v6.04: mobile-only Ioki Wall mini game */
.io-menu-game-link{border:0;background:transparent;color:inherit;font:inherit;font-weight:900;cursor:pointer;text-align:inherit}.io-menu-game-link-floating{display:none!important}.io-wall-game-section{display:none}
@media(max-width:980px){.io-wall-game-section.is-open{display:block}.io-wall-game{overflow:hidden;border:1px solid rgba(226,207,250,.9);border-radius:26px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(247,241,255,.96));box-shadow:0 24px 60px rgba(120,66,182,.14)}.io-wall-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:18px 18px 12px;border-bottom:1px solid rgba(234,220,249,.86)}.io-wall-kicker{display:block;color:#b266ee;font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.io-wall-head h3{margin:6px 0 0;color:#653094;font-size:15px;line-height:1.45;font-weight:900}.io-wall-best{display:grid;place-items:center;min-width:70px;min-height:54px;border-radius:18px;background:linear-gradient(135deg,#f2e8ff,#fff);box-shadow:inset 0 0 0 1px rgba(201,174,239,.85)}.io-wall-best span{color:#a66bea;font-size:9px;font-weight:900;letter-spacing:.12em}.io-wall-best strong{color:#6b33a0;font-size:20px}
.io-wall-stage{position:relative;overflow:hidden;min-height:56vh;margin:14px;border:7px solid #fff;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.34),rgba(190,228,255,.34)),radial-gradient(circle at 50% 70%,rgba(120,205,255,.48),transparent 36%),linear-gradient(180deg,#dff7ff 0%,#f7ecff 48%,#9ddfff 100%);box-shadow:inset 0 0 0 1px rgba(196,162,240,.42),0 18px 42px rgba(130,70,190,.12);touch-action:none}.io-wall-pool-bg:before{content:"";position:absolute;left:-20%;right:-20%;bottom:-18%;height:48%;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.55),transparent 9%),radial-gradient(circle at 70% 40%,rgba(255,255,255,.5),transparent 8%),repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 3px,transparent 3px 32px),linear-gradient(180deg,rgba(117,208,255,.35),rgba(42,169,233,.45));border-radius:50% 50% 0 0;animation:ioWallWater 2.2s ease-in-out infinite alternate}@keyframes ioWallWater{to{transform:translateY(7px)}}
.io-wall-crowd{position:absolute;left:0;right:0;bottom:5%;height:28%;pointer-events:none;z-index:2}.io-wall-crowd span{position:absolute;font-size:24px;filter:drop-shadow(0 6px 10px rgba(80,37,124,.16));animation:ioWallCrowdPop .42s ease-out both}@keyframes ioWallCrowdPop{from{transform:translateY(14px) scale(.78);opacity:0}}.io-wall-idol{position:absolute;left:50%;bottom:4%;z-index:4;width:112px;transform:translateX(-50%);pointer-events:none;filter:drop-shadow(0 12px 18px rgba(80,37,124,.22))}.io-wall-idol img{display:block;width:100%;height:auto;border-radius:18px}.io-wall-idol span{position:absolute;right:4px;top:4px;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:rgba(255,255,255,.78);color:#ba62ee;font-weight:900}
.io-wall-holes{position:absolute;inset:9% 5% 23%;z-index:5;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:12px}.io-wall-hole{position:relative;border:0;border-radius:20px;background:rgba(255,255,255,.16);box-shadow:inset 0 0 0 1px rgba(255,255,255,.28);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.io-wall-hole:after{content:"";position:absolute;left:15%;right:15%;bottom:6%;height:13px;border-radius:999px;background:rgba(93,55,140,.12)}.io-wall-cameko{position:absolute;left:50%;bottom:5%;width:74px;transform:translateX(-50%);animation:ioWallCamekoUp .18s ease-out both}.io-wall-cameko img{display:block;width:100%;height:auto;border-radius:18px;filter:drop-shadow(0 8px 14px rgba(80,37,124,.2))}.io-wall-cameko b{position:absolute;right:-4px;top:-6px;display:grid;place-items:center;width:27px;height:27px;border-radius:999px;background:rgba(255,255,255,.78);font-size:18px}@keyframes ioWallCamekoUp{from{transform:translateX(-50%) translateY(22px) scale(.82);opacity:0}}
.io-wall-hole.is-hit{background:rgba(255,214,245,.36)}.io-wall-hole.is-hit:before{content:"目線♡";position:absolute;left:50%;top:10%;transform:translateX(-50%);color:#fff;background:linear-gradient(135deg,#b565ee,#ff89cf);padding:5px 10px;border-radius:999px;font-size:12px;font-weight:900;z-index:4;animation:ioWallHit .26s ease-out both}@keyframes ioWallHit{to{transform:translateX(-50%) translateY(-12px);opacity:0}}.io-wall-hole.is-missed{background:rgba(120,80,160,.18)}.io-wall-start{position:absolute;inset:0;z-index:10;display:grid;place-items:center;align-content:center;gap:10px;background:rgba(255,255,255,.58);backdrop-filter:blur(4px);color:#69349a;text-align:center}.io-wall-start[hidden]{display:none}.io-wall-start strong{font-size:25px;font-weight:900;letter-spacing:.08em}.io-wall-start span{font-size:13px;font-weight:900}
.io-wall-ui{padding:0 14px 16px}.io-wall-popularity{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(225,203,249,.9);border-radius:16px;background:rgba(255,255,255,.9)}.io-wall-popularity span,.io-wall-popularity strong{color:#7b43aa;font-weight:900}.io-wall-popularity span{font-size:11px}.io-wall-popularity i{overflow:hidden;display:block;height:11px;border-radius:999px;background:#f0e2ff}.io-wall-popularity b{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#b565ee,#ff89cf);transition:width .16s linear}.io-wall-popularity b.is-danger{background:linear-gradient(90deg,#ff4c7f,#ff9a9a)}
.io-wall-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}.io-wall-stats div{display:grid;place-items:center;min-height:56px;border:1px solid rgba(225,203,249,.9);border-radius:14px;background:#fff}.io-wall-stats span{color:#9a70b9;font-size:10px;font-weight:900;letter-spacing:.08em}.io-wall-stats strong{color:#6a3396;font-size:19px;line-height:1}.io-wall-message{margin:10px 0 0;padding:12px;border-radius:15px;background:#fff;color:#6c438b;font-size:12px;line-height:1.6;font-weight:900}.io-wall-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.io-wall-actions button{min-height:44px;border:0;border-radius:999px;color:#fff;background:linear-gradient(135deg,#b565ee,#ff89cf);font-size:13px;font-weight:900}}
@media(min-width:981px){.io-menu-game-link,.io-menu-game-item,.io-wall-game-section{display:none!important}}

/* v6.04: guarantee MINI GAME access from smartphone menu */
.io-mobile-nav-game-item {
  list-style: none;
}

.io-mobile-nav-link.io-menu-game-link,
.io-menu-game-link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
  text-align: left;
}

.io-mobile-nav-link.io-menu-game-link span {
  color: #8a45c8;
  font-size: 16px;
  letter-spacing: .08em;
  font-weight: 900;
}

.io-mobile-nav-link.io-menu-game-link small {
  color: #b77be8;
  font-size: 11px;
  font-weight: 900;
}

.io-wall-fixed-open {
  display: none;
}

@media (max-width: 980px) {
  .io-wall-fixed-open {
    position: fixed;
    right: 18px;
    bottom: max(18px, env(safe-area-inset-bottom));
    z-index: 999;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(135deg, #b565ee, #ff89cf);
    box-shadow: 0 12px 28px rgba(160, 85, 210, .28);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .06em;
  }

  .io-wall-game-section[hidden] {
    display: none !important;
  }

  .io-wall-game-section.is-open {
    display: block !important;
  }
}

@media (min-width: 981px) {
  .io-wall-fixed-open {
    display: none !important;
  }
}
/* v6.04: horizontal real photo-session wall layout */
@media(max-width:980px){
  .io-wall-stage{
    min-height:56vh!important;
    background-image:linear-gradient(90deg,rgba(255,255,255,.48),rgba(255,255,255,.18)),url("assets/images/io-wall-pool-bg.jpg")!important;
    background-size:cover!important;
    background-position:center!important;
  }
  .io-wall-pool-bg:before{display:none!important}
  .io-wall-holes,.io-wall-hole{display:none!important}
  .io-wall-free-layer{
    position:absolute;
    inset:0;
    z-index:6;
    touch-action:none;
  }
  .io-wall-idol{
    left:17%!important;
    bottom:16%!important;
    width:104px!important;
    border-radius:0!important;
    transition:transform .18s ease;
    transform:translateX(-50%) rotate(var(--io-wall-look-rotate,0deg));
  }
  .io-wall-idol img{
    border-radius:0!important;
    background:transparent!important;
  }
  .io-wall-idol span{
    transform:translate(var(--io-wall-look-x,0),var(--io-wall-look-y,0));
    transition:transform .18s ease;
  }
  .io-wall-idol.is-looking{
    animation:ioWallIdolLook .5s ease-out both;
  }
  @keyframes ioWallIdolLook{
    45%{transform:translateX(-50%) rotate(var(--io-wall-look-rotate,0deg)) scale(1.06)}
  }
  .io-wall-crowd{
    left:31%!important;
    right:1%!important;
    bottom:2%!important;
    height:32%!important;
    z-index:3!important;
  }
  .io-wall-crowd span{
    font-size:25px!important;
  }
  .io-wall-free-cameko{
    position:absolute;
    z-index:7;
    width:72px;
    height:72px;
    margin:-36px 0 0 -36px;
    border:0;
    background:transparent;
    padding:0;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
    animation:ioWallFreeIn .18s ease-out both;
  }
  .io-wall-free-cameko img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
    background:transparent!important;
    filter:drop-shadow(0 7px 12px rgba(40,25,70,.22));
    pointer-events:none;
  }
  .io-wall-free-cameko b{
    position:absolute;
    right:-5px;
    top:-8px;
    display:grid;
    place-items:center;
    width:26px;
    height:26px;
    border-radius:999px;
    background:rgba(255,255,255,.74);
    font-size:17px;
    pointer-events:none;
  }
  .io-wall-free-cameko.is-hit:after{
    content:"目線♡";
    position:absolute;
    left:50%;
    top:-12px;
    transform:translateX(-50%);
    color:#fff;
    background:linear-gradient(135deg,#b565ee,#ff89cf);
    padding:5px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
    white-space:nowrap;
    animation:ioWallHit .24s ease-out both;
  }
  @keyframes ioWallFreeIn{
    from{transform:translateY(22px) scale(.78);opacity:0}
  }
  .io-wall-popularity b{
    background:linear-gradient(90deg,#8fd3ff,#b565ee,#ff89cf)!important;
  }
}
@media(max-width:640px){
  .io-wall-stage{min-height:52vh!important}
  .io-wall-idol{width:88px!important;left:17%!important;bottom:18%!important}
  .io-wall-free-cameko{width:62px;height:62px;margin:-31px 0 0 -31px}
}
/* v6.04: real pool background and illustrated cameko crowd */
@media(max-width:980px){
  .io-wall-stage{
    background-image:linear-gradient(90deg,rgba(255,255,255,.30),rgba(255,255,255,.06)),url("assets/images/io-wall-pool-bg-v588.jpg")!important;
    background-size:cover!important;
    background-position:center center!important;
  }
  .io-wall-crowd{
    left:30%!important;
    right:0!important;
    bottom:0!important;
    height:38%!important;
    z-index:4!important;
  }
  .io-wall-crowd span{
    position:absolute;
    width:46px;
    height:70px;
    font-size:0!important;
    filter:drop-shadow(0 7px 10px rgba(20,20,35,.24));
  }
  .io-wall-crowd span img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
    background:transparent!important;
  }
  .io-wall-free-cameko{
    width:78px!important;
    height:86px!important;
    margin:-43px 0 0 -39px!important;
    background:transparent!important;
  }
  .io-wall-free-cameko img{
    width:100%!important;
    height:100%!important;
    object-fit:contain!important;
    background:transparent!important;
    border-radius:0!important;
    filter:drop-shadow(0 9px 13px rgba(25,20,40,.28))!important;
  }
  .io-wall-free-cameko b{
    display:none!important;
  }
  .io-wall-idol{
    z-index:8!important;
  }
}
@media(max-width:640px){
  .io-wall-crowd span{
    width:38px;
    height:58px;
  }
  .io-wall-free-cameko{
    width:68px!important;
    height:76px!important;
    margin:-38px 0 0 -34px!important;
  }
}
/* v6.04: crowd density area and sukumizu bonus */
@media(max-width:980px){
  .io-wall-crowd{
    left:33%!important;
    right:0!important;
    top:18%!important;
    bottom:auto!important;
    height:63%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:polygon(0 18%, 28% 3%, 100% 9%, 100% 100%, 53% 82%, 24% 55%, 0 47%);
    background:linear-gradient(90deg,rgba(255,120,180,.10),rgba(255,80,120,.16));
    border-radius:34px 0 0 42px;
  }
  .io-wall-crowd span{
    position:absolute!important;
    width:48px!important;
    height:72px!important;
    font-size:0!important;
    filter:drop-shadow(0 7px 10px rgba(20,20,35,.24));
    transition:opacity .18s linear, transform .18s linear;
  }
  .io-wall-crowd span img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
    background:transparent!important;
  }
  .io-wall-sukumizu-item{
    position:absolute;
    z-index:9;
    width:66px;
    height:78px;
    margin:-39px 0 0 -33px;
    border:0;
    background:transparent;
    padding:0;
    animation:ioWallSukumizuFloat .9s ease-in-out infinite alternate;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
  }
  .io-wall-sukumizu-item img{
    display:block;
    width:100%;
    height:66px;
    object-fit:contain;
    filter:drop-shadow(0 8px 14px rgba(20,40,100,.25));
  }
  .io-wall-sukumizu-item strong{
    position:absolute;
    left:50%;
    bottom:-2px;
    transform:translateX(-50%);
    padding:3px 8px;
    border-radius:999px;
    color:#fff;
    background:linear-gradient(135deg,#3159d4,#7aa8ff);
    font-size:10px;
    font-weight:900;
    white-space:nowrap;
  }
  @keyframes ioWallSukumizuFloat{
    to{transform:translateY(-8px) scale(1.05)}
  }
  .io-wall-boost{
    display:grid;
    grid-template-columns:1fr auto;
    gap:8px;
    align-items:center;
    margin-top:8px;
    padding:8px 11px;
    border-radius:14px;
    background:linear-gradient(135deg,rgba(48,88,210,.92),rgba(144,185,255,.9));
    color:#fff;
    font-weight:900;
    box-shadow:0 10px 18px rgba(60,90,180,.18);
  }
  .io-wall-boost[hidden]{
    display:none!important;
  }
  .io-wall-boost span{
    font-size:11px;
    letter-spacing:.06em;
  }
  .io-wall-boost strong{
    font-size:15px;
  }
  .io-wall-idol.is-sukumizu:after{
    content:"アヒルボート";
    position:absolute;
    left:50%;
    bottom:-10px;
    transform:translateX(-50%);
    padding:4px 10px;
    border-radius:999px;
    color:#fff;
    background:linear-gradient(135deg,#1c4e9a,#0f2461);
    font-size:11px;
    font-weight:900;
    box-shadow:0 8px 16px rgba(30,60,140,.2);
  }
}
@media(max-width:640px){
  .io-wall-crowd span{
    width:39px!important;
    height:60px!important;
  }
  .io-wall-sukumizu-item{
    width:58px;
    height:70px;
    margin:-35px 0 0 -29px;
  }
}
/* v6.04: persistent wide cameko wall and clearer swimsuit item */
@media(max-width:980px){
  .io-wall-crowd{
    left:31%!important;
    right:0!important;
    top:14%!important;
    bottom:auto!important;
    width:69%!important;
    height:70%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:polygon(0 17%, 20% 5%, 58% 4%, 100% 10%, 100% 100%, 58% 92%, 28% 73%, 0 58%);
    background:linear-gradient(90deg,rgba(255,120,180,.08),rgba(255,80,120,.14));
    border-radius:34px 0 0 46px;
  }
  .io-wall-crowd span{
    position:absolute!important;
    width:48px!important;
    height:72px!important;
    font-size:0!important;
    filter:drop-shadow(0 7px 10px rgba(20,20,35,.22));
    opacity:.7;
    animation:none!important;
    transition:none!important;
    will-change:auto!important;
  }
  .io-wall-crowd span img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
    background:transparent!important;
  }
  .io-wall-sukumizu-item{
    position:absolute;
    z-index:9;
    width:72px;
    height:72px;
    margin:-36px 0 0 -36px;
    border:0;
    background:transparent;
    padding:0;
    animation:ioWallSukumizuFloat .9s ease-in-out infinite alternate;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
  }
  .io-wall-sukumizu-item img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
    filter:drop-shadow(0 8px 14px rgba(20,40,100,.25));
  }
  .io-wall-sukumizu-item strong{
    display:none!important;
  }
  .io-wall-idol.is-sukumizu:after{
    content:"";
    position:absolute;
    left:50%;
    bottom:-10px;
    transform:translateX(-50%);
    width:58px;
    height:22px;
    border-radius:999px;
    background:linear-gradient(135deg,#1c4e9a,#0f2461);
    box-shadow:0 8px 16px rgba(30,60,140,.2);
    opacity:.92;
  }
}
@media(max-width:640px){
  .io-wall-crowd span{
    width:40px!important;
    height:60px!important;
  }
  .io-wall-sukumizu-item{
    width:62px;
    height:62px;
    margin:-31px 0 0 -31px;
  }
}
/* v6.04: duck boat item, S-shaped crowd area, gaze and kyun effects */
@media(max-width:980px){
  .io-wall-crowd{
    left:14%!important;right:0!important;top:8%!important;bottom:auto!important;width:86%!important;height:87%!important;z-index:4!important;pointer-events:none;
    clip-path:polygon(8% 12%,30% 2%,55% 0%,72% 7%,76% 25%,76% 48%,71% 65%,61% 78%,51% 88%,47% 100%,100% 100%,100% 0%,8% 0%);
    background:linear-gradient(90deg,rgba(255,120,180,.08),rgba(255,80,120,.15));border-radius:48px 0 0 48px;
  }
  .io-wall-crowd span{animation:none!important;transition:none!important;}
  .io-wall-duckboat-item{
    position:absolute;z-index:9;width:78px;height:60px;margin:-30px 0 0 -39px;border:0;background:transparent;padding:0;
    animation:ioWallDuckboatFloat .9s ease-in-out infinite alternate;touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  }
  .io-wall-duckboat-item img{display:block;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(100,70,10,.28));background:transparent!important;}
  .io-wall-duckboat-item strong{display:none!important;}
  @keyframes ioWallDuckboatFloat{to{transform:translateY(-8px) scale(1.05)}}
  .io-wall-idol.is-duckboat:after{
    content:"";position:absolute;left:50%;bottom:-10px;transform:translateX(-50%);width:70px;height:24px;border-radius:999px;
    background:linear-gradient(135deg,#ffd83b,#ff9f2d);box-shadow:0 8px 16px rgba(180,120,20,.22);opacity:.94;
  }
  .io-wall-gaze-beam{
    position:absolute;z-index:10;height:4px;border-radius:999px;transform-origin:left center;pointer-events:none;
    background:linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,118,210,.85),rgba(255,255,255,0));box-shadow:0 0 12px rgba(255,98,204,.8);
    animation:ioWallGazeBeam .42s ease-out both;
  }
  @keyframes ioWallGazeBeam{0%{opacity:0;transform:scaleX(.1)}35%{opacity:1}100%{opacity:0;filter:blur(2px)}}
  .io-wall-kyun-pop{
    position:absolute;z-index:12;transform:translate(-50%,-50%);display:grid;place-items:center;width:34px;height:34px;border-radius:999px;color:#fff;
    background:linear-gradient(135deg,#ff71ca,#b565ee);font-size:20px;font-weight:900;pointer-events:none;box-shadow:0 8px 18px rgba(180,70,190,.28);
    animation:ioWallKyunPop .52s ease-out both;
  }
  @keyframes ioWallKyunPop{0%{opacity:0;transform:translate(-50%,-20%) scale(.5)}35%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}100%{opacity:0;transform:translate(-50%,-120%) scale(.9)}}
}
@media(max-width:640px){.io-wall-duckboat-item{width:68px;height:52px;margin:-26px 0 0 -34px;}}
/* v6.04: combo, fever and mission gameplay upgrade */
@media(max-width:980px){
  .io-wall-game.is-fever .io-wall-stage{
    box-shadow:inset 0 0 0 2px rgba(255,118,210,.55),0 0 28px rgba(255,118,210,.35),0 18px 42px rgba(130,70,190,.12)!important;
  }
  .io-wall-gameplay-status{
    display:grid;
    grid-template-columns:1fr;
    gap:7px;
    margin-top:8px;
  }
  .io-wall-combo,
  .io-wall-fever,
  .io-wall-mission{
    display:grid;
    grid-template-columns:auto 1fr;
    align-items:center;
    gap:8px;
    padding:8px 10px;
    border-radius:14px;
    background:rgba(255,255,255,.9);
    border:1px solid rgba(225,203,249,.9);
    color:#6a3396;
    font-weight:900;
  }
  .io-wall-combo[hidden],
  .io-wall-fever[hidden]{
    display:none!important;
  }
  .io-wall-combo span,
  .io-wall-fever span,
  .io-wall-mission span{
    color:#b565ee;
    font-size:10px;
    letter-spacing:.09em;
  }
  .io-wall-combo strong{
    justify-self:end;
    font-size:18px;
    color:#ff63bd;
  }
  .io-wall-mission strong{
    justify-self:end;
    font-size:11px;
    line-height:1.35;
    text-align:right;
  }
  .io-wall-fever i{
    display:block;
    overflow:hidden;
    height:10px;
    border-radius:999px;
    background:#f0e2ff;
  }
  .io-wall-fever b{
    display:block;
    height:100%;
    border-radius:inherit;
    background:linear-gradient(90deg,#ff71ca,#ffd83b,#b565ee);
    transition:width .15s linear;
  }
  .io-wall-idol.is-fever{
    filter:drop-shadow(0 0 18px rgba(255,118,210,.8)) drop-shadow(0 12px 18px rgba(80,37,124,.22))!important;
  }
  .io-wall-gaze-beam.is-special{
    height:7px!important;
    background:linear-gradient(90deg,rgba(255,255,255,1),rgba(255,217,70,.95),rgba(255,113,202,.85),rgba(255,255,255,0))!important;
    box-shadow:0 0 18px rgba(255,200,80,.95),0 0 22px rgba(255,98,204,.75)!important;
  }
  .io-wall-kyun-pop{
    min-width:34px;
    padding:0 7px;
    white-space:nowrap;
  }
}
/* v6.04: safe duckboat idol image fallback */
@media(max-width:980px){
  .io-wall-idol.is-duckboat:after{
    background:linear-gradient(135deg,#ffd83b,#ff9f2d)!important;
  }
}
/* v6.04: crowd display area updated to latest red reference */
@media(max-width:980px){
  .io-wall-crowd{
    left:4%!important;
    right:0!important;
    top:0!important;
    bottom:auto!important;
    width:96%!important;
    height:100%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:polygon(
      10% 0%,
      94% 0%,
      94% 17%,
      92% 35%,
      92% 52%,
      88% 70%,
      80% 86%,
      72% 100%,
      51% 100%,
      54% 87%,
      63% 75%,
      68% 62%,
      66% 51%,
      56% 43%,
      42% 37%,
      30% 31%,
      18% 30%,
      8% 33%,
      0% 27%,
      0% 14%,
      4% 6%
    );
    background:linear-gradient(90deg,rgba(255,80,100,.10),rgba(255,80,120,.17));
    border-radius:32px 0 0 34px;
  }
  .io-wall-crowd span{
    animation:none!important;
    transition:none!important;
  }
}
/* v6.04: latest crowd area, remove duckboat lower yellow line, lower gaze origin */
@media(max-width:980px){
  .io-wall-crowd{
    left:10%!important;
    right:0!important;
    top:13%!important;
    bottom:auto!important;
    width:90%!important;
    height:86%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:polygon(
      0% 16%,
      9% 8%,
      28% 2%,
      47% 1%,
      66% 3%,
      84% 8%,
      100% 15%,
      100% 45%,
      89% 45%,
      74% 41%,
      63% 37%,
      57% 48%,
      57% 60%,
      50% 70%,
      38% 78%,
      26% 82%,
      17% 88%,
      8% 96%,
      0% 100%,
      100% 100%,
      100% 45%,
      91% 50%,
      80% 55%,
      68% 61%,
      58% 66%,
      48% 70%,
      37% 73%,
      27% 75%,
      17% 76%,
      8% 73%,
      2% 65%,
      0% 53%,
      0% 16%
    );
    background:linear-gradient(90deg,rgba(255,80,100,.10),rgba(255,80,120,.18));
    border-radius:38px 0 0 38px;
  }

  .io-wall-idol.is-duckboat:after{
    display:none!important;
    content:none!important;
  }

  .io-wall-gaze-beam{
    transform-origin:left center!important;
  }
}
/* v6.04: crowd display area adjusted to smartphone screenshot red area */
@media(max-width:980px){
  .io-wall-crowd{
    left:0!important;
    right:0!important;
    top:12%!important;
    bottom:auto!important;
    width:100%!important;
    height:88%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:polygon(
      0% 18%,
      9% 8%,
      25% 4%,
      43% 2%,
      60% 3%,
      75% 8%,
      90% 16%,
      100% 27%,
      100% 100%,
      74% 100%,
      66% 88%,
      55% 76%,
      43% 68%,
      30% 65%,
      17% 68%,
      6% 78%,
      0% 88%,
      0% 61%,
      8% 54%,
      20% 49%,
      33% 45%,
      45% 41%,
      56% 34%,
      63% 25%,
      56% 18%,
      42% 14%,
      25% 14%,
      11% 17%,
      2% 25%,
      0% 18%
    );
    background:linear-gradient(90deg,rgba(255,0,0,.16),rgba(255,0,0,.22));
    border-radius:28px 0 0 34px;
  }

  .io-wall-crowd span{
    animation:none!important;
    transition:none!important;
  }
}
/* v6.04: exact image-mask based crowd display area */
@media(max-width:980px){
  .io-wall-crowd{
    left:0!important;
    right:0!important;
    top:0!important;
    bottom:0!important;
    width:100%!important;
    height:100%!important;
    z-index:4!important;
    pointer-events:none;
    clip-path:none!important;
    background:transparent!important;
    border-radius:0!important;
    -webkit-mask-image:url("assets/images/io-wall-crowd-mask-v599.png");
    mask-image:url("assets/images/io-wall-crowd-mask-v599.png");
    -webkit-mask-size:100% 100%;
    mask-size:100% 100%;
    -webkit-mask-repeat:no-repeat;
    mask-repeat:no-repeat;
    -webkit-mask-position:center;
    mask-position:center;
  }

  .io-wall-crowd span{
    animation:none!important;
    transition:none!important;
  }
}
/* v6.04: compact smartphone mini-game UI and copy cleanup */
@media(max-width:980px){
  .io-wall-game-section.is-open{padding-top:6px!important;margin-top:0!important;}
  .io-wall-game-section .io-section-center{display:none!important;}
  .io-wall-game-section .io-container{padding-left:10px!important;padding-right:10px!important;}
  .io-wall-game{border-radius:22px!important;box-shadow:0 12px 32px rgba(120,66,182,.13)!important;}
  .io-wall-head{padding:10px 12px 8px!important;gap:8px!important;}
  .io-wall-kicker{font-size:10px!important;letter-spacing:.04em!important;}
  .io-wall-head h3{margin-top:3px!important;font-size:12px!important;line-height:1.35!important;}
  .io-wall-best{min-width:58px!important;min-height:44px!important;border-radius:14px!important;}
  .io-wall-best strong{font-size:17px!important;}
  .io-wall-stage{margin:8px!important;min-height:0!important;height:min(42vh,340px)!important;border-width:5px!important;border-radius:19px!important;}
  .io-wall-ui{padding:0 8px 10px!important;}
  .io-wall-popularity{margin-top:0!important;padding:7px 9px!important;gap:7px!important;border-radius:13px!important;}
  .io-wall-popularity span{font-size:10px!important;}
  .io-wall-popularity strong{font-size:18px!important;}
  .io-wall-popularity i{height:8px!important;}
  .io-wall-gameplay-status{margin-top:6px!important;gap:5px!important;}
  .io-wall-combo,.io-wall-mission{padding:6px 8px!important;border-radius:12px!important;}
  .io-wall-fever{display:none!important;}
  .io-wall-combo span,.io-wall-mission span{font-size:9px!important;}
  .io-wall-combo strong{font-size:15px!important;}
  .io-wall-mission strong{font-size:10px!important;line-height:1.25!important;}
  .io-wall-stats{margin-top:6px!important;gap:6px!important;}
  .io-wall-stats div{min-height:46px!important;border-radius:12px!important;}
  .io-wall-stats span{font-size:9px!important;}
  .io-wall-stats strong{font-size:18px!important;}
  .io-wall-message{margin-top:6px!important;padding:8px 10px!important;border-radius:13px!important;font-size:11px!important;line-height:1.45!important;}
  .io-wall-actions{margin-top:6px!important;gap:8px!important;}
  .io-wall-actions button{min-height:38px!important;font-size:12px!important;}
  .io-wall-boost{position:absolute!important;top:8px!important;left:50%!important;transform:translateX(-50%)!important;z-index:30!important;display:grid!important;grid-template-columns:auto auto!important;gap:7px!important;align-items:center!important;width:auto!important;max-width:86%!important;margin:0!important;padding:6px 10px!important;border-radius:999px!important;background:linear-gradient(135deg,rgba(255,216,59,.96),rgba(255,159,45,.96))!important;color:#6f3b00!important;box-shadow:0 10px 20px rgba(180,120,20,.23)!important;pointer-events:none!important;}
  .io-wall-boost[hidden]{display:none!important;}
  .io-wall-boost span{font-size:10px!important;color:#6f3b00!important;white-space:nowrap!important;}
  .io-wall-boost strong{font-size:12px!important;color:#6f3b00!important;white-space:nowrap!important;}
  .io-wall-fixed-open{min-height:38px!important;padding:0 14px!important;font-size:12px!important;right:14px!important;bottom:max(12px,env(safe-area-inset-bottom))!important;}
}
@media(max-width:640px){
  .io-wall-stage{height:min(39vh,315px)!important;}
  .io-wall-idol{width:72px!important;}
  .io-wall-free-cameko{width:56px!important;height:64px!important;margin:-32px 0 0 -28px!important;}
  .io-wall-crowd span{width:34px!important;height:52px!important;}
  .io-wall-head h3{font-size:11px!important;}
}
@media(max-height:720px) and (max-width:980px){
  .io-wall-stage{height:34vh!important;min-height:235px!important;}
  .io-wall-message{display:none!important;}
  .io-wall-actions button{min-height:34px!important;}
}
/* v6.04: stage height +300px and popularity max 2000 support */
@media(max-width:980px){
  .io-wall-stage{
    height:min(72vh, 640px)!important;
    min-height:540px!important;
  }
}
@media(max-width:640px){
  .io-wall-stage{
    height:min(68vh, 615px)!important;
    min-height:515px!important;
  }
}
@media(max-height:720px) and (max-width:980px){
  .io-wall-stage{
    height:calc(34vh + 300px)!important;
    min-height:535px!important;
  }
}
/* v6.04: stage height reduced by 150px from v6.01 */
@media(max-width:980px){
  .io-wall-stage{
    height:min(72vh, 490px)!important;
    min-height:390px!important;
  }
}
@media(max-width:640px){
  .io-wall-stage{
    height:min(68vh, 465px)!important;
    min-height:365px!important;
  }
}
@media(max-height:720px) and (max-width:980px){
  .io-wall-stage{
    height:calc(34vh + 150px)!important;
    min-height:385px!important;
  }
}
/* v6.04: move Ioki character speech bubble slightly away so it does not overlap the character */
@media(max-width:980px){
  .io-wall-idol span{
    top:-14px!important;
    right:-14px!important;
  }
}
@media(max-width:640px){
  .io-wall-idol span{
    top:-12px!important;
    right:-12px!important;
  }
}
/* v6.04: stage height reduced by 30px from v6.03 */
@media(max-width:980px){
  .io-wall-stage{
    height:min(72vh, 460px)!important;
    min-height:360px!important;
  }
}
@media(max-width:640px){
  .io-wall-stage{
    height:min(68vh, 435px)!important;
    min-height:335px!important;
  }
}
@media(max-height:720px) and (max-width:980px){
  .io-wall-stage{
    height:calc(34vh + 120px)!important;
    min-height:355px!important;
  }
}



/* v6.29: battle mini game copy, enemy art, gaze attack, call attack upgrades */
.io-battle-enemy{width:86px!important;height:86px!important;margin:-43px 0 0 -43px!important;padding:0!important;border:0!important;border-radius:0!important;background:transparent!important;box-shadow:none!important;overflow:visible}
.io-battle-enemy img{display:block;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 14px rgba(43,28,82,.22))}
.io-battle-enemy b,.io-battle-enemy span{display:none!important}
.io-battle-item{display:flex;flex-direction:column;align-items:center;justify-content:center;width:48px;height:48px;margin:-24px 0 0 -24px;border:2px solid rgba(255,255,255,.9);border-radius:999px;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.95),rgba(247,233,255,.92) 48%,rgba(231,201,255,.95));box-shadow:0 10px 22px rgba(117,67,180,.18)}
.io-battle-item small{display:block;margin-top:-1px;color:#7e44b5;font-size:8px;font-weight:900;letter-spacing:.06em;line-height:1}
.io-battle-item.is-heart{background:radial-gradient(circle at 35% 30%,#fff,rgba(255,232,244,.96) 48%,rgba(255,186,212,.95));}
.io-battle-item.is-mic{background:radial-gradient(circle at 35% 30%,#fff,rgba(236,232,255,.96) 48%,rgba(196,175,255,.95));}
.io-battle-item.is-light{background:radial-gradient(circle at 35% 30%,#fff,rgba(255,250,223,.96) 48%,rgba(255,232,157,.95));}
.io-battle-bullet{width:44px;height:18px;margin:-9px 0 0 -22px;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(234,183,255,.45) 22%,rgba(255,137,207,.95) 70%,rgba(255,255,255,0) 100%);box-shadow:0 0 16px rgba(224,155,255,.55);animation:none;display:flex;align-items:center;justify-content:flex-end;padding-right:6px}
.io-battle-bullet i{font-style:normal;color:#fff;font-size:14px;line-height:1;text-shadow:0 0 8px rgba(255,255,255,.65)}
.io-battle-bullet:before{content:'';position:absolute;left:-20px;top:50%;width:28px;height:6px;transform:translateY(-50%);border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(212,145,255,.85),rgba(255,200,235,.1))}
.io-battle-gaze{position:absolute;z-index:8;width:54px;height:14px;transform:translate(-50%,-50%);border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(218,151,255,.25) 35%,rgba(255,152,204,.75));box-shadow:0 0 12px rgba(218,151,255,.25);pointer-events:none;animation:ioBattleGaze .28s ease-out both}
.io-battle-gaze i{position:absolute;right:-2px;top:50%;transform:translateY(-52%);font-style:normal;color:#fff;font-size:12px;text-shadow:0 0 8px rgba(255,255,255,.7)}
@keyframes ioBattleGaze{from{opacity:.95;transform:translate(-50%,-50%) scaleX(.7)}to{opacity:0;transform:translate(70%,-50%) scaleX(1.25)}}
.io-battle-call{position:absolute;z-index:7;min-width:54px;max-width:110px;transform:translate(-50%,-50%);padding:5px 8px;border-radius:999px;background:rgba(255,255,255,.96);border:2px solid rgba(210,185,245,.92);box-shadow:0 8px 18px rgba(121,70,183,.18);pointer-events:none}
.io-battle-call span{display:block;color:#7f44b6;font-size:10px;font-weight:900;line-height:1.25;text-align:center;white-space:nowrap}
.io-battle-call:after{content:'';position:absolute;left:50%;bottom:-7px;width:12px;height:12px;transform:translateX(-50%) rotate(45deg);background:#fff;border-right:2px solid rgba(210,185,245,.92);border-bottom:2px solid rgba(210,185,245,.92)}
.io-battle-pop{white-space:nowrap}
.io-battle-game-head .io-battle-kicker{text-transform:none!important}
.io-battle-start-screen span{font-size:14px;line-height:1.6}
@media(max-width:640px){.io-battle-enemy{width:72px!important;height:72px!important;margin:-36px 0 0 -36px!important}.io-battle-call{min-width:46px;max-width:92px;padding:4px 6px}.io-battle-call span{font-size:9px}.io-battle-bullet{width:36px;height:16px;margin:-8px 0 0 -18px}.io-battle-gaze{width:44px;height:12px}}
/* v6.29: battle button text and transparent item visuals */
.io-battle-item{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  text-shadow:0 2px 8px rgba(80,40,120,.24);
}
.io-battle-item:before,
.io-battle-item:after{
  display:none!important;
  content:none!important;
}
.io-battle-item small{
  background:rgba(255,255,255,.72)!important;
  border-radius:999px!important;
  padding:1px 5px!important;
  box-shadow:0 3px 8px rgba(80,40,120,.12)!important;
}
.io-battle-item.is-heart,
.io-battle-item.is-mic,
.io-battle-item.is-light{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
/* v6.29: replace idol stage battle background image */
.io-battle-stage{
  background-image:
    linear-gradient(180deg, rgba(15,10,35,.14), rgba(12,8,28,.34)),
    url("assets/images/io-battle-stage-bg-v607.jpg")!important;
  background-size:cover!important;
  background-position:center center!important;
}
.io-battle-stage:before{
  background:
    radial-gradient(circle at 50% 18%, rgba(255,255,255,.26), transparent 24%),
    linear-gradient(180deg, rgba(42,18,76,.02), rgba(16,8,35,.28))!important;
}
/* v6.29: animated Ioki player and smaller enemies */
.io-battle-player{
  width:86px!important;
  height:86px!important;
}
.io-battle-player img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
}
.io-battle-player:after{
  display:none!important;
  content:none!important;
}
.io-battle-enemy{
  width:64px!important;
  height:64px!important;
  margin:-32px 0 0 -32px!important;
}
@media(max-width:640px){
  .io-battle-player{
    width:76px!important;
    height:76px!important;
  }
  .io-battle-enemy{
    width:56px!important;
    height:56px!important;
    margin:-28px 0 0 -28px!important;
  }
}
/* v6.29: fix player animation black artifacts and enforce smaller enemies */
.io-battle-player{
  width:86px!important;
  height:86px!important;
}
.io-battle-player img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  background:transparent!important;
}
.io-battle-stage .io-battle-enemy,
.io-battle-game .io-battle-enemy,
.io-battle-enemy{
  width:52px!important;
  height:52px!important;
  min-width:52px!important;
  min-height:52px!important;
  max-width:52px!important;
  max-height:52px!important;
  margin:-26px 0 0 -26px!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.io-battle-stage .io-battle-enemy img,
.io-battle-game .io-battle-enemy img,
.io-battle-enemy img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
}
@media(max-width:640px){
  .io-battle-player{
    width:76px!important;
    height:76px!important;
  }
  .io-battle-stage .io-battle-enemy,
  .io-battle-game .io-battle-enemy,
  .io-battle-enemy{
    width:46px!important;
    height:46px!important;
    min-width:46px!important;
    min-height:46px!important;
    max-width:46px!important;
    max-height:46px!important;
    margin:-23px 0 0 -23px!important;
  }
}
/* v6.29: v6.09 base, bottom 3 banners height +10px */
.io-banner-row .io-promo-banner,
.io-banner-row .io-promo-banner.has-custom-image{
  min-height:calc(var(--io-promo-banner-base-height, 116px) + 10px)!important;
}

.io-banner-row .io-promo-banner-image,
.io-banner-row .io-promo-banner.has-custom-image .io-promo-banner-image{
  min-height:calc(var(--io-promo-banner-base-height, 116px) + 10px)!important;
  object-fit:cover;
}

@media(max-width:720px){
  .io-banner-row .io-promo-banner,
  .io-banner-row .io-promo-banner.has-custom-image,
  .io-banner-row .io-promo-banner-image,
  .io-banner-row .io-promo-banner.has-custom-image .io-promo-banner-image{
    min-height:calc(var(--io-promo-banner-base-height-sp, 96px) + 10px)!important;
  }
}

/* v6.29: PC header top gap correction */
@media(min-width:981px){
  html:not(.wp-toolbar) body:not(.admin-bar) .io-header{
    top:0!important;
    margin-top:0!important;
  }

  html:not(.wp-toolbar) body:not(.admin-bar) .io-header-inner{
    padding-top:0!important;
    margin-top:0!important;
  }

  html:not(.wp-toolbar) body:not(.admin-bar) .io-nav{
    padding-top:0!important;
    margin-top:0!important;
    align-items:center!important;
  }

  body.admin-bar .io-header{
    top:32px!important;
    margin-top:0!important;
  }
}
/* v6.29: v6.09 base, bottom 3 banners height +20px total */
.io-banner-row .io-promo-banner,
.io-banner-row .io-promo-banner.has-custom-image{
  min-height:calc(var(--io-promo-banner-base-height, 116px) + 20px)!important;
}

.io-banner-row .io-promo-banner-image,
.io-banner-row .io-promo-banner.has-custom-image .io-promo-banner-image{
  min-height:calc(var(--io-promo-banner-base-height, 116px) + 20px)!important;
  object-fit:cover;
}

@media(max-width:720px){
  .io-banner-row .io-promo-banner,
  .io-banner-row .io-promo-banner.has-custom-image,
  .io-banner-row .io-promo-banner-image,
  .io-banner-row .io-promo-banner.has-custom-image .io-promo-banner-image{
    min-height:calc(var(--io-promo-banner-base-height-sp, 96px) + 20px)!important;
  }
}
/* v6.29: third mini game replacement, Ioki rhythm pose */



















@keyframes ioRhythmPop{from{opacity:1;transform:translate(-50%,-30%) scale(.9)}to{opacity:0;transform:translate(-50%,-120%) scale(1.2)}}







.io-nav [data-io-open-game-fanservice],.io-nav [data-io-open-game-station]{display:none!important}
@media(max-width:980px){}
@media(max-height:740px) and (max-width:980px){}
/* v6.29: third mini game replacement, simple Street Fighter style Ioki stage fight */
.io-fight-game-section[hidden]{display:none!important}
.io-fight-game{max-width:900px;margin:0 auto 56px;border:1px solid rgba(185,150,226,.45);border-radius:28px;background:linear-gradient(180deg,#fff,rgba(250,245,255,.96));box-shadow:0 20px 60px rgba(120,70,180,.16);overflow:hidden}
.io-fight-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:18px 20px 14px}
.io-fight-kicker{display:inline-block;color:#8e54d7;font-size:12px;font-weight:900;letter-spacing:.12em}
.io-fight-head h3{margin:4px 0 0;color:#5e337f;font-size:22px;line-height:1.35}
.io-fight-best{min-width:76px;padding:8px 10px;border-radius:16px;background:#f7efff;color:#8e54d7;text-align:center;font-size:10px;font-weight:900;letter-spacing:.12em}
.io-fight-best strong{display:block;color:#683199;font-size:22px;letter-spacing:0}
.io-fight-stage{position:relative;height:430px;margin:0 16px;border-radius:22px;overflow:hidden;background:linear-gradient(180deg,rgba(20,12,40,.05),rgba(24,10,52,.22)),url("assets/images/io-fight-stage-bg-v625.jpg") center/cover no-repeat;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.io-fight-hud{position:absolute;z-index:70;left:10px;right:10px;top:10px;display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
.io-fight-hp{padding:7px 9px;border-radius:12px;background:rgba(255,255,255,.9);box-shadow:0 8px 18px rgba(80,40,120,.12)}
.io-fight-hp span{display:block;margin-bottom:4px;color:#713ca2;font-size:10px;font-weight:900;letter-spacing:.12em}
.io-fight-hp i{display:block;height:10px;border-radius:999px;background:#efe3ff;overflow:hidden}
.io-fight-hp b{display:block;height:100%;width:100%;border-radius:999px;background:linear-gradient(90deg,#b26bff,#ff71ca)}
.io-fight-hp.is-enemy b{background:linear-gradient(90deg,#ff8b71,#ffca5f)}
.io-fight-round{padding:8px 10px;border-radius:999px;background:rgba(74,40,112,.88);color:#fff;font-size:11px;font-weight:900;letter-spacing:.08em;white-space:nowrap}
.io-fight-floor{position:absolute;left:0;right:0;bottom:0;height:40%;background:linear-gradient(180deg,transparent,rgba(22,10,50,.26));pointer-events:none}
.io-fight-player,.io-fight-enemy{position:absolute;z-index:30;bottom:14%;width:108px;height:168px;transform-origin:center bottom}
.io-fight-player{left:25%}
.io-fight-enemy{left:74%}
.io-fight-player img,.io-fight-enemy img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 16px 14px rgba(25,12,45,.28))}
.io-fight-player.is-damaged img,.io-fight-enemy.is-damaged img{filter:brightness(1.25) saturate(1.4) drop-shadow(0 16px 14px rgba(25,12,45,.28))}
.io-fight-effects{position:absolute;inset:0;z-index:90;pointer-events:none}
.io-fight-hit{position:absolute;width:84px;height:84px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.95),rgba(255,126,218,.65) 40%,rgba(255,255,255,0) 70%);animation:ioFightHit .36s ease-out both}
@keyframes ioFightHit{from{opacity:1;transform:translate(-50%,-50%) scale(.4)}to{opacity:0;transform:translate(-50%,-50%) scale(1.4)}}
.io-fight-pop{position:absolute;z-index:95;transform:translate(-50%,-50%);color:#fff;font-weight:900;text-shadow:0 2px 8px rgba(80,40,120,.7);animation:ioFightPop .85s ease-out both;white-space:nowrap}
.io-fight-pop.is-hit{font-size:20px;color:#fff3fb}
@keyframes ioFightPop{from{opacity:1;transform:translate(-50%,-20%) scale(1)}to{opacity:0;transform:translate(-50%,-120%) scale(1.2)}}
.io-fight-start-screen{position:absolute;inset:0;z-index:100;display:grid;place-content:center;text-align:center;background:rgba(55,25,86,.48);backdrop-filter:blur(2px);color:#fff}
.io-fight-start-screen[hidden]{display:none!important}
.io-fight-start-screen strong{font-size:38px;letter-spacing:.16em}
.io-fight-start-screen span{margin-top:10px;font-weight:900;max-width:300px;line-height:1.55}
.io-fight-ui{padding:14px 16px 18px}
.io-fight-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.io-fight-stats div{padding:8px 6px;border-radius:14px;background:#fff;border:1px solid rgba(190,160,230,.35);text-align:center}
.io-fight-stats span{display:block;color:#9d75ca;font-size:10px;font-weight:900;letter-spacing:.14em}
.io-fight-stats strong{display:block;color:#6d30a5;font-size:22px}
.io-fight-message{margin:8px 0 0;padding:9px 12px;border-radius:14px;background:#fff;color:#673789;font-weight:900;line-height:1.5}
.io-fight-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.io-fight-actions button{min-height:48px;border:0;border-radius:999px;background:linear-gradient(135deg,#b15dff,#ff6fc9);color:#fff;font-weight:900;font-size:15px;box-shadow:0 10px 20px rgba(160,80,200,.22);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.io-fight-actions button[disabled]{opacity:.45}
.io-fight-actions button[data-fight-action]{background:linear-gradient(135deg,#ff71ca,#ffb347)}
@media(max-width:980px){.io-fight-game{margin-inline:10px;border-radius:22px}.io-fight-head{padding:12px}.io-fight-head h3{font-size:14px}.io-fight-stage{height:360px;margin:0 10px}.io-fight-player,.io-fight-enemy{width:84px;height:136px;bottom:13%}.io-fight-start-screen strong{font-size:28px}.io-fight-message{font-size:12px}.io-fight-actions button{min-height:46px}}
@media(max-height:740px) and (max-width:980px){.io-fight-stage{height:315px}.io-fight-message{display:none}}
/* v6.29: remove obsolete rhythm-pose menu and expose stage-fight menu */
[data-io-open-game-rhythm],
a[href*="mini-game-rhythm"],
button[data-io-open-game-rhythm]{
  display:none!important;
}
.io-nav [data-io-open-game-fight],
.io-menu [data-io-open-game-fight],
.io-mobile-menu [data-io-open-game-fight],
.io-drawer [data-io-open-game-fight]{
  cursor:pointer;
}
/* v6.29: side-scroll stage fight upgrade */
.io-fight-stage{
  touch-action:none!important;
}
.io-fight-player,
.io-fight-enemy{
  bottom:6%!important;
}
.io-fight-player{
  width:96px!important;
  height:148px!important;
}
.io-fight-enemy{
  width:78px!important;
  height:120px!important;
}
.io-fight-enemy.is-boss{
  width:98px!important;
  height:148px!important;
}
.io-fight-item{
  position:absolute;
  z-index:50;
  transform:translate(-50%,-50%);
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:22px;
  font-weight:900;
  color:#fff;
  text-shadow:0 1px 8px rgba(80,40,120,.55);
  box-shadow:0 8px 18px rgba(80,40,120,.22);
}
.io-fight-item.is-coin{
  background:linear-gradient(135deg,#ffd85a,#ff9f2e);
}
.io-fight-item.is-heart{
  background:linear-gradient(135deg,#ff7ac8,#b865ff);
}
.io-fight-projectile{
  position:absolute;
  z-index:55;
  transform:translate(-50%,-50%);
  width:26px;
  height:26px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.95);
  color:#9c4be0;
  font-weight:900;
  box-shadow:0 0 14px rgba(255,255,255,.8),0 7px 16px rgba(80,40,120,.22);
}
.io-fight-stage:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:26%;
  background:
    repeating-linear-gradient(90deg,rgba(255,255,255,.10) 0 2px,transparent 2px 70px),
    linear-gradient(180deg,transparent,rgba(20,8,40,.24));
  pointer-events:none;
}
@media(max-width:980px){
  .io-fight-hud{
    top:6px!important;
  }
  .io-fight-player{
    bottom:5%!important;
    width:78px!important;
    height:126px!important;
  }
  .io-fight-enemy{
    bottom:5%!important;
    width:60px!important;
    height:92px!important;
  }
  .io-fight-enemy.is-boss{
    width:80px!important;
    height:120px!important;
  }
}
/* v6.29: tap jump and walking animations */
.io-fight-player img,
.io-fight-enemy img{
  image-rendering:auto;
}
.io-fight-player{
  transition:left .08s linear,bottom .08s linear!important;
}
.io-fight-enemy{
  transition:left .08s linear!important;
}
.io-fight-stage:before{
  content:"TAP: JUMP / SWIPE: MOVE";
  position:absolute;
  left:50%;
  bottom:6px;
  z-index:75;
  transform:translateX(-50%);
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.78);
  color:#6d30a5;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  pointer-events:none;
}
@media(max-width:980px){
  .io-fight-stage:before{
    bottom:4px;
    font-size:9px;
  }
}
/* v6.29: enemy direction fix, camera-flash short attack, higher jump and stomp */
.io-fight-projectile{
  display:none!important;
}
.io-fight-camera-flash{
  position:absolute;
  z-index:62;
  width:86px;
  height:66px;
  transform:translate(-50%,-50%);
  pointer-events:none;
  animation:ioFightCameraFlash .42s ease-out both;
}
.io-fight-camera-flash i{
  position:absolute;
  inset:0;
  display:block;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,246,180,.92) 28%,rgba(255,255,255,.35) 54%,rgba(255,255,255,0) 72%);
  box-shadow:0 0 24px rgba(255,255,255,.92),0 0 44px rgba(255,235,140,.58);
}
.io-fight-camera-flash b{
  position:absolute;
  left:-18px;
  top:50%;
  width:92px;
  height:34px;
  transform:translateY(-50%) skewX(-12deg);
  border-radius:999px;
  background:linear-gradient(90deg,rgba(255,255,255,.92),rgba(255,240,160,.45),rgba(255,255,255,0));
  filter:blur(.4px);
}
.io-fight-camera-flash.is-boss{
  width:112px;
  height:86px;
}
@keyframes ioFightCameraFlash{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.45)}
  18%{opacity:1;transform:translate(-50%,-50%) scale(1.16)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.55)}
}
.io-fight-player{
  will-change:left,bottom,transform;
}
.io-fight-enemy{
  will-change:left,transform;
}
.io-fight-pop.is-hit{
  white-space:nowrap;
}
@media(max-width:980px){
  .io-fight-camera-flash{
    width:70px;
    height:54px;
  }
  .io-fight-camera-flash.is-boss{
    width:92px;
    height:72px;
  }
}

/* v6.30: visible jump, jump-only obstacles and endless boss loops */
.io-fight-player{
  transition:left .08s linear!important;
}
.io-fight-player.is-jumping img{
  filter:drop-shadow(0 22px 18px rgba(25,12,45,.24));
}
.io-fight-obstacle{
  position:absolute;
  z-index:32;
  bottom:6%;
  transform:translateX(-50%);
  pointer-events:none;
  filter:drop-shadow(0 9px 8px rgba(20,10,42,.26));
}
.io-fight-obstacle.is-case{
  width:58px;
  height:52px;
  border:3px solid #382a51;
  border-radius:7px;
  background:
    linear-gradient(90deg,transparent 0 9px,rgba(255,255,255,.18) 9px 12px,transparent 12px 46px,rgba(255,255,255,.18) 46px 49px,transparent 49px),
    linear-gradient(180deg,#7d55a9,#4b346b);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
}
.io-fight-obstacle.is-case:before,
.io-fight-obstacle.is-case:after{
  content:"";
  position:absolute;
  bottom:-6px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#241a35;
  box-shadow:inset 0 0 0 2px #6f6382;
}
.io-fight-obstacle.is-case:before{left:7px}
.io-fight-obstacle.is-case:after{right:7px}
.io-fight-obstacle.is-case span{
  position:absolute;
  left:50%;
  top:8px;
  width:22px;
  height:7px;
  transform:translateX(-50%);
  border:2px solid #d9c8ef;
  border-bottom:0;
  border-radius:5px 5px 0 0;
}
.io-fight-obstacle.is-case i,
.io-fight-obstacle.is-case b{
  position:absolute;
  top:19px;
  width:7px;
  height:14px;
  border-radius:2px;
  background:#d9c8ef;
  box-shadow:0 0 0 2px #382a51;
}
.io-fight-obstacle.is-case i{left:7px}
.io-fight-obstacle.is-case b{right:7px}
.io-fight-obstacle.is-barrier{
  width:78px;
  height:42px;
}
.io-fight-obstacle.is-barrier:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:4px;
  height:25px;
  border:3px solid #4d315f;
  border-radius:7px;
  background:repeating-linear-gradient(135deg,#ffd968 0 12px,#ff7ca8 12px 24px);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.28);
}
.io-fight-obstacle.is-barrier:after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  bottom:0;
  height:13px;
  border-left:6px solid #4d315f;
  border-right:6px solid #4d315f;
}
.io-fight-obstacle.is-barrier span{
  position:absolute;
  left:50%;
  bottom:0;
  width:68px;
  height:6px;
  transform:translateX(-50%);
  border-radius:999px;
  background:#4d315f;
}
.io-fight-obstacle.is-barrier i,
.io-fight-obstacle.is-barrier b{
  display:none;
}
.io-fight-pop.is-loop{
  color:#fff6a8;
  font-size:24px;
  text-shadow:0 2px 12px rgba(90,40,120,.8);
}
@media(max-width:980px){
  .io-fight-obstacle{
    bottom:5%;
  }
  .io-fight-obstacle.is-case{
    width:48px;
    height:43px;
  }
  .io-fight-obstacle.is-barrier{
    width:64px;
    height:36px;
  }
  .io-fight-obstacle.is-barrier:before{
    height:22px;
  }
  .io-fight-obstacle.is-barrier span{
    width:56px;
  }
  .io-fight-pop.is-loop{
    font-size:20px;
  }
}


/* v6.31: chibi Ioki animation frames, heart projectiles, tighter hitboxes */
.io-fight-player{
  width:112px!important;
  height:172px!important;
}
.io-fight-player img{
  object-fit:contain;
}
.io-fight-projectile{
  display:grid!important;
  position:absolute;
  z-index:58;
  width:34px;
  height:34px;
  transform:translate(-50%,-50%) rotate(-8deg);
  place-items:center;
  border-radius:999px;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.98),rgba(255,255,255,.92) 18%,rgba(255,166,213,.94) 44%,rgba(189,94,255,.92) 76%,rgba(189,94,255,.12) 100%);
  box-shadow:0 0 18px rgba(255,255,255,.88),0 10px 18px rgba(111,47,171,.26);
  animation:ioFightHeartFloat .36s ease-in-out infinite alternate;
}
.io-fight-projectile span{
  display:block;
  color:#ff4aa4;
  font-size:18px;
  line-height:1;
  transform:translateY(-1px);
  text-shadow:0 1px 2px rgba(255,255,255,.72),0 0 8px rgba(255,255,255,.72);
}
.io-fight-projectile.is-special{
  width:42px;
  height:42px;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.99),rgba(255,255,255,.94) 20%,rgba(255,197,225,.98) 42%,rgba(255,113,196,.96) 70%,rgba(185,99,255,.36) 100%);
  box-shadow:0 0 24px rgba(255,255,255,.9),0 12px 22px rgba(111,47,171,.32);
}
.io-fight-projectile.is-special span{
  font-size:22px;
}
.io-fight-hit.is-heart{
  width:62px;
  height:62px;
  background:radial-gradient(circle,rgba(255,255,255,.98),rgba(255,168,214,.82) 38%,rgba(255,255,255,0) 74%);
}
@keyframes ioFightHeartFloat{
  from{transform:translate(-50%,-50%) rotate(-10deg) scale(.96)}
  to{transform:translate(-50%,-53%) rotate(8deg) scale(1.04)}
}
@media(max-width:980px){
  .io-fight-player{
    width:90px!important;
    height:140px!important;
  }
  .io-fight-projectile{
    width:28px;
    height:28px;
  }
  .io-fight-projectile span{
    font-size:15px;
  }
  .io-fight-projectile.is-special{
    width:36px;
    height:36px;
  }
  .io-fight-projectile.is-special span{
    font-size:19px;
  }
}


/* v6.33: title cleanup, lower heart origin, enemy flash shots */
.io-fight-game-section .io-section-center{margin-bottom:12px!important}
.io-fight-kicker{font-size:13px!important;letter-spacing:.08em!important}
.io-fight-camera-shot{position:absolute;z-index:61;width:58px;height:26px;transform:translate(-50%,-50%);pointer-events:none;filter:drop-shadow(0 0 10px rgba(255,255,255,.92)) drop-shadow(0 8px 14px rgba(255,232,135,.28));animation:ioFightFlashShotPulse .18s ease-in-out infinite alternate}
.io-fight-camera-shot i{position:absolute;right:0;top:50%;width:26px;height:26px;transform:translateY(-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,247,190,.96) 30%,rgba(255,255,255,.40) 58%,rgba(255,255,255,0) 76%);box-shadow:0 0 16px rgba(255,255,255,.95),0 0 28px rgba(255,240,160,.55)}
.io-fight-camera-shot b{position:absolute;left:0;top:50%;width:42px;height:14px;transform:translateY(-50%) skewX(-18deg);border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,248,214,.42),rgba(255,255,255,.95));filter:blur(.2px)}
.io-fight-camera-shot.is-boss{width:74px;height:34px}
.io-fight-camera-shot.is-boss i{width:34px;height:34px}
.io-fight-camera-shot.is-boss b{width:54px;height:18px}
@keyframes ioFightFlashShotPulse{from{opacity:.88;transform:translate(-50%,-50%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1.04)}}
@media(max-width:980px){.io-fight-camera-shot{width:46px;height:22px}.io-fight-camera-shot i{width:22px;height:22px}.io-fight-camera-shot b{width:32px;height:12px}.io-fight-camera-shot.is-boss{width:60px;height:28px}.io-fight-camera-shot.is-boss i{width:28px;height:28px}.io-fight-camera-shot.is-boss b{width:42px;height:14px}}


/* v6.34: lower heart origin and restore player/enemy vertical balance */
.io-fight-player{width:100px!important;height:154px!important;bottom:6%!important}
@media(max-width:980px){.io-fight-player{width:82px!important;height:128px!important;bottom:5%!important}}


/* v6.35: lower player visual baseline, lower heart origin, version bump */
.io-fight-player{width:98px!important;height:150px!important;bottom:5.2%!important}
@media(max-width:980px){.io-fight-player{width:80px!important;height:124px!important;bottom:4.2%!important}}


/* v6.36: smartphone mini game submenu in hamburger menu */
.io-mobile-nav-game-group,
.io-mini-game-submenu{
  display:none!important;
}
@media (max-width:980px), (pointer:coarse){
  .io-mobile-nav-game-group{
    display:block!important;
    list-style:none;
  }
  .io-mini-game-toggle{
    position:relative;
    display:grid;
    grid-template-columns:28px 1fr 18px;
    grid-template-rows:auto auto;
    align-items:center;
    justify-items:start;
    width:100%;
    min-height:58px;
    padding:10px 18px;
    border:0;
    border-bottom:1px solid rgba(232,216,255,.72);
    background:transparent;
    color:#6e39a8;
    font:inherit;
    text-align:left;
    cursor:pointer;
  }
  .io-mini-game-toggle span{
    grid-row:1 / span 2;
    align-self:center;
    color:#c392fb;
    font-size:16px;
  }
  .io-mini-game-toggle strong{
    margin:0;
    font-size:12px;
    line-height:1.2;
    letter-spacing:.08em;
    font-weight:900;
  }
  .io-mini-game-toggle small{
    margin-top:2px;
    color:#9d75ca;
    font-size:9px;
    line-height:1.2;
    font-weight:900;
  }
  .io-mini-game-toggle i{
    grid-column:3;
    grid-row:1 / span 2;
    align-self:center;
    justify-self:end;
    width:9px;
    height:9px;
    border-right:2px solid #9b66d5;
    border-bottom:2px solid #9b66d5;
    transform:rotate(45deg) translateY(-2px);
    transition:transform .2s ease;
  }
  .io-mini-game-toggle[aria-expanded="true"]{
    background:linear-gradient(90deg,rgba(245,235,255,.86),rgba(255,255,255,.9));
  }
  .io-mini-game-toggle[aria-expanded="true"] i{
    transform:rotate(225deg) translate(-2px,-2px);
  }
  .io-mini-game-submenu{
    display:block!important;
    margin:0;
    padding:6px 10px 9px 42px;
    list-style:none;
    background:linear-gradient(180deg,rgba(249,244,255,.96),rgba(255,255,255,.98));
    border-bottom:1px solid rgba(232,216,255,.72);
  }
  .io-mini-game-submenu[hidden]{
    display:none!important;
  }
  .io-mini-game-submenu li{
    margin:0;
  }
  .io-mini-game-submenu button{
    display:block;
    width:100%;
    min-height:54px;
    padding:9px 12px;
    border:0;
    border-radius:12px;
    background:transparent;
    color:#673789;
    font:inherit;
    text-align:left;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
  }
  .io-mini-game-submenu button:active{
    background:#f1e4ff;
  }
  .io-mini-game-submenu strong{
    display:block;
    font-size:12px;
    line-height:1.35;
    font-weight:900;
  }
  .io-mini-game-submenu small{
    display:block;
    margin-top:3px;
    color:#a77bca;
    font-size:9px;
    line-height:1.3;
    font-weight:900;
  }
  .io-wall-fixed-open{
    display:none!important;
  }
}


/* v6.37: renamed mini games and title-position menu scrolling */
[data-io-game-title-battle],
[data-io-game-title-wall],
[data-io-game-title-fight]{
  scroll-margin-top:96px;
}
@media(max-width:980px){
  [data-io-game-title-battle],
  [data-io-game-title-wall],
  [data-io-game-title-fight]{
    scroll-margin-top:84px;
  }
}


/* v6.38: mini-game heading cleanup, stage scroll targets, mobile menu order */
.io-battle-game-section .io-section-center{
  margin-bottom:8px!important;
}
.io-battle-stage,
.io-wall-stage{
  scroll-margin-top:96px;
}
@media(max-width:980px){
  .io-battle-game-section .io-section-center{
    margin-bottom:6px!important;
  }
  .io-battle-stage,
  .io-wall-stage{
    scroll-margin-top:88px;
  }
}


/* v6.39: smartphone 3x3 icon grid navigation */
@media (max-width:900px){
  .io-nav.is-open{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
    padding:16px;
    border-radius:28px;
    background:rgba(255,255,255,.97);
  }
  .io-nav.is-open > .io-menu{
    grid-column:1 / -1;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
    width:100%;
  }
  .io-menu > li{
    min-width:0;
    margin:0!important;
  }
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    position:relative;
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:34px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    place-items:center!important;
    width:100%!important;
    min-width:0!important;
    min-height:98px!important;
    padding:11px 5px 9px!important;
    border:1px solid rgba(226,207,250,.92)!important;
    border-radius:18px!important;
    background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(248,241,255,.96))!important;
    box-shadow:0 9px 22px rgba(109,62,167,.10)!important;
    color:#6e39a8!important;
    text-align:center!important;
    line-height:1.15!important;
    overflow:hidden;
    -webkit-tap-highlight-color:transparent;
  }
  .io-nav.is-open > a:active,
  .io-menu > li > a:active,
  .io-mini-game-toggle:active,
  .io-mini-game-toggle[aria-expanded="true"]{
    background:linear-gradient(145deg,#f2e4ff,#fff5fc)!important;
    transform:translateY(1px);
  }
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    grid-column:1!important;
    grid-row:1!important;
    align-self:center!important;
    color:#b86cf1!important;
    font-size:25px!important;
    line-height:1!important;
  }
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    grid-column:1!important;
    grid-row:2!important;
    display:block!important;
    margin:2px 0 0!important;
    color:#713ca2!important;
    font-size:10px!important;
    line-height:1.25!important;
    letter-spacing:.04em!important;
    font-weight:900!important;
    text-align:center!important;
    word-break:break-word;
  }
  .io-nav.is-open > a small,
  .io-menu > li > a small,
  .io-mini-game-toggle small{
    grid-column:1!important;
    grid-row:3!important;
    display:block!important;
    margin:2px 0 0!important;
    color:#a27ac2!important;
    font-size:8px!important;
    line-height:1.2!important;
    font-weight:900!important;
    text-align:center!important;
  }
  .io-mini-game-toggle i{
    position:absolute!important;
    top:9px!important;
    right:9px!important;
    width:7px!important;
    height:7px!important;
    border-right:2px solid #a26dd7!important;
    border-bottom:2px solid #a26dd7!important;
    transform:rotate(45deg)!important;
  }
  .io-mini-game-toggle[aria-expanded="true"] i{
    transform:rotate(225deg)!important;
    top:12px!important;
  }
  .io-mobile-nav-game-group{
    min-width:0;
  }
  .io-mobile-nav-game-group.is-submenu-open{
    grid-column:1 / -1;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
  }
  .io-mobile-nav-game-group.is-submenu-open > .io-mini-game-toggle{
    grid-column:1;
  }
  .io-mini-game-submenu{
    grid-column:1 / -1;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    margin:0!important;
    padding:10px!important;
    border:1px solid rgba(226,207,250,.88)!important;
    border-radius:18px!important;
    background:linear-gradient(145deg,rgba(250,245,255,.98),rgba(255,255,255,.98))!important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.85);
  }
  .io-mini-game-submenu[hidden]{
    display:none!important;
  }
  .io-mini-game-submenu li{
    min-width:0;
    margin:0!important;
  }
  .io-mini-game-submenu button{
    display:grid!important;
    grid-template-rows:30px auto auto;
    align-items:center;
    justify-items:center;
    width:100%!important;
    min-height:112px!important;
    padding:9px 5px!important;
    border:1px solid rgba(230,214,250,.92)!important;
    border-radius:15px!important;
    background:rgba(255,255,255,.92)!important;
    box-shadow:0 6px 15px rgba(109,62,167,.08);
    color:#673789!important;
    text-align:center!important;
  }
  .io-mini-game-submenu button:active{
    background:#f1e4ff!important;
  }
  .io-mini-game-submenu-icon{
    display:block!important;
    font-size:22px!important;
    line-height:1!important;
  }
  .io-mini-game-submenu strong{
    display:block!important;
    margin:3px 0 0!important;
    font-size:9px!important;
    line-height:1.28!important;
    font-weight:900!important;
    word-break:break-word;
  }
  .io-mini-game-submenu small{
    display:block!important;
    margin:3px 0 0!important;
    color:#a77bca!important;
    font-size:7px!important;
    line-height:1.25!important;
    font-weight:900!important;
  }
}
@media (max-width:380px){
  .io-nav.is-open{
    gap:7px;
    padding:12px;
  }
  .io-nav.is-open > .io-menu,
  .io-mobile-nav-game-group.is-submenu-open{
    gap:7px;
  }
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    min-height:91px!important;
    border-radius:15px!important;
  }
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    font-size:9px!important;
  }
}


/* v6.40: larger mobile grid icons and overlay mini-game submenu */
@media (max-width:900px){
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    grid-template-rows:42px auto auto!important;
    min-height:108px!important;
    padding:12px 5px 10px!important;
  }
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    font-size:31px!important;
  }
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    font-size:12px!important;
    line-height:1.22!important;
    letter-spacing:.035em!important;
  }
  .io-nav.is-open > a small,
  .io-menu > li > a small,
  .io-mini-game-toggle small{
    font-size:9px!important;
  }
  .io-nav.is-open > .io-menu,
  .io-menu{
    position:relative;
  }
  .io-mobile-nav-game-group{
    position:relative;
    z-index:2;
  }
  .io-mobile-nav-game-group.is-submenu-open{
    grid-column:auto!important;
    display:block!important;
    z-index:80;
  }
  .io-mobile-nav-game-group.is-submenu-open > .io-mini-game-toggle{
    grid-column:auto!important;
  }
  .io-mini-game-submenu{
    position:absolute!important;
    z-index:90!important;
    top:calc(100% + 10px)!important;
    left:calc(-100% - 10px)!important;
    width:calc(300% + 20px)!important;
    grid-column:auto!important;
    margin:0!important;
    padding:10px!important;
    background:rgba(255,255,255,.99)!important;
    box-shadow:0 18px 42px rgba(83,35,128,.24),inset 0 0 0 1px rgba(255,255,255,.9)!important;
  }
  .io-mini-game-submenu button{
    min-height:108px!important;
    grid-template-rows:38px auto auto!important;
  }
  .io-mini-game-submenu-icon{
    font-size:28px!important;
  }
  .io-mini-game-submenu strong{
    font-size:10px!important;
    line-height:1.22!important;
  }
  .io-mini-game-submenu small{
    font-size:8px!important;
  }
}
@media (max-width:380px){
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    min-height:101px!important;
  }
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    font-size:28px!important;
  }
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    font-size:11px!important;
  }
  .io-mini-game-submenu{
    top:calc(100% + 7px)!important;
    left:calc(-100% - 7px)!important;
    width:calc(300% + 14px)!important;
  }
  .io-mini-game-submenu button{
    min-height:101px!important;
  }
}


/* v6.41: pastel color-coded smartphone menu buttons */
@media (max-width:900px){
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle,
  .io-mini-game-submenu button{
    transition:transform .12s ease,filter .12s ease,box-shadow .12s ease!important;
  }
  .io-nav.is-open > a:active,
  .io-menu > li > a:active,
  .io-mini-game-toggle:active,
  .io-mini-game-submenu button:active{
    filter:brightness(.97) saturate(1.08)!important;
    transform:translateY(1px)!important;
  }
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    width:44px!important;
    height:44px!important;
    display:grid!important;
    place-items:center!important;
    border-radius:15px!important;
    background:rgba(255,255,255,.62)!important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.78),0 5px 12px rgba(109,62,167,.08)!important;
  }

  .io-nav.is-open > a[href*="#top"],
  .io-menu > li > a[href*="#top"]{
    background:linear-gradient(145deg,#f3ecff,#fbf8ff)!important;
    border-color:#dfd0f6!important;
  }
  .io-nav.is-open > a[href*="#schedule"],
  .io-menu > li > a[href*="#schedule"]{
    background:linear-gradient(145deg,#e9f5ff,#f7fbff)!important;
    border-color:#cfe6f8!important;
  }
  .io-nav.is-open > a[href*="#news"],
  .io-menu > li > a[href*="#news"]{
    background:linear-gradient(145deg,#fff8dc,#fffdf4)!important;
    border-color:#f4e6b3!important;
  }
  .io-nav.is-open > a[href*="#profile"],
  .io-menu > li > a[href*="#profile"]{
    background:linear-gradient(145deg,#ffeaf4,#fff8fb)!important;
    border-color:#f4d2e2!important;
  }
  .io-mini-game-toggle,
  .io-mini-game-toggle[aria-expanded="true"]{
    background:linear-gradient(145deg,#eee7ff,#faf7ff)!important;
    border-color:#d9c9f6!important;
  }
  .io-nav.is-open > a[href*="#release"],
  .io-menu > li > a[href*="#release"]{
    background:linear-gradient(145deg,#fff0e5,#fffaf6)!important;
    border-color:#f3d9c6!important;
  }
  .io-nav.is-open > a[href*="#movie"],
  .io-menu > li > a[href*="#movie"]{
    background:linear-gradient(145deg,#e8faef,#f7fdf9)!important;
    border-color:#ccebd7!important;
  }
  .io-nav.is-open > a[href*="#goods"],
  .io-menu > li > a[href*="#goods"]{
    background:linear-gradient(145deg,#ffe9ee,#fff7f9)!important;
    border-color:#f4cfd8!important;
  }
  .io-nav.is-open > a[href*="#contact"],
  .io-menu > li > a[href*="#contact"]{
    background:linear-gradient(145deg,#e8faf8,#f7fdfc)!important;
    border-color:#ccebe7!important;
  }

  .io-mini-game-submenu{
    background:linear-gradient(145deg,rgba(251,247,255,.99),rgba(255,255,255,.99))!important;
  }
  .io-mini-game-submenu li:nth-child(1) button{
    background:linear-gradient(145deg,#ffe9f4,#fff8fc)!important;
    border-color:#f3d0e2!important;
  }
  .io-mini-game-submenu li:nth-child(2) button{
    background:linear-gradient(145deg,#e9f5ff,#f8fcff)!important;
    border-color:#cfe5f6!important;
  }
  .io-mini-game-submenu li:nth-child(3) button{
    background:linear-gradient(145deg,#f0eaff,#fbf8ff)!important;
    border-color:#dbcdf5!important;
  }
  .io-mini-game-submenu-icon{
    width:42px!important;
    height:42px!important;
    display:grid!important;
    place-items:center!important;
    border-radius:14px!important;
    background:rgba(255,255,255,.68)!important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.8),0 5px 12px rgba(109,62,167,.08)!important;
  }
}
@media (max-width:380px){
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    width:40px!important;
    height:40px!important;
    border-radius:13px!important;
  }
  .io-mini-game-submenu-icon{
    width:38px!important;
    height:38px!important;
    border-radius:12px!important;
  }
}


/* v6.42: remove white icon cushions from smartphone grid menu */
@media (max-width:900px){
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span,
  .io-mini-game-submenu-icon{
    background:transparent!important;
    box-shadow:none!important;
  }
}


/* v6.43: semi-transparent white cushions beneath mobile menu buttons */
@media (max-width:900px){
  .io-nav.is-open{
    background:rgba(255,255,255,.84)!important;
    -webkit-backdrop-filter:blur(14px);
    backdrop-filter:blur(14px);
  }
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    box-shadow:0 9px 22px rgba(109,62,167,.08),inset 0 0 0 1px rgba(255,255,255,.38)!important;
  }
  .io-nav.is-open > a[href*="#top"],
  .io-menu > li > a[href*="#top"]{
    background:linear-gradient(145deg,rgba(243,236,255,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#schedule"],
  .io-menu > li > a[href*="#schedule"]{
    background:linear-gradient(145deg,rgba(233,245,255,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#news"],
  .io-menu > li > a[href*="#news"]{
    background:linear-gradient(145deg,rgba(255,248,220,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#profile"],
  .io-menu > li > a[href*="#profile"]{
    background:linear-gradient(145deg,rgba(255,234,244,.78),rgba(255,255,255,.30))!important;
  }
  .io-mini-game-toggle,
  .io-mini-game-toggle[aria-expanded="true"]{
    background:linear-gradient(145deg,rgba(238,231,255,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#release"],
  .io-menu > li > a[href*="#release"]{
    background:linear-gradient(145deg,rgba(255,240,229,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#movie"],
  .io-menu > li > a[href*="#movie"]{
    background:linear-gradient(145deg,rgba(232,250,239,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#goods"],
  .io-menu > li > a[href*="#goods"]{
    background:linear-gradient(145deg,rgba(255,233,238,.78),rgba(255,255,255,.30))!important;
  }
  .io-nav.is-open > a[href*="#contact"],
  .io-menu > li > a[href*="#contact"]{
    background:linear-gradient(145deg,rgba(232,250,248,.78),rgba(255,255,255,.30))!important;
  }
  .io-mini-game-submenu{
    background:linear-gradient(145deg,rgba(251,247,255,.82),rgba(255,255,255,.62))!important;
    -webkit-backdrop-filter:blur(12px);
    backdrop-filter:blur(12px);
  }
  .io-mini-game-submenu li:nth-child(1) button{
    background:linear-gradient(145deg,rgba(255,233,244,.78),rgba(255,255,255,.30))!important;
  }
  .io-mini-game-submenu li:nth-child(2) button{
    background:linear-gradient(145deg,rgba(233,245,255,.78),rgba(255,255,255,.30))!important;
  }
  .io-mini-game-submenu li:nth-child(3) button{
    background:linear-gradient(145deg,rgba(240,234,255,.78),rgba(255,255,255,.30))!important;
  }
}

/* v6.47: Design D - dreamy idol-stage smartphone grid menu */
@media (max-width:900px){
  .io-nav.is-open{
    position:relative;
    padding:14px!important;
    border:1px solid rgba(224,200,255,.92)!important;
    border-radius:30px!important;
    background:
      radial-gradient(ellipse at 12% 0%,rgba(255,229,250,.72),transparent 34%),
      radial-gradient(ellipse at 50% -8%,rgba(224,204,255,.88),transparent 38%),
      radial-gradient(ellipse at 88% 0%,rgba(246,228,255,.76),transparent 34%),
      linear-gradient(180deg,rgba(255,255,255,.94),rgba(247,239,255,.93))!important;
    box-shadow:0 22px 52px rgba(108,58,165,.22),inset 0 0 0 1px rgba(255,255,255,.86)!important;
    -webkit-backdrop-filter:blur(16px);
    backdrop-filter:blur(16px);
    overflow:visible!important;
  }
  .io-nav.is-open:before{
    content:"";
    position:absolute;
    inset:6px 10px auto;
    height:70px;
    pointer-events:none;
    background:
      radial-gradient(circle at 8% 14%,rgba(255,255,255,.95) 0 2px,transparent 3px),
      radial-gradient(circle at 24% 30%,rgba(255,221,249,.96) 0 2px,transparent 3px),
      radial-gradient(circle at 74% 24%,rgba(255,255,255,.95) 0 2px,transparent 3px),
      radial-gradient(circle at 92% 10%,rgba(232,211,255,.95) 0 2px,transparent 3px),
      linear-gradient(115deg,transparent 9%,rgba(255,255,255,.45) 10%,transparent 22%),
      linear-gradient(65deg,transparent 78%,rgba(255,255,255,.38) 80%,transparent 92%);
    opacity:.9;
  }
  .io-nav.is-open:after{
    content:"";
    position:absolute;
    left:14px;
    right:14px;
    bottom:12px;
    height:18px;
    pointer-events:none;
    background:
      radial-gradient(circle at 8% 50%,#cda3f5 0 2px,transparent 3px),
      radial-gradient(circle at 24% 50%,#ead7ff 0 2px,transparent 3px),
      radial-gradient(circle at 50% 50%,#b875ef 0 3px,transparent 4px),
      radial-gradient(circle at 76% 50%,#ead7ff 0 2px,transparent 3px),
      radial-gradient(circle at 92% 50%,#cda3f5 0 2px,transparent 3px);
    opacity:.72;
  }

  .io-nav.is-open > .io-menu{
    position:relative!important;
    grid-column:1 / -1;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:0!important;
    width:100%;
    margin:0!important;
    padding:50px 8px 24px!important;
    border:1px solid rgba(224,207,247,.86);
    border-radius:26px;
    background:
      radial-gradient(ellipse at 10% 0%,rgba(255,220,247,.32),transparent 28%),
      radial-gradient(ellipse at 50% 0%,rgba(226,203,255,.36),transparent 34%),
      radial-gradient(ellipse at 90% 0%,rgba(255,228,250,.30),transparent 28%),
      linear-gradient(180deg,rgba(255,255,255,.68),rgba(255,255,255,.36));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.88),0 9px 24px rgba(113,66,170,.10);
    overflow:visible!important;
  }
  .io-nav.is-open > .io-menu:before{
    content:"";
    position:absolute;
    z-index:4;
    top:-37px;
    left:50%;
    width:160px;
    height:60px;
    transform:translateX(-50%);
    background:url("assets/images/menu-v647/menu-bow-v647.svg") center/contain no-repeat;
    filter:drop-shadow(0 7px 8px rgba(123,65,183,.18));
    pointer-events:none;
  }
  .io-nav.is-open > .io-menu:after{
    content:"";
    position:absolute;
    z-index:1;
    top:2px;
    left:5%;
    right:5%;
    height:72px;
    pointer-events:none;
    background:
      linear-gradient(104deg,transparent 3%,rgba(255,255,255,.52) 4%,rgba(255,255,255,.08) 23%,transparent 24%),
      linear-gradient(76deg,transparent 76%,rgba(255,255,255,.08) 77%,rgba(255,255,255,.48) 96%,transparent 97%);
    opacity:.9;
  }

  .io-menu > li{
    position:relative;
    min-width:0;
    margin:0!important;
    border-right:1px dashed rgba(192,151,231,.38);
    border-bottom:1px dashed rgba(192,151,231,.38);
  }
  .io-menu > li:nth-child(3n){border-right:0}
  .io-menu > li:nth-child(n+7){border-bottom:0}

  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    position:relative;
    z-index:2;
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:62px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    place-items:center!important;
    width:100%!important;
    min-width:0!important;
    min-height:122px!important;
    padding:11px 4px 10px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    color:#6d35a9!important;
    text-align:center!important;
    line-height:1.15!important;
    overflow:visible!important;
    -webkit-tap-highlight-color:transparent;
    transition:transform .16s ease,filter .16s ease,background .16s ease!important;
  }
  .io-nav.is-open > a:active,
  .io-menu > li > a:active,
  .io-mini-game-toggle:active{
    transform:translateY(1px) scale(.985)!important;
    filter:brightness(.98) saturate(1.08)!important;
  }
  .io-menu > li > a:hover,
  .io-mini-game-toggle:hover{
    background:rgba(255,255,255,.22)!important;
  }

  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    grid-column:1!important;
    grid-row:1!important;
    display:block!important;
    width:72px!important;
    height:62px!important;
    margin:0!important;
    border-radius:0!important;
    background-color:transparent!important;
    background-position:center!important;
    background-repeat:no-repeat!important;
    background-size:contain!important;
    box-shadow:none!important;
    color:transparent!important;
    font-size:0!important;
    line-height:0!important;
    filter:drop-shadow(0 7px 8px rgba(109,54,168,.22));
  }
  .io-menu > li > a[data-io-menu-key="top"] span,
  .io-nav.is-open > a[data-io-menu-key="top"] span{background-image:url("assets/images/menu-v647/top-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="schedule"] span,
  .io-nav.is-open > a[data-io-menu-key="schedule"] span{background-image:url("assets/images/menu-v647/schedule-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="news"] span,
  .io-nav.is-open > a[data-io-menu-key="news"] span{background-image:url("assets/images/menu-v647/news-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="profile"] span,
  .io-nav.is-open > a[data-io-menu-key="profile"] span{background-image:url("assets/images/menu-v647/profile-v647.svg")!important}
  .io-mini-game-toggle span{background-image:url("assets/images/menu-v647/game-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="works"] span,
  .io-nav.is-open > a[data-io-menu-key="works"] span{background-image:url("assets/images/menu-v647/works-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="movie"] span,
  .io-nav.is-open > a[data-io-menu-key="movie"] span{background-image:url("assets/images/menu-v647/movie-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="goods"] span,
  .io-nav.is-open > a[data-io-menu-key="goods"] span{background-image:url("assets/images/menu-v647/goods-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="contact"] span,
  .io-nav.is-open > a[data-io-menu-key="contact"] span{background-image:url("assets/images/menu-v647/contact-v647.svg")!important}

  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    grid-column:1!important;
    grid-row:2!important;
    display:block!important;
    margin:3px 0 0!important;
    color:#6d35a9!important;
    font-family:Georgia,"Times New Roman","Noto Serif JP",serif!important;
    font-size:14px!important;
    font-weight:700!important;
    letter-spacing:.035em!important;
    line-height:1.18!important;
    white-space:nowrap;
    text-shadow:0 1px 0 rgba(255,255,255,.9);
  }
  .io-nav.is-open > a small,
  .io-menu > li > a small,
  .io-mini-game-toggle small{
    grid-column:1!important;
    grid-row:3!important;
    display:block!important;
    margin:5px 0 0!important;
    color:#8f65b7!important;
    font-size:10px!important;
    font-weight:800!important;
    letter-spacing:.025em!important;
    line-height:1.2!important;
    text-shadow:0 1px 0 rgba(255,255,255,.9);
  }

  .io-mobile-nav-game-group{
    position:relative!important;
    z-index:5;
  }
  .io-mini-game-toggle,
  .io-mini-game-toggle[aria-expanded="true"]{
    margin:5px!important;
    width:calc(100% - 10px)!important;
    min-height:112px!important;
    border:1px solid rgba(218,188,246,.88)!important;
    border-radius:18px!important;
    background:
      radial-gradient(circle at 50% 30%,rgba(255,255,255,.82),transparent 48%),
      linear-gradient(180deg,rgba(255,255,255,.68),rgba(241,226,255,.56))!important;
    box-shadow:0 10px 24px rgba(117,61,176,.15),inset 0 1px 0 rgba(255,255,255,.82)!important;
  }
  .io-mini-game-toggle:before{
    content:"";
    position:absolute;
    inset:-5px;
    z-index:-1;
    border-radius:22px;
    background:radial-gradient(circle,rgba(216,168,255,.22),rgba(216,168,255,0) 70%);
    pointer-events:none;
  }
  .io-mini-game-toggle i{
    position:absolute!important;
    top:8px!important;
    right:8px!important;
    width:22px!important;
    height:22px!important;
    border:1px solid rgba(255,255,255,.88)!important;
    border-radius:50%!important;
    background:linear-gradient(135deg,#d9b3ff,#8e52d4)!important;
    box-shadow:0 4px 10px rgba(108,54,166,.22)!important;
    transform:none!important;
  }
  .io-mini-game-toggle i:before,
  .io-mini-game-toggle i:after{
    content:"";
    position:absolute;
    top:9px;
    width:7px;
    height:2px;
    border-radius:2px;
    background:#fff;
  }
  .io-mini-game-toggle i:before{left:5px;transform:rotate(45deg)}
  .io-mini-game-toggle i:after{right:5px;transform:rotate(-45deg)}
  .io-mini-game-toggle[aria-expanded="true"] i{transform:rotate(180deg)!important}

  .io-mobile-nav-game-group.is-submenu-open{
    grid-column:auto!important;
    display:block!important;
    z-index:80!important;
  }
  .io-mini-game-submenu{
    position:absolute!important;
    z-index:90!important;
    top:calc(100% + 10px)!important;
    left:calc(-100% - 0px)!important;
    width:300%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:8px!important;
    margin:0!important;
    padding:10px!important;
    border:1px solid rgba(218,195,244,.94)!important;
    border-radius:20px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,238,255,.95))!important;
    box-shadow:0 18px 42px rgba(86,38,133,.22),inset 0 1px 0 rgba(255,255,255,.9)!important;
    -webkit-backdrop-filter:blur(14px);
    backdrop-filter:blur(14px);
  }
  .io-mini-game-submenu[hidden]{display:none!important}
  .io-mini-game-submenu li{
    border:0!important;
    min-width:0;
    margin:0!important;
  }
  .io-mini-game-submenu button{
    display:grid!important;
    grid-template-rows:34px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:102px!important;
    padding:9px 5px!important;
    border:1px solid rgba(226,207,247,.88)!important;
    border-radius:15px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(244,235,255,.76))!important;
    box-shadow:0 7px 16px rgba(109,62,167,.10),inset 0 1px 0 rgba(255,255,255,.88)!important;
    color:#673789!important;
    text-align:center!important;
  }
  .io-mini-game-submenu button:active{
    transform:translateY(1px)!important;
    filter:brightness(.98) saturate(1.08)!important;
  }
  .io-mini-game-submenu-icon{
    display:block!important;
    width:auto!important;
    height:auto!important;
    background:transparent!important;
    box-shadow:none!important;
    font-size:24px!important;
    line-height:1!important;
    filter:drop-shadow(0 4px 5px rgba(109,62,167,.16));
  }
  .io-mini-game-submenu strong{
    display:block!important;
    margin:3px 0 0!important;
    color:#7040aa!important;
    font-size:9px!important;
    line-height:1.22!important;
    font-weight:900!important;
    word-break:break-word;
  }
  .io-mini-game-submenu small{
    display:block!important;
    margin:3px 0 0!important;
    color:#9a73bd!important;
    font-size:7px!important;
    line-height:1.2!important;
    font-weight:900!important;
  }
}

@media (max-width:380px){
  .io-nav.is-open{padding:11px!important}
  .io-nav.is-open > .io-menu{padding:45px 5px 20px!important}
  .io-nav.is-open > .io-menu:before{width:142px;height:54px;top:-33px}
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{min-height:108px!important;grid-template-rows:54px auto auto!important}
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{width:62px!important;height:54px!important}
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{font-size:12px!important}
  .io-nav.is-open > a small,
  .io-menu > li > a small,
  .io-mini-game-toggle small{font-size:9px!important}
  .io-mini-game-submenu{top:calc(100% + 7px)!important;left:-100%!important;width:300%!important;padding:7px!important;gap:6px!important}
  .io-mini-game-submenu button{min-height:96px!important}
}


/* v6.48: refine mobile 3x3 menu to match approved Design D reference more closely */
@media (max-width:900px){
  .io-header-inner{
    align-items:flex-start!important;
  }
  .io-mobile-menu-button{
    width:104px!important;
    min-width:104px!important;
    height:104px!important;
    min-height:104px!important;
    padding:14px 10px 12px!important;
    border:2px solid rgba(214,191,245,.95)!important;
    border-radius:50%!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,239,255,.95))!important;
    box-shadow:0 10px 26px rgba(118,70,181,.18), inset 0 1px 0 rgba(255,255,255,.98)!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:40px auto!important;
    justify-items:center!important;
    align-items:center!important;
    gap:2px!important;
  }
  .io-mobile-menu-icon{
    width:34px!important;
    height:34px!important;
    display:grid!important;
    align-content:center!important;
    gap:6px!important;
  }
  .io-mobile-menu-icon i{
    height:3px!important;
    border-radius:999px!important;
    background:#8f4fe0!important;
    box-shadow:none!important;
  }
  .io-mobile-menu-text{
    font-size:13px!important;
    font-weight:800!important;
    line-height:1!important;
    letter-spacing:.12em!important;
    color:#8f4fe0!important;
  }
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(9px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(2){opacity:0!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-9px) rotate(-45deg)!important}

  .io-nav.is-open{
    padding:12px!important;
    border-radius:32px!important;
    border:2px solid rgba(225,204,248,.98)!important;
    background:linear-gradient(180deg,rgba(255,255,255,.93),rgba(250,245,255,.94))!important;
    box-shadow:0 20px 52px rgba(115,67,175,.18), inset 0 1px 0 rgba(255,255,255,.98)!important;
  }
  .io-nav.is-open:before{
    inset:0!important;
    height:auto!important;
    background:
      radial-gradient(circle at 12% 21%, rgba(255,255,255,.92) 0 3px, transparent 4px),
      radial-gradient(circle at 24% 18%, rgba(255,215,246,.95) 0 2px, transparent 3px),
      radial-gradient(circle at 84% 16%, rgba(255,255,255,.94) 0 2px, transparent 3px),
      radial-gradient(circle at 90% 28%, rgba(240,216,255,.95) 0 2px, transparent 3px),
      radial-gradient(circle at 8% 70%, rgba(244,223,255,.8) 0 2px, transparent 3px),
      radial-gradient(circle at 94% 76%, rgba(244,223,255,.8) 0 2px, transparent 3px);
    opacity:1!important;
  }
  .io-nav.is-open:after{
    left:18px!important;
    right:18px!important;
    bottom:10px!important;
    height:16px!important;
    background:
      radial-gradient(circle at 8% 50%,#eddcff 0 2px,transparent 3px),
      radial-gradient(circle at 24% 50%,#eddcff 0 2px,transparent 3px),
      radial-gradient(circle at 50% 50%,#d9b2ff 0 4px,transparent 5px),
      radial-gradient(circle at 76% 50%,#eddcff 0 2px,transparent 3px),
      radial-gradient(circle at 92% 50%,#eddcff 0 2px,transparent 3px)!important;
    opacity:.9!important;
  }

  .io-nav.is-open > .io-menu{
    padding:56px 10px 28px!important;
    border-radius:26px!important;
    border:2px solid rgba(232,221,249,.94)!important;
    background:
      radial-gradient(ellipse at 50% 2%, rgba(237,229,255,.75) 0%, rgba(237,229,255,.3) 34%, transparent 35%),
      linear-gradient(180deg, rgba(255,255,255,.78), rgba(253,249,255,.66))!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.97), 0 8px 18px rgba(118,72,181,.08)!important;
  }
  .io-nav.is-open > .io-menu:before{
    width:188px!important;
    height:76px!important;
    top:-46px!important;
    z-index:8!important;
    filter:drop-shadow(0 8px 12px rgba(132,80,194,.20))!important;
  }
  .io-nav.is-open > .io-menu:after{
    top:4px!important;
    left:4%!important;
    right:4%!important;
    height:88px!important;
    background:
      radial-gradient(ellipse at 18% 10%, rgba(255,255,255,.92), transparent 55%),
      radial-gradient(ellipse at 82% 10%, rgba(255,255,255,.92), transparent 55%),
      linear-gradient(0deg, rgba(255,255,255,0), rgba(255,255,255,.18) 40%, rgba(255,255,255,0) 41%),
      linear-gradient(112deg, transparent 14%, rgba(255,255,255,.54) 15%, rgba(255,255,255,.02) 30%, transparent 31%),
      linear-gradient(68deg, transparent 69%, rgba(255,255,255,.02) 70%, rgba(255,255,255,.54) 85%, transparent 86%)!important;
    opacity:1!important;
  }

  .io-menu > li{
    border-right:1px dashed rgba(208,177,239,.72)!important;
    border-bottom:1px dashed rgba(208,177,239,.72)!important;
  }
  .io-menu > li:before,
  .io-menu > li:after{
    content:"";
    position:absolute;
    width:8px;
    height:8px;
    pointer-events:none;
    background:radial-gradient(circle,#f7ebff 0 38%,rgba(227,196,255,.95) 39% 72%,transparent 73%);
    box-shadow:0 0 10px rgba(240,219,255,.7);
  }
  .io-menu > li:before{top:-4px;left:-4px}
  .io-menu > li:after{top:-4px;right:-4px}
  .io-menu > li:nth-child(3n):after{right:auto;left:-4px}
  .io-menu > li:nth-child(n+7):before,
  .io-menu > li:nth-child(n+7):after{top:auto;bottom:-4px}

  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    grid-template-rows:68px auto auto!important;
    min-height:128px!important;
    padding:12px 6px 10px!important;
  }
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    width:84px!important;
    height:66px!important;
    filter:drop-shadow(0 10px 10px rgba(118,72,181,.16))!important;
  }
  .io-nav.is-open > a strong,
  .io-menu > li > a strong,
  .io-mini-game-toggle strong{
    margin-top:5px!important;
    font-size:15px!important;
    color:#6b33ab!important;
  }
  .io-nav.is-open > a small,
  .io-menu > li > a small,
  .io-mini-game-toggle small{
    margin-top:5px!important;
    font-size:10px!important;
    color:#8350ba!important;
  }

  .io-mini-game-toggle,
  .io-mini-game-toggle[aria-expanded="true"]{
    margin:6px!important;
    width:calc(100% - 12px)!important;
    min-height:116px!important;
    border:2px solid rgba(227,198,250,.96)!important;
    border-radius:22px!important;
    background:
      radial-gradient(circle at 50% 28%, rgba(255,255,255,.88), transparent 46%),
      linear-gradient(180deg, rgba(255,255,255,.76), rgba(245,232,255,.74))!important;
    box-shadow:0 12px 30px rgba(127,80,188,.16), inset 0 1px 0 rgba(255,255,255,.95)!important;
  }
  .io-mini-game-toggle:before{
    inset:-8px!important;
    border-radius:26px!important;
    background:radial-gradient(circle,rgba(229,194,255,.42),rgba(229,194,255,0) 70%)!important;
  }
  .io-mini-game-toggle i{
    top:10px!important;
    right:10px!important;
    width:24px!important;
    height:24px!important;
  }

  .io-mini-game-submenu{
    top:calc(100% + 12px)!important;
    padding:12px!important;
    border:2px solid rgba(225,202,249,.96)!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(248,241,255,.96))!important;
    box-shadow:0 16px 38px rgba(104,58,159,.18), inset 0 1px 0 rgba(255,255,255,.96)!important;
  }
  .io-mini-game-submenu button{
    min-height:106px!important;
    border:1px solid rgba(228,208,248,.90)!important;
    border-radius:18px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,239,255,.84))!important;
  }

  .io-brand-link{
    filter:drop-shadow(0 2px 6px rgba(255,255,255,.32));
  }
}


/* v6.48: Design D faithful refinement + robust mobile menu visibility */
@media (max-width:900px){
  html.io-mobile-menu-open,
  body.io-mobile-menu-open{
    overflow:hidden;
    touch-action:none;
  }

  .io-mobile-menu-button{
    width:96px!important;
    height:96px!important;
    padding:10px 8px!important;
    border-radius:999px!important;
    border:2px solid rgba(214,186,248,.95)!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,242,255,.96))!important;
    box-shadow:0 18px 36px rgba(122,78,180,.18), inset 0 1px 0 rgba(255,255,255,.98)!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:7px!important;
    backdrop-filter:blur(8px);
  }
  .io-mobile-menu-icon{
    width:28px!important;
    height:28px!important;
    gap:6px!important;
  }
  .io-mobile-menu-icon i{
    height:3px!important;
    border-radius:999px!important;
    background:#8e58d9!important;
  }
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(9px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-9px) rotate(-45deg)!important}
  .io-mobile-menu-text{
    font-size:15px!important;
    font-weight:800!important;
    letter-spacing:.08em!important;
    color:#8853d5!important;
  }

  .io-nav{
    top:calc(106px + env(safe-area-inset-top))!important;
    left:18px!important;
    right:18px!important;
    z-index:9998!important;
    max-height:calc(100vh - 126px - env(safe-area-inset-top))!important;
    overflow:auto!important;
    visibility:hidden;
    opacity:0;
    pointer-events:none;
    transform:translateY(-10px);
    transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  }
  .admin-bar .io-nav{
    top:calc(138px + env(safe-area-inset-top))!important;
    max-height:calc(100vh - 158px - env(safe-area-inset-top))!important;
  }
  .io-nav.is-open,
  body.io-mobile-menu-open .io-nav{
    display:block!important;
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    transform:none!important;
  }

  .io-nav.is-open{
    padding:14px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:34px!important;
    background:
      radial-gradient(circle at 14% 9%,rgba(251,233,248,.90),transparent 24%),
      radial-gradient(circle at 50% 4%,rgba(231,216,255,.92),transparent 26%),
      radial-gradient(circle at 88% 10%,rgba(250,232,250,.88),transparent 24%),
      linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,239,255,.97))!important;
    box-shadow:0 24px 56px rgba(111,70,172,.22), inset 0 1px 0 rgba(255,255,255,.98)!important;
    backdrop-filter:blur(16px)!important;
    overflow:auto!important;
  }
  .io-nav.is-open:before{
    inset:12px 18px auto!important;
    height:76px!important;
    background:
      radial-gradient(circle at 7% 16%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 22% 30%,rgba(255,222,244,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 78% 24%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 92% 12%,rgba(232,209,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 38% 18%,rgba(255,244,251,.92) 0 4px,transparent 5px),
      linear-gradient(112deg,transparent 8%,rgba(255,255,255,.46) 9%,transparent 23%),
      linear-gradient(67deg,transparent 78%,rgba(255,255,255,.38) 79%,transparent 92%)!important;
  }

  .io-nav.is-open > .io-menu{
    padding:72px 10px 22px!important;
    border:1px solid rgba(226,209,247,.92)!important;
    border-radius:26px!important;
    background:
      radial-gradient(ellipse at 12% 0%,rgba(255,224,247,.26),transparent 24%),
      radial-gradient(ellipse at 50% 0%,rgba(229,205,255,.28),transparent 30%),
      radial-gradient(ellipse at 88% 0%,rgba(255,228,250,.22),transparent 24%),
      linear-gradient(180deg,rgba(255,255,255,.72),rgba(253,252,255,.60))!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.90),0 10px 24px rgba(114,70,171,.10)!important;
  }
  .io-nav.is-open > .io-menu:before{
    top:-42px!important;
    width:168px!important;
    height:66px!important;
    background:url("assets/images/menu-v647/menu-bow-v647.svg") center/contain no-repeat!important;
    filter:drop-shadow(0 8px 10px rgba(124,70,182,.22))!important;
  }
  .io-nav.is-open > .io-menu:after{
    top:0!important;
    left:3%!important;
    right:3%!important;
    height:118px!important;
    background:
      linear-gradient(160deg,transparent 12%,rgba(255,255,255,.74) 13%,rgba(255,255,255,.08) 29%,transparent 30%),
      linear-gradient(20deg,transparent 74%,rgba(255,255,255,.10) 75%,rgba(255,255,255,.58) 92%,transparent 93%),
      linear-gradient(to bottom, rgba(198,176,235,.36), rgba(255,255,255,0) 58%)!important;
    opacity:.95!important;
  }

  .io-menu > li{
    border-right:1px dashed rgba(200,163,236,.42)!important;
    border-bottom:1px dashed rgba(200,163,236,.42)!important;
    background:transparent!important;
  }
  .io-menu > li:nth-child(3n){border-right:0!important}
  .io-menu > li:nth-child(n+7){border-bottom:0!important}

  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{
    min-height:170px!important;
    padding:20px 8px 14px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    grid-template-rows:74px auto auto!important;
  }
  .io-nav.is-open > a:before,
  .io-nav.is-open > a:after,
  .io-menu > li > a:before,
  .io-menu > li > a:after,
  .io-mini-game-toggle:before,
  .io-mini-game-toggle:after{display:none!important}

  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{
    width:86px!important;
    height:64px!important;
    margin:0 auto 6px!important;
    border:0!important;
    border-radius:0!important;
    background-color:transparent!important;
    background-size:contain!important;
    background-position:center!important;
    background-repeat:no-repeat!important;
    box-shadow:none!important;
    filter:drop-shadow(0 6px 12px rgba(163,121,223,.28));
    font-size:0!important;
  }
  .io-menu > li > a strong,
  .io-mini-game-toggle strong,
  .io-nav.is-open > a strong{
    margin:2px 0 0!important;
    color:#7f42c3!important;
    font-size:18px!important;
    font-weight:900!important;
    letter-spacing:.02em!important;
    line-height:1.15!important;
  }
  .io-menu > li > a small,
  .io-mini-game-toggle small,
  .io-nav.is-open > a small{
    margin:8px 0 0!important;
    color:#835eb7!important;
    font-size:10px!important;
    font-weight:900!important;
    line-height:1.25!important;
  }

  .io-mobile-nav-game-group{
    position:relative!important;
  }
  .io-mini-game-toggle{
    position:relative!important;
    margin:4px!important;
    min-height:162px!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.56),rgba(238,214,255,.28))!important;
    box-shadow:inset 0 0 0 1px rgba(232,201,255,.76),0 0 0 3px rgba(245,228,255,.46),0 10px 18px rgba(161,108,224,.16)!important;
  }
  .io-mini-game-toggle i{
    top:12px!important;
    right:12px!important;
    width:12px!important;
    height:12px!important;
    border-right:3px solid #fff!important;
    border-bottom:3px solid #fff!important;
    border-radius:1px!important;
    transform:rotate(45deg)!important;
    background:#b57cf0!important;
    width:28px!important;
    height:28px!important;
    border-radius:50%!important;
    box-shadow:0 4px 10px rgba(157,103,228,.22)!important;
  }
  .io-mini-game-toggle[aria-expanded="true"] i{transform:rotate(225deg)!important}

  .io-menu > li > a[data-io-menu-key="top"] span{background-image:url("assets/images/menu-v647/top-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="schedule"] span{background-image:url("assets/images/menu-v647/schedule-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="news"] span{background-image:url("assets/images/menu-v647/news-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="profile"] span{background-image:url("assets/images/menu-v647/profile-v647.svg")!important}
  .io-mini-game-toggle span{background-image:url("assets/images/menu-v647/game-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="works"] span{background-image:url("assets/images/menu-v647/works-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="movie"] span{background-image:url("assets/images/menu-v647/movie-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="goods"] span{background-image:url("assets/images/menu-v647/goods-v647.svg")!important}
  .io-menu > li > a[data-io-menu-key="contact"] span{background-image:url("assets/images/menu-v647/contact-v647.svg")!important}

  .io-mini-game-submenu{
    top:calc(100% - 8px)!important;
    left:6px!important;
    right:6px!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:10px!important;
    border:1px solid rgba(225,204,247,.96)!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(247,240,255,.96))!important;
    box-shadow:0 18px 40px rgba(109,69,171,.18)!important;
  }
  .io-mini-game-submenu li{
    border-right:1px dashed rgba(200,163,236,.38);
  }
  .io-mini-game-submenu li:last-child{border-right:0}
  .io-mini-game-submenu button{
    min-height:120px!important;
    padding:14px 6px 10px!important;
    border:0!important;
    border-radius:16px!important;
    background:transparent!important;
    box-shadow:none!important;
  }
  .io-mini-game-submenu button:after{display:none!important}
  .io-mini-game-submenu-icon{
    width:54px!important;
    height:44px!important;
    margin:0 auto 6px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    font-size:28px!important;
    line-height:1!important;
  }
  .io-mini-game-submenu strong{
    font-size:11px!important;
    color:#7f42c3!important;
    line-height:1.2!important;
  }
  .io-mini-game-submenu small{
    font-size:9px!important;
    color:#8662b8!important;
    line-height:1.25!important;
  }
}
@media (max-width:380px){
  .io-mobile-menu-button{width:88px!important;height:88px!important}
  .io-nav{left:12px!important;right:12px!important}
  .io-nav.is-open > .io-menu{padding:68px 6px 18px!important}
  .io-nav.is-open > a,
  .io-menu > li > a,
  .io-mini-game-toggle{min-height:154px!important}
  .io-nav.is-open > a span,
  .io-menu > li > a span,
  .io-mini-game-toggle span{width:76px!important;height:56px!important}
  .io-menu > li > a strong,
  .io-mini-game-toggle strong,
  .io-nav.is-open > a strong{font-size:16px!important}
}


/* v6.49: force stable Design D 3x3 grid menu and smaller MENU button */
@media (max-width:900px){
  .io-mobile-menu-button{
    width:78px!important;
    height:78px!important;
    min-width:78px!important;
    min-height:78px!important;
    padding:8px 6px!important;
    top:calc(14px + env(safe-area-inset-top))!important;
    right:calc(12px + env(safe-area-inset-right))!important;
    border:2px solid rgba(215,191,246,.96)!important;
    border-radius:999px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,243,255,.97))!important;
    box-shadow:0 14px 30px rgba(124,82,182,.18), inset 0 1px 0 rgba(255,255,255,.98)!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:5px!important;
    z-index:10002!important;
  }
  .io-mobile-menu-icon{width:24px!important;gap:5px!important}
  .io-mobile-menu-icon i{height:3px!important;background:#8d58d8!important;border-radius:999px!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(8px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-8px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:12px!important;font-weight:900!important;letter-spacing:.08em!important;color:#8856d5!important}

  .io-nav,
  .io-header .io-nav{
    position:fixed!important;
    top:calc(102px + env(safe-area-inset-top))!important;
    left:16px!important;
    right:16px!important;
    width:auto!important;
    max-width:none!important;
    max-height:calc(100vh - 122px - env(safe-area-inset-top))!important;
    margin:0!important;
    padding:12px!important;
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
    overflow:auto!important;
    overflow-x:hidden!important;
    border:1px solid rgba(222,199,248,.96)!important;
    border-radius:34px!important;
    background:
      radial-gradient(circle at 14% 10%,rgba(251,234,248,.92),transparent 22%),
      radial-gradient(circle at 50% 2%,rgba(229,214,255,.96),transparent 24%),
      radial-gradient(circle at 87% 10%,rgba(252,235,250,.90),transparent 22%),
      linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,239,255,.97))!important;
    box-shadow:0 24px 56px rgba(110,69,172,.22), inset 0 1px 0 rgba(255,255,255,.98)!important;
    backdrop-filter:blur(16px)!important;
    z-index:10001!important;
    transform:translateY(-8px)!important;
    transition:opacity .18s ease, transform .18s ease, visibility .18s ease!important;
  }
  .io-nav.is-open,
  .io-header .io-nav.is-open,
  body.io-mobile-menu-open .io-nav{
    display:block!important;
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    transform:none!important;
  }
  .io-nav.is-open:before{
    content:"";
    position:absolute;
    inset:10px 16px auto!important;
    height:78px!important;
    pointer-events:none!important;
    background:
      radial-gradient(circle at 8% 18%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 24% 32%,rgba(255,224,246,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 74% 24%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 92% 14%,rgba(232,208,255,.98) 0 2px,transparent 3px),
      linear-gradient(112deg,transparent 8%,rgba(255,255,255,.50) 9%,transparent 24%),
      linear-gradient(67deg,transparent 78%,rgba(255,255,255,.40) 79%,transparent 92%)!important;
  }
  .io-nav.is-open:after{
    content:"";
    position:absolute;
    left:16px!important;
    right:16px!important;
    bottom:12px!important;
    height:18px!important;
    pointer-events:none!important;
    background:
      radial-gradient(circle at 8% 50%,#ceb0f5 0 2px,transparent 3px),
      radial-gradient(circle at 24% 50%,#eadbff 0 2px,transparent 3px),
      radial-gradient(circle at 50% 50%,#b879ef 0 3px,transparent 4px),
      radial-gradient(circle at 76% 50%,#eadbff 0 2px,transparent 3px),
      radial-gradient(circle at 92% 50%,#ceb0f5 0 2px,transparent 3px)!important;
    opacity:.72!important;
  }

  .io-nav .io-menu,
  .io-nav.is-open .io-menu{
    position:relative!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    width:100%!important;
    list-style:none!important;
    margin:0!important;
    padding:66px 8px 24px!important;
    border:1px solid rgba(225,207,247,.90)!important;
    border-radius:28px!important;
    background:
      radial-gradient(ellipse at 12% 0%,rgba(255,224,247,.25),transparent 24%),
      radial-gradient(ellipse at 50% 0%,rgba(229,205,255,.28),transparent 30%),
      radial-gradient(ellipse at 88% 0%,rgba(255,228,250,.22),transparent 24%),
      linear-gradient(180deg,rgba(255,255,255,.72),rgba(253,252,255,.60))!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.90),0 10px 24px rgba(114,70,171,.10)!important;
    overflow:visible!important;
  }
  .io-nav .io-menu:before,
  .io-nav.is-open .io-menu:before{
    content:"";
    position:absolute!important;
    top:-40px!important;
    left:50%!important;
    width:168px!important;
    height:66px!important;
    transform:translateX(-50%)!important;
    background:url("assets/images/menu-v647/menu-bow-v647.svg") center/contain no-repeat!important;
    filter:drop-shadow(0 8px 10px rgba(124,70,182,.22))!important;
    pointer-events:none!important;
    z-index:4!important;
  }
  .io-nav .io-menu:after,
  .io-nav.is-open .io-menu:after{
    content:"";
    position:absolute!important;
    top:0!important;
    left:2%!important;
    right:2%!important;
    height:118px!important;
    background:
      linear-gradient(160deg,transparent 12%,rgba(255,255,255,.74) 13%,rgba(255,255,255,.08) 29%,transparent 30%),
      linear-gradient(20deg,transparent 74%,rgba(255,255,255,.10) 75%,rgba(255,255,255,.58) 92%,transparent 93%),
      linear-gradient(to bottom, rgba(198,176,235,.36), rgba(255,255,255,0) 58%)!important;
    opacity:.95!important;
    pointer-events:none!important;
    z-index:1!important;
  }

  .io-nav .io-menu > li,
  .io-nav.is-open .io-menu > li,
  .io-nav .io-menu > .io-mobile-nav-game-group,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group{
    display:block!important;
    width:auto!important;
    min-width:0!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    list-style:none!important;
    position:relative!important;
    border-right:1px dashed rgba(197,159,235,.44)!important;
    border-bottom:1px dashed rgba(197,159,235,.44)!important;
    background:transparent!important;
  }
  .io-nav .io-menu > li:nth-child(3n),
  .io-nav.is-open .io-menu > li:nth-child(3n),
  .io-nav .io-menu > .io-mobile-nav-game-group:nth-child(3n),
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group:nth-child(3n){border-right:0!important}
  .io-nav .io-menu > li:nth-child(n+7),
  .io-nav.is-open .io-menu > li:nth-child(n+7),
  .io-nav .io-menu > .io-mobile-nav-game-group:nth-child(n+7),
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group:nth-child(n+7){border-bottom:0!important}

  .io-nav .io-menu > li > a,
  .io-nav.is-open .io-menu > li > a,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:74px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-width:0!important;
    min-height:168px!important;
    padding:18px 8px 14px!important;
    margin:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    text-align:center!important;
    line-height:1.15!important;
    overflow:visible!important;
  }
  .io-nav .io-menu > li > a:before,
  .io-nav .io-menu > li > a:after,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle:before,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle:after{display:none!important}

  .io-nav .io-menu > li > a span,
  .io-nav.is-open .io-menu > li > a span,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle span,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle span{
    display:block!important;
    width:88px!important;
    height:64px!important;
    margin:0 auto 6px!important;
    border:0!important;
    border-radius:0!important;
    background-color:transparent!important;
    background-size:contain!important;
    background-position:center!important;
    background-repeat:no-repeat!important;
    box-shadow:none!important;
    filter:drop-shadow(0 6px 12px rgba(163,121,223,.28))!important;
    font-size:0!important;
    color:transparent!important;
  }
  .io-nav .io-menu > li > a strong,
  .io-nav.is-open .io-menu > li > a strong,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle strong,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle strong{
    display:block!important;
    margin:0!important;
    color:#7f43c3!important;
    font-size:17px!important;
    font-weight:900!important;
    letter-spacing:.02em!important;
    line-height:1.12!important;
    white-space:nowrap!important;
  }
  .io-nav .io-menu > li > a small,
  .io-nav.is-open .io-menu > li > a small,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle small,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle small{
    display:block!important;
    margin:8px 0 0!important;
    color:#855cb8!important;
    font-size:10px!important;
    font-weight:900!important;
    line-height:1.25!important;
    white-space:nowrap!important;
  }

  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle{
    margin:4px!important;
    min-height:160px!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.56),rgba(238,214,255,.30))!important;
    box-shadow:inset 0 0 0 1px rgba(232,201,255,.78),0 0 0 3px rgba(245,228,255,.48),0 10px 18px rgba(161,108,224,.16)!important;
  }
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle i,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle i{
    position:absolute!important;
    top:12px!important;
    right:12px!important;
    width:28px!important;
    height:28px!important;
    border:0!important;
    border-radius:50%!important;
    background:#b57cf0!important;
    box-shadow:0 4px 10px rgba(157,103,228,.22)!important;
  }
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle i:before,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle i:after{
    content:"";
    position:absolute;
    inset:0;
    margin:auto;
    width:8px;
    height:8px;
    border-right:3px solid #fff;
    border-bottom:3px solid #fff;
    transform:rotate(45deg) translate(-1px,-1px);
    top:7px;
    left:8px;
  }
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle[aria-expanded="true"] i:before,
  .io-nav.is-open .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle[aria-expanded="true"] i:before{transform:rotate(225deg) translate(-1px,-1px)}

  .io-nav .io-menu > li > a[data-io-menu-key="top"] span{background-image:url("assets/images/menu-v647/top-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="schedule"] span{background-image:url("assets/images/menu-v647/schedule-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="news"] span{background-image:url("assets/images/menu-v647/news-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="profile"] span{background-image:url("assets/images/menu-v647/profile-v647.svg")!important}
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle span{background-image:url("assets/images/menu-v647/game-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="works"] span{background-image:url("assets/images/menu-v647/works-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="movie"] span{background-image:url("assets/images/menu-v647/movie-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="goods"] span{background-image:url("assets/images/menu-v647/goods-v647.svg")!important}
  .io-nav .io-menu > li > a[data-io-menu-key="contact"] span{background-image:url("assets/images/menu-v647/contact-v647.svg")!important}

  .io-mini-game-submenu{
    position:absolute!important;
    top:calc(100% - 8px)!important;
    left:6px!important;
    right:6px!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:10px!important;
    border:1px solid rgba(225,204,247,.96)!important;
    border-radius:22px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(247,240,255,.96))!important;
    box-shadow:0 18px 40px rgba(109,69,171,.18)!important;
    z-index:10!important;
  }
  .io-mini-game-submenu[hidden]{display:none!important}
  .io-mini-game-submenu li{list-style:none!important;margin:0!important;border-right:1px dashed rgba(197,159,235,.38)!important}
  .io-mini-game-submenu li:last-child{border-right:0!important}
  .io-mini-game-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:48px auto auto!important;
    width:100%!important;
    min-height:118px!important;
    padding:14px 6px 10px!important;
    border:0!important;
    border-radius:16px!important;
    background:transparent!important;
    box-shadow:none!important;
    text-align:center!important;
  }
  .io-mini-game-submenu button:after{display:none!important}
  .io-mini-game-submenu-icon{
    display:grid!important;
    place-items:center!important;
    width:54px!important;
    height:44px!important;
    margin:0 auto 6px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    font-size:28px!important;
    line-height:1!important;
  }
  .io-mini-game-submenu strong{display:block!important;font-size:11px!important;color:#7f43c3!important;line-height:1.2!important}
  .io-mini-game-submenu small{display:block!important;font-size:9px!important;color:#855cb8!important;line-height:1.25!important}
}
@media (max-width:380px){
  .io-nav,.io-header .io-nav{left:12px!important;right:12px!important}
  .io-nav .io-menu,.io-nav.is-open .io-menu{padding:62px 6px 20px!important}
  .io-nav .io-menu > li > a,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle{min-height:154px!important}
  .io-nav .io-menu > li > a span,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle span{width:76px!important;height:56px!important}
  .io-nav .io-menu > li > a strong,
  .io-nav .io-menu > .io-mobile-nav-game-group > .io-mini-game-toggle strong{font-size:15px!important}
}


/* v6.50: dedicated Design D mobile menu overlay */
@media (max-width:900px){
  .io-nav{display:none!important}
  .io-mobile-menu-button{
    width:74px!important;height:74px!important;min-width:74px!important;min-height:74px!important;
    padding:7px 5px!important;top:calc(14px + env(safe-area-inset-top))!important;right:calc(12px + env(safe-area-inset-right))!important;
    border:2px solid rgba(212,186,245,.96)!important;border-radius:999px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,242,255,.97))!important;
    box-shadow:0 12px 26px rgba(124,82,182,.16), inset 0 1px 0 rgba(255,255,255,.98)!important;
    display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:4px!important;z-index:10020!important;
  }
  .io-mobile-menu-icon{width:22px!important;gap:5px!important}
  .io-mobile-menu-icon i{height:3px!important;background:#8a56d3!important;border-radius:999px!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(8px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-8px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:12px!important;font-weight:900!important;letter-spacing:.06em!important;color:#8857d3!important}

  .io-design-d-mobile-menu{
    position:fixed!important;top:calc(104px + env(safe-area-inset-top))!important;left:16px!important;right:16px!important;
    z-index:10010!important;display:none;max-height:calc(100vh - 124px - env(safe-area-inset-top));overflow:auto;padding:0 0 12px;
  }
  .io-design-d-mobile-menu.is-open{display:block!important}
  .io-design-d-mobile-shell{
    position:relative;padding:56px 14px 16px;border:1px solid rgba(222,198,248,.96);border-radius:34px;
    background:
      radial-gradient(circle at 14% 9%,rgba(251,233,248,.92),transparent 22%),
      radial-gradient(circle at 50% 2%,rgba(231,216,255,.96),transparent 24%),
      radial-gradient(circle at 87% 10%,rgba(252,235,250,.90),transparent 22%),
      linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,239,255,.97));
    box-shadow:0 24px 56px rgba(110,69,172,.22), inset 0 1px 0 rgba(255,255,255,.98);
    backdrop-filter:blur(16px);
    overflow:visible;
  }
  .io-design-d-mobile-shell:before{
    content:"";position:absolute;left:50%;top:-26px;transform:translateX(-50%);width:170px;height:66px;
    background:url("assets/images/menu-v647/menu-bow-v647.svg") center/contain no-repeat;
    filter:drop-shadow(0 8px 10px rgba(124,70,182,.22));pointer-events:none;
  }
  .io-design-d-mobile-shell:after{
    content:"";position:absolute;left:12px;right:12px;top:14px;height:94px;pointer-events:none;
    background:
      linear-gradient(160deg,transparent 12%,rgba(255,255,255,.78) 13%,rgba(255,255,255,.08) 29%,transparent 30%),
      linear-gradient(20deg,transparent 74%,rgba(255,255,255,.10) 75%,rgba(255,255,255,.58) 92%,transparent 93%),
      radial-gradient(circle at 8% 18%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 24% 32%,rgba(255,224,246,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 74% 24%,rgba(255,255,255,.98) 0 2px,transparent 3px),
      radial-gradient(circle at 92% 14%,rgba(232,208,255,.98) 0 2px,transparent 3px),
      linear-gradient(to bottom, rgba(198,176,235,.34), rgba(255,255,255,0) 58%);
    opacity:.95;
  }
  .io-design-d-mobile-grid{
    position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
    padding:22px 8px 20px;border:1px solid rgba(225,207,247,.90);border-radius:28px;
    background:
      radial-gradient(ellipse at 12% 0%,rgba(255,224,247,.25),transparent 24%),
      radial-gradient(ellipse at 50% 0%,rgba(229,205,255,.28),transparent 30%),
      radial-gradient(ellipse at 88% 0%,rgba(255,228,250,.22),transparent 24%),
      linear-gradient(180deg,rgba(255,255,255,.72),rgba(253,252,255,.60));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.90),0 10px 24px rgba(114,70,171,.10);
  }
  .io-design-d-mobile-grid > *{position:relative;min-width:0}
  .io-dd-item,
  .io-dd-game-toggle{
    display:grid!important;grid-template-columns:1fr;grid-template-rows:72px auto auto;align-items:center;justify-items:center;
    width:100%;min-height:164px;padding:16px 8px 14px;border:0;background:transparent;color:#7f43c3;text-align:center;line-height:1.15;
  }
  .io-dd-item{border-right:1px dashed rgba(197,159,235,.44);border-bottom:1px dashed rgba(197,159,235,.44)}
  .io-dd-item:nth-child(3), .io-dd-item:nth-child(6), .io-dd-item:nth-child(9){border-right:0}
  .io-dd-item:nth-child(7), .io-dd-item:nth-child(8), .io-dd-item:nth-child(9){border-bottom:0}
  .io-dd-game-group{border-right:1px dashed rgba(197,159,235,.44);border-bottom:1px dashed rgba(197,159,235,.44)}
  .io-dd-icon{
    display:block;width:88px;height:64px;margin:0 auto 6px;background-position:center;background-repeat:no-repeat;background-size:contain;
    filter:drop-shadow(0 6px 12px rgba(163,121,223,.28));
  }
  .io-dd-top .io-dd-icon{background-image:url("assets/images/menu-v647/top-v647.svg")}
  .io-dd-schedule .io-dd-icon{background-image:url("assets/images/menu-v647/schedule-v647.svg")}
  .io-dd-news .io-dd-icon{background-image:url("assets/images/menu-v647/news-v647.svg")}
  .io-dd-profile .io-dd-icon{background-image:url("assets/images/menu-v647/profile-v647.svg")}
  .io-dd-game-toggle .io-dd-icon{background-image:url("assets/images/menu-v647/game-v647.svg")}
  .io-dd-works .io-dd-icon{background-image:url("assets/images/menu-v647/works-v647.svg")}
  .io-dd-movie .io-dd-icon{background-image:url("assets/images/menu-v647/movie-v647.svg")}
  .io-dd-goods .io-dd-icon{background-image:url("assets/images/menu-v647/goods-v647.svg")}
  .io-dd-contact .io-dd-icon{background-image:url("assets/images/menu-v647/contact-v647.svg")}
  .io-dd-item strong,.io-dd-game-toggle strong{display:block;margin:0;color:#7f43c3;font-size:17px;font-weight:900;letter-spacing:.02em;line-height:1.12;white-space:nowrap}
  .io-dd-item small,.io-dd-game-toggle small{display:block;margin:8px 0 0;color:#855cb8;font-size:10px;font-weight:900;line-height:1.25;white-space:nowrap}
  .io-dd-game-group{position:relative}
  .io-dd-game-toggle{position:relative;margin:4px;min-height:156px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.56),rgba(238,214,255,.30));box-shadow:inset 0 0 0 1px rgba(232,201,255,.78),0 0 0 3px rgba(245,228,255,.48),0 10px 18px rgba(161,108,224,.16)}
  .io-dd-game-toggle i{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:#b57cf0;box-shadow:0 4px 10px rgba(157,103,228,.22)}
  .io-dd-game-toggle i:before{content:"";position:absolute;top:7px;left:8px;width:8px;height:8px;border-right:3px solid #fff;border-bottom:3px solid #fff;transform:rotate(45deg)}
  .io-dd-game-toggle[aria-expanded="true"] i:before{transform:rotate(225deg)}
  .io-dd-submenu{
    position:absolute;top:calc(100% - 8px);left:calc(-100% - 1px);width:calc(300% + 2px);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
    padding:10px;border:1px solid rgba(225,204,247,.96);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(247,240,255,.96));box-shadow:0 18px 40px rgba(109,69,171,.18);z-index:10;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none;margin:0;border-right:1px dashed rgba(197,159,235,.38)}
  .io-dd-submenu li:last-child{border-right:0}
  .io-dd-submenu button{display:grid;grid-template-columns:1fr;grid-template-rows:48px auto auto;width:100%;min-height:118px;padding:14px 6px 10px;border:0;background:transparent;text-align:center}
  .io-dd-sub-icon{display:grid;place-items:center;width:54px;height:44px;margin:0 auto 6px;font-size:28px;line-height:1}
  .io-dd-submenu strong{display:block;font-size:11px;color:#7f43c3;line-height:1.2}
  .io-dd-submenu small{display:block;font-size:9px;color:#855cb8;line-height:1.25}
}


/* v6.51: compact complete-frame Design D menu with dedicated PNG icons */
@media (max-width:900px){
  .io-mobile-menu-button{
    width:62px!important;
    height:62px!important;
    min-width:62px!important;
    min-height:62px!important;
    padding:6px 4px!important;
    top:calc(12px + env(safe-area-inset-top))!important;
    right:calc(10px + env(safe-area-inset-right))!important;
    gap:3px!important;
    border-width:1.5px!important;
    box-shadow:0 10px 22px rgba(124,82,182,.15),inset 0 1px 0 rgba(255,255,255,.98)!important;
  }
  .io-mobile-menu-icon{width:20px!important;gap:4px!important}
  .io-mobile-menu-icon i{height:2.5px!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(6.5px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:10px!important;letter-spacing:.05em!important}

  .io-design-d-mobile-menu{
    top:calc(82px + env(safe-area-inset-top))!important;
    left:12px!important;
    right:12px!important;
    max-height:calc(100dvh - 94px - env(safe-area-inset-top))!important;
    padding:10px 0 14px!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch;
  }
  .io-design-d-mobile-shell{
    padding:42px 10px 12px!important;
    border-radius:28px!important;
    border:1px solid rgba(218,192,248,.98)!important;
    background:
      radial-gradient(circle at 14% 7%,rgba(251,233,248,.94),transparent 22%),
      radial-gradient(circle at 50% 1%,rgba(231,216,255,.98),transparent 24%),
      radial-gradient(circle at 87% 8%,rgba(252,235,250,.92),transparent 22%),
      linear-gradient(180deg,rgba(255,255,255,.99),rgba(246,239,255,.98))!important;
    box-shadow:0 18px 42px rgba(110,69,172,.19),inset 0 1px 0 rgba(255,255,255,.99)!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-shell:before{
    top:-12px!important;
    width:136px!important;
    height:50px!important;
    background-image:url("assets/images/menu-v651/menu-bow-v651.png")!important;
    background-size:contain!important;
    filter:drop-shadow(0 5px 7px rgba(124,70,182,.20))!important;
    z-index:4!important;
  }
  .io-design-d-mobile-shell:after{
    left:8px!important;
    right:8px!important;
    top:9px!important;
    height:74px!important;
    opacity:.88!important;
  }
  .io-design-d-mobile-grid{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:14px 6px 14px!important;
    border-radius:23px!important;
    border:1px solid rgba(224,205,247,.96)!important;
    background:
      radial-gradient(ellipse at 12% 0%,rgba(255,224,247,.22),transparent 24%),
      radial-gradient(ellipse at 50% 0%,rgba(229,205,255,.25),transparent 30%),
      radial-gradient(ellipse at 88% 0%,rgba(255,228,250,.20),transparent 24%),
      linear-gradient(180deg,rgba(255,255,255,.78),rgba(253,252,255,.66))!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 8px 18px rgba(114,70,171,.08)!important;
  }
  .io-dd-item,
  .io-dd-game-toggle{
    grid-template-rows:54px auto auto!important;
    min-height:112px!important;
    padding:8px 4px 8px!important;
  }
  .io-dd-item{
    border-right:1px dashed rgba(197,159,235,.40)!important;
    border-bottom:1px dashed rgba(197,159,235,.40)!important;
  }
  .io-dd-game-group{
    border-right:1px dashed rgba(197,159,235,.40)!important;
    border-bottom:1px dashed rgba(197,159,235,.40)!important;
  }
  .io-dd-icon{
    width:64px!important;
    height:52px!important;
    margin:0 auto 2px!important;
    background-size:contain!important;
    filter:drop-shadow(0 4px 8px rgba(151,98,214,.24))!important;
  }
  .io-dd-top .io-dd-icon{background-image:url("assets/images/menu-v651/top-v651.png")!important}
  .io-dd-schedule .io-dd-icon{background-image:url("assets/images/menu-v651/schedule-v651.png")!important}
  .io-dd-news .io-dd-icon{background-image:url("assets/images/menu-v651/news-v651.png")!important}
  .io-dd-profile .io-dd-icon{background-image:url("assets/images/menu-v651/profile-v651.png")!important}
  .io-dd-game-toggle .io-dd-icon{background-image:url("assets/images/menu-v651/game-v651.png")!important}
  .io-dd-works .io-dd-icon{background-image:url("assets/images/menu-v651/works-v651.png")!important}
  .io-dd-movie .io-dd-icon{background-image:url("assets/images/menu-v651/movie-v651.png")!important}
  .io-dd-goods .io-dd-icon{background-image:url("assets/images/menu-v651/goods-v651.png")!important}
  .io-dd-contact .io-dd-icon{background-image:url("assets/images/menu-v651/contact-v651.png")!important}
  .io-dd-item strong,.io-dd-game-toggle strong{
    font-size:14px!important;
    line-height:1.08!important;
    letter-spacing:.015em!important;
  }
  .io-dd-item small,.io-dd-game-toggle small{
    margin:5px 0 0!important;
    font-size:8.5px!important;
    line-height:1.15!important;
  }
  .io-dd-game-toggle{
    margin:3px!important;
    min-height:106px!important;
    border-radius:17px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.60),rgba(238,214,255,.33))!important;
    box-shadow:inset 0 0 0 1px rgba(232,201,255,.80),0 0 0 2px rgba(245,228,255,.50),0 7px 14px rgba(161,108,224,.14)!important;
  }
  .io-dd-game-toggle i{
    top:7px!important;
    right:7px!important;
    width:22px!important;
    height:22px!important;
    box-shadow:0 3px 7px rgba(157,103,228,.18)!important;
  }
  .io-dd-game-toggle i:before{
    top:5px!important;
    left:6px!important;
    width:6px!important;
    height:6px!important;
    border-width:2px!important;
  }
  .io-dd-submenu{
    top:calc(100% - 4px)!important;
    left:calc(-100% - 1px)!important;
    width:calc(300% + 2px)!important;
    padding:8px!important;
    border-radius:18px!important;
  }
  .io-dd-submenu button{
    grid-template-rows:36px auto auto!important;
    min-height:88px!important;
    padding:8px 4px 7px!important;
  }
  .io-dd-sub-icon{
    width:42px!important;
    height:34px!important;
    margin:0 auto 4px!important;
    font-size:22px!important;
  }
  .io-dd-submenu strong{font-size:9px!important;line-height:1.15!important}
  .io-dd-submenu small{font-size:7.5px!important;line-height:1.15!important}
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important}
  .io-design-d-mobile-shell{padding:38px 7px 10px!important}
  .io-design-d-mobile-grid{padding:12px 4px!important}
  .io-dd-item,.io-dd-game-toggle{min-height:104px!important;grid-template-rows:50px auto auto!important}
  .io-dd-icon{width:58px!important;height:48px!important}
  .io-dd-item strong,.io-dd-game-toggle strong{font-size:13px!important}
  .io-dd-item small,.io-dd-game-toggle small{font-size:8px!important}
}


/* v6.52: tighten Design D layout, hide legacy menu, refine submenu */
@media (max-width:900px){
  .io-nav,
  .io-nav.is-open,
  .io-header .io-nav,
  .io-header .io-nav.is-open{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
    height:0!important;
    max-height:0!important;
    overflow:hidden!important;
  }

  .io-mobile-menu-button{
    width:56px!important;
    height:56px!important;
    min-width:56px!important;
    min-height:56px!important;
    padding:5px 3px!important;
    top:calc(12px + env(safe-area-inset-top))!important;
    right:calc(10px + env(safe-area-inset-right))!important;
    gap:2px!important;
    border-width:1.5px!important;
    box-shadow:0 8px 18px rgba(124,82,182,.14), inset 0 1px 0 rgba(255,255,255,.98)!important;
  }
  .io-mobile-menu-icon{width:18px!important;gap:4px!important}
  .io-mobile-menu-icon i{height:2px!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(6px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-6px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:9px!important;letter-spacing:.04em!important}

  .io-design-d-mobile-menu{
    top:calc(76px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    max-height:calc(100dvh - 84px - env(safe-area-inset-top))!important;
    padding:6px 0 10px!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
  }
  .io-design-d-mobile-shell{
    padding:34px 9px 10px!important;
    border-radius:24px!important;
  }
  .io-design-d-mobile-shell:before{
    top:-10px!important;
    width:118px!important;
    height:42px!important;
  }
  .io-design-d-mobile-shell:after{
    left:6px!important;
    right:6px!important;
    top:8px!important;
    height:56px!important;
    opacity:.84!important;
  }
  .io-design-d-mobile-grid{
    padding:10px 4px 12px!important;
    border-radius:20px!important;
  }
  .io-dd-item,
  .io-dd-game-toggle{
    grid-template-rows:44px auto auto!important;
    min-height:94px!important;
    padding:7px 3px 7px!important;
  }
  .io-dd-icon{
    width:54px!important;
    height:42px!important;
    margin:0 auto 2px!important;
    background-size:contain!important;
    filter:drop-shadow(0 3px 6px rgba(151,98,214,.20))!important;
  }
  .io-dd-item strong,
  .io-dd-game-toggle strong{
    font-size:12px!important;
    line-height:1.08!important;
    letter-spacing:.01em!important;
  }
  .io-dd-item small,
  .io-dd-game-toggle small{
    margin:3px 0 0!important;
    font-size:7.5px!important;
    line-height:1.12!important;
  }
  .io-dd-game-toggle{
    margin:2px!important;
    min-height:90px!important;
    border-radius:15px!important;
    box-shadow:inset 0 0 0 1px rgba(232,201,255,.78),0 0 0 2px rgba(245,228,255,.50),0 5px 10px rgba(161,108,224,.10)!important;
  }
  .io-dd-game-toggle i{
    top:6px!important;
    right:6px!important;
    width:20px!important;
    height:20px!important;
  }
  .io-dd-game-toggle i:before{
    top:5px!important;
    left:6px!important;
    width:5px!important;
    height:5px!important;
    border-width:2px!important;
  }
  .io-dd-submenu{
    top:calc(100% - 2px)!important;
    left:calc(-100% - 2px)!important;
    width:calc(300% + 4px)!important;
    padding:6px!important;
    border-radius:16px!important;
    box-shadow:0 12px 26px rgba(109,69,171,.16)!important;
  }
  .io-dd-submenu li{border-right:1px dashed rgba(197,159,235,.30)!important}
  .io-dd-submenu button{
    grid-template-rows:28px auto auto!important;
    min-height:72px!important;
    padding:6px 3px 6px!important;
  }
  .io-dd-sub-icon{
    width:32px!important;
    height:24px!important;
    margin:0 auto 2px!important;
    font-size:17px!important;
  }
  .io-dd-submenu strong{
    font-size:7.6px!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    word-break:keep-all!important;
  }
  .io-dd-submenu small{
    margin-top:2px!important;
    font-size:6.6px!important;
    line-height:1.05!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(74px + env(safe-area-inset-top))!important}
  .io-dd-item,.io-dd-game-toggle{min-height:88px!important}
  .io-dd-icon{width:48px!important;height:38px!important}
  .io-dd-item strong,.io-dd-game-toggle strong{font-size:11px!important}
  .io-dd-item small,.io-dd-game-toggle small{font-size:7px!important}
}


/* v6.53: direct PNG icon embeds for Design D + menu close fix */
@media (max-width:900px){
  .io-design-d-mobile-menu,
  .io-design-d-mobile-shell,
  .io-design-d-mobile-grid{
    overflow:visible!important;
  }
  .io-design-d-mobile-menu{
    top:calc(74px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    max-height:calc(100dvh - 82px - env(safe-area-inset-top))!important;
    padding:4px 0 8px!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
  }
  .io-design-d-mobile-shell{
    padding:32px 8px 8px!important;
    border-radius:24px!important;
    border:1px solid rgba(218,192,248,.98)!important;
    box-shadow:0 16px 38px rgba(110,69,172,.18),inset 0 1px 0 rgba(255,255,255,.99)!important;
  }
  .io-design-d-mobile-shell:before{
    top:-8px!important;
    width:124px!important;
    height:44px!important;
    background:url("assets/images/menu-v651/menu-bow-v651.png") center/contain no-repeat!important;
  }
  .io-design-d-mobile-shell:after{
    height:52px!important;
  }
  .io-design-d-mobile-grid{
    padding:10px 6px 10px!important;
    border-radius:20px!important;
    border:1px solid rgba(224,205,247,.96)!important;
  }
  .io-dd-item,
  .io-dd-game-toggle{
    grid-template-rows:40px auto auto!important;
    min-height:88px!important;
    padding:6px 3px 6px!important;
  }
  .io-dd-icon{
    display:grid!important;
    place-items:center!important;
    width:52px!important;
    height:40px!important;
    margin:0 auto 2px!important;
    background:none!important;
    filter:none!important;
  }
  .io-dd-icon img{
    display:block!important;
    width:52px!important;
    height:40px!important;
    object-fit:contain!important;
    filter:drop-shadow(0 3px 6px rgba(151,98,214,.20))!important;
  }
  .io-dd-top .io-dd-icon,
  .io-dd-schedule .io-dd-icon,
  .io-dd-news .io-dd-icon,
  .io-dd-profile .io-dd-icon,
  .io-dd-works .io-dd-icon,
  .io-dd-movie .io-dd-icon,
  .io-dd-goods .io-dd-icon,
  .io-dd-contact .io-dd-icon,
  .io-dd-game-toggle .io-dd-icon{background-image:none!important}
  .io-dd-item strong,
  .io-dd-game-toggle strong{
    font-size:11.5px!important;
    line-height:1.06!important;
    letter-spacing:.01em!important;
  }
  .io-dd-item small,
  .io-dd-game-toggle small{
    margin:3px 0 0!important;
    font-size:7px!important;
    line-height:1.1!important;
  }
  .io-dd-game-toggle{
    margin:2px!important;
    min-height:86px!important;
    border-radius:14px!important;
  }
  .io-dd-game-toggle i{
    top:5px!important;
    right:5px!important;
    width:18px!important;
    height:18px!important;
  }
  .io-dd-game-toggle i:before{
    top:4px!important;
    left:5px!important;
    width:5px!important;
    height:5px!important;
    border-width:2px!important;
  }
  .io-dd-submenu{
    top:calc(100% - 2px)!important;
    left:calc(-100% - 2px)!important;
    width:calc(300% + 4px)!important;
    padding:6px!important;
    border-radius:16px!important;
    box-shadow:0 12px 26px rgba(109,69,171,.16)!important;
  }
  .io-dd-submenu li{
    min-width:0!important;
  }
  .io-dd-submenu button{
    grid-template-rows:24px auto auto!important;
    min-height:68px!important;
    padding:5px 2px 5px!important;
  }
  .io-dd-sub-icon{
    width:28px!important;
    height:20px!important;
    margin:0 auto 2px!important;
    font-size:16px!important;
  }
  .io-dd-submenu strong{
    font-size:7.3px!important;
    line-height:1.06!important;
    letter-spacing:0!important;
    white-space:normal!important;
    word-break:keep-all!important;
  }
  .io-dd-submenu small{
    margin-top:1px!important;
    font-size:6.2px!important;
    line-height:1.02!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important}
  .io-dd-item,.io-dd-game-toggle{min-height:84px!important}
  .io-dd-icon,.io-dd-icon img{width:48px!important;height:36px!important}
  .io-dd-item strong,.io-dd-game-toggle strong{font-size:10.6px!important}
  .io-dd-item small,.io-dd-game-toggle small{font-size:6.8px!important}
}


/* v6.54: exact Design D look using panel art from provided reference */
@media (max-width:900px){
  .io-nav,
  .io-nav.is-open,
  .io-header .io-nav,
  .io-header .io-nav.is-open{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
    height:0!important;
    max-height:0!important;
    overflow:hidden!important;
  }

  .io-mobile-menu-button{
    width:52px!important;
    height:52px!important;
    min-width:52px!important;
    min-height:52px!important;
    padding:4px 3px!important;
    top:calc(12px + env(safe-area-inset-top))!important;
    right:calc(10px + env(safe-area-inset-right))!important;
    gap:2px!important;
    border:1.5px solid rgba(214,188,245,.96)!important;
    box-shadow:0 7px 16px rgba(124,82,182,.14), inset 0 1px 0 rgba(255,255,255,.98)!important;
    z-index:10020!important;
  }
  .io-mobile-menu-icon{width:16px!important;gap:4px!important}
  .io-mobile-menu-icon i{height:2px!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(6px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-6px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:8.5px!important;line-height:1!important;letter-spacing:.02em!important}

  .io-design-d-mobile-menu{
    position:fixed!important;
    top:calc(72px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    z-index:10010!important;
    display:none;
    max-height:calc(100dvh - 80px - env(safe-area-inset-top))!important;
    overflow:auto!important;
    padding:0!important;
  }
  .io-design-d-mobile-menu.is-open{display:block!important}
  .io-design-d-mobile-shell{
    position:relative!important;
    padding:0!important;
    aspect-ratio:780 / 995!important;
    width:100%!important;
    border:0!important;
    border-radius:0!important;
    background:url("assets/images/menu-v654/menu-panel-v654.png") center/100% 100% no-repeat!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-shell:before,
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.8% 2.2% 3.2% 2.2%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{
    position:relative!important;
    min-width:0!important;
    min-height:0!important;
    overflow:visible!important;
  }
  .io-dd-item,
  .io-dd-game-toggle{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    color:transparent!important;
    text-decoration:none!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-item strong,
  .io-dd-item small,
  .io-dd-icon,
  .io-dd-game-toggle strong,
  .io-dd-game-toggle small,
  .io-dd-game-toggle .io-dd-icon,
  .io-dd-game-toggle i{
    opacity:0!important;
    pointer-events:none!important;
  }

  .io-dd-game-group{z-index:30!important}
  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 4px)!important;
    width:calc(300% - 8px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,241,255,.95))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:62px!important;
    padding:5px 3px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,242,255,.95))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 1px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    color:#7d47be!important;
    font-size:7.3px!important;
    font-weight:900!important;
    line-height:1.08!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6px!important;
    font-weight:800!important;
    line-height:1.02!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(70px + env(safe-area-inset-top))!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:58px!important;padding:4px 2px!important}
}


/* v6.55: exact Design D panel replacement, visible submenu labels, smaller menu button */
@media (max-width:900px){
  .io-nav,
  .io-nav.is-open,
  .io-header .io-nav,
  .io-header .io-nav.is-open{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
    height:0!important;
    max-height:0!important;
    overflow:hidden!important;
  }
  .io-mobile-menu-button{
    width:48px!important;
    height:48px!important;
    min-width:48px!important;
    min-height:48px!important;
    padding:4px 2px!important;
    top:calc(12px + env(safe-area-inset-top))!important;
    right:calc(10px + env(safe-area-inset-right))!important;
    gap:1px!important;
    border:1.5px solid rgba(214,188,245,.96)!important;
    border-radius:999px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,242,255,.97))!important;
    box-shadow:0 6px 14px rgba(124,82,182,.14), inset 0 1px 0 rgba(255,255,255,.98)!important;
    z-index:10020!important;
  }
  .io-mobile-menu-icon{width:14px!important;gap:3px!important}
  .io-mobile-menu-icon i{height:2px!important;border-radius:999px!important;background:#8a56d3!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(5px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-5px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:8px!important;line-height:1!important;letter-spacing:.01em!important;color:#8857d3!important}

  .io-design-d-mobile-menu{
    position:fixed!important;
    top:calc(70px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    z-index:10010!important;
    display:none;
    max-height:calc(100dvh - 78px - env(safe-area-inset-top))!important;
    overflow:auto!important;
    padding:0!important;
  }
  .io-design-d-mobile-menu.is-open{display:block!important}
  .io-design-d-mobile-shell{
    position:relative!important;
    width:100%!important;
    aspect-ratio:780 / 995!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:url("assets/images/menu-v655/menu-panel-v655.png") center/100% 100% no-repeat!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-shell:before,
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.7% 2.0% 3.4% 2.0%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{
    position:relative!important;
    min-width:0!important;
    min-height:0!important;
    overflow:visible!important;
  }
  .io-dd-item,
  .io-dd-game-toggle{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    color:transparent!important;
    text-decoration:none!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-item strong,
  .io-dd-item small,
  .io-dd-icon,
  .io-dd-game-toggle strong,
  .io-dd-game-toggle small,
  .io-dd-game-toggle .io-dd-icon,
  .io-dd-game-toggle i{opacity:0!important;pointer-events:none!important}

  .io-dd-game-group{z-index:30!important}
  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 6px)!important;
    width:calc(300% - 12px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:66px!important;
    padding:6px 4px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 2px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    color:#7d47be!important;
    font-size:7.6px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6.2px!important;
    font-weight:800!important;
    line-height:1.04!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(68px + env(safe-area-inset-top))!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:60px!important;padding:4px 2px!important}
}


/* v6.56: transparent frame overlay, exact icon crops, neutral game icon, visible submenu text */
@media (max-width:900px){
  .io-nav,
  .io-nav.is-open,
  .io-header .io-nav,
  .io-header .io-nav.is-open{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
    height:0!important;
    max-height:0!important;
    overflow:hidden!important;
  }

  .io-mobile-menu-button{
    width:48px!important;
    height:48px!important;
    min-width:48px!important;
    min-height:48px!important;
    padding:4px 2px!important;
    top:calc(12px + env(safe-area-inset-top))!important;
    right:calc(10px + env(safe-area-inset-right))!important;
    gap:1px!important;
    border:1.5px solid rgba(214,188,245,.96)!important;
    border-radius:999px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,242,255,.97))!important;
    box-shadow:0 6px 14px rgba(124,82,182,.14), inset 0 1px 0 rgba(255,255,255,.98)!important;
    z-index:10020!important;
  }
  .io-mobile-menu-icon{width:14px!important;gap:3px!important}
  .io-mobile-menu-icon i{height:2px!important;border-radius:999px!important;background:#8a56d3!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(1){transform:translateY(5px) rotate(45deg)!important}
  .io-mobile-menu-button.is-open .io-mobile-menu-icon i:nth-child(3){transform:translateY(-5px) rotate(-45deg)!important}
  .io-mobile-menu-text{font-size:8px!important;line-height:1!important;letter-spacing:.01em!important;color:#8857d3!important}

  .io-design-d-mobile-menu{
    position:fixed!important;
    top:calc(70px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    z-index:10010!important;
    display:none;
    max-height:calc(100dvh - 78px - env(safe-area-inset-top))!important;
    overflow:auto!important;
    padding:0!important;
  }
  .io-design-d-mobile-menu.is-open{display:block!important}

  .io-design-d-mobile-shell{
    position:relative!important;
    width:100%!important;
    aspect-ratio:780 / 995!important;
    padding:0!important;
    border:0!important;
    border-radius:34px!important;
    background:linear-gradient(180deg,rgba(248,244,255,.98),rgba(255,255,255,.98))!important;
    overflow:hidden!important;
    box-shadow:0 14px 34px rgba(110,69,172,.16)!important;
  }
  .io-design-d-mobile-shell:before{
    content:""!important;
    position:absolute!important;
    inset:0!important;
    background:url("assets/images/menu-v656/menu-frame-overlay-v656.png") center/100% 100% no-repeat!important;
    pointer-events:none!important;
    z-index:5!important;
  }
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.7% 2.0% 3.4% 2.0%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
    z-index:2!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{position:relative!important;min-width:0!important;min-height:0!important;overflow:visible!important}

  .io-dd-item,
  .io-dd-game-toggle{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:18px 6px 10px!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    text-decoration:none!important;
    color:#7b47bc!important;
    text-align:center!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-icon,
  .io-dd-game-toggle .io-dd-icon{
    display:grid!important;
    place-items:center!important;
    width:82px!important;
    height:60px!important;
    margin:0 auto 12px!important;
    opacity:1!important;
    pointer-events:none!important;
  }
  .io-dd-icon img,
  .io-dd-game-toggle .io-dd-icon img{
    display:block!important;
    width:100%!important;
    height:100%!important;
    object-fit:contain!important;
    filter:drop-shadow(0 4px 8px rgba(145,104,204,.18))!important;
  }
  .io-dd-item strong,
  .io-dd-game-toggle strong{
    display:block!important;
    opacity:1!important;
    color:#7b47bc!important;
    font-size:15px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:.02em!important;
    pointer-events:none!important;
  }
  .io-dd-item small,
  .io-dd-game-toggle small{
    display:block!important;
    opacity:1!important;
    margin-top:8px!important;
    color:#7f58b6!important;
    font-size:8.6px!important;
    font-weight:800!important;
    line-height:1.08!important;
    pointer-events:none!important;
  }

  .io-dd-game-toggle{
    padding:18px 6px 10px!important;
  }
  .io-dd-game-toggle i{
    position:absolute!important;
    top:14px!important;
    right:14px!important;
    width:18px!important;
    height:18px!important;
    border-radius:50%!important;
    background:#b57cf0!important;
    box-shadow:0 4px 10px rgba(157,103,228,.16)!important;
    opacity:1!important;
    pointer-events:none!important;
  }
  .io-dd-game-toggle i:before{
    content:""!important;
    position:absolute!important;
    top:4px!important;
    left:5px!important;
    width:5px!important;
    height:5px!important;
    border-right:2px solid #fff!important;
    border-bottom:2px solid #fff!important;
    transform:rotate(45deg)!important;
  }
  .io-dd-game-toggle[aria-expanded="true"] i:before{transform:rotate(225deg)!important}

  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 6px)!important;
    width:calc(300% - 12px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:66px!important;
    padding:6px 4px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 2px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    opacity:1!important;
    color:#7d47be!important;
    font-size:7.6px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    opacity:1!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6.2px!important;
    font-weight:800!important;
    line-height:1.04!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(68px + env(safe-area-inset-top))!important}
  .io-dd-icon,.io-dd-game-toggle .io-dd-icon{width:72px!important;height:52px!important;margin-bottom:8px!important}
  .io-dd-item strong,.io-dd-game-toggle strong{font-size:13px!important}
  .io-dd-item small,.io-dd-game-toggle small{font-size:8px!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:60px!important;padding:4px 2px!important}
}


/* v6.57: restore exact Design D frame/icons and neutral minigame tile */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    position:relative!important;
    width:100%!important;
    aspect-ratio:780 / 995!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:url("assets/images/menu-v657/menu-panel-v657.png") center/100% 100% no-repeat!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-shell:before,
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.7% 2.0% 3.4% 2.0%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
    z-index:2!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{position:relative!important;min-width:0!important;min-height:0!important;overflow:visible!important}

  .io-dd-item,
  .io-dd-game-toggle{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    text-decoration:none!important;
    color:transparent!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-item strong,
  .io-dd-item small,
  .io-dd-icon,
  .io-dd-game-toggle strong,
  .io-dd-game-toggle small,
  .io-dd-game-toggle .io-dd-icon,
  .io-dd-game-toggle i{
    opacity:0!important;
    pointer-events:none!important;
  }

  .io-dd-game-group{z-index:30!important}
  .io-dd-game-group:before{
    content:""!important;
    position:absolute!important;
    left:50%!important;
    top:52.5%!important;
    width:34.1%!important;
    height:28.6%!important;
    min-width:250px!important;
    min-height:266px!important;
    transform:translate(-50%,-50%)!important;
    background:url("assets/images/menu-v657/game-neutral-tile-v657.png") center/contain no-repeat!important;
    pointer-events:none!important;
    z-index:3!important;
  }

  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 6px)!important;
    width:calc(300% - 12px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:66px!important;
    padding:6px 4px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 2px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    opacity:1!important;
    color:#7d47be!important;
    font-size:7.6px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    opacity:1!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6.2px!important;
    font-weight:800!important;
    line-height:1.04!important;
    white-space:normal!important;
  }
}
@media (max-width:430px){
  .io-dd-game-group:before{
    width:34.1%!important;
    height:28.6%!important;
    min-width:210px!important;
    min-height:224px!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(68px + env(safe-area-inset-top))!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:60px!important;padding:4px 2px!important}
  .io-dd-game-group:before{min-width:190px!important;min-height:204px!important}
}


/* v6.58: restore v6.54 icon look and transparent Design D frame */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    position:relative!important;
    width:100%!important;
    aspect-ratio:780 / 995!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:url("assets/images/menu-v658/menu-panel-transparent-v658.png") center/100% 100% no-repeat!important;
    box-shadow:none!important;
    overflow:visible!important;
  }
  .io-design-d-mobile-shell:before,
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.7% 2.0% 3.4% 2.0%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
    z-index:2!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{position:relative!important;min-width:0!important;min-height:0!important;overflow:visible!important}

  .io-dd-item,
  .io-dd-game-toggle{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    color:transparent!important;
    text-decoration:none!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-item strong,
  .io-dd-item small,
  .io-dd-icon,
  .io-dd-game-toggle strong,
  .io-dd-game-toggle small,
  .io-dd-game-toggle .io-dd-icon,
  .io-dd-game-toggle i{
    opacity:0!important;
    pointer-events:none!important;
  }

  /* remove v6.57 special minigame overlay and use the original v6.54 look */
  .io-dd-game-group:before{display:none!important;content:none!important}

  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 6px)!important;
    width:calc(300% - 12px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:66px!important;
    padding:6px 4px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 2px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    opacity:1!important;
    color:#7d47be!important;
    font-size:7.6px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    opacity:1!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6.2px!important;
    font-weight:800!important;
    line-height:1.04!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(68px + env(safe-area-inset-top))!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:60px!important;padding:4px 2px!important}
}


/* v6.59: restore v6.54-style Design D panel and clip only outside frame */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    position:relative!important;
    width:100%!important;
    aspect-ratio:780 / 995!important;
    padding:0!important;
    border:0!important;
    border-radius:28px!important;
    background:url("assets/images/menu-v659/menu-panel-v659.png") center/100% 100% no-repeat!important;
    background-color:transparent!important;
    box-shadow:0 10px 26px rgba(110,69,172,.12)!important;
    overflow:hidden!important;
  }
  .io-design-d-mobile-shell:before,
  .io-design-d-mobile-shell:after{display:none!important}

  .io-design-d-mobile-menu{
    top:calc(70px + env(safe-area-inset-top))!important;
    left:10px!important;
    right:10px!important;
    max-height:calc(100dvh - 78px - env(safe-area-inset-top))!important;
    overflow:auto!important;
  }

  .io-design-d-mobile-grid{
    position:absolute!important;
    inset:11.7% 2.0% 3.4% 2.0%!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr))!important;
    gap:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    overflow:visible!important;
    z-index:2!important;
  }
  .io-design-d-mobile-grid > .io-dd-item,
  .io-design-d-mobile-grid > .io-dd-game-group{
    position:relative!important;
    min-width:0!important;
    min-height:0!important;
    overflow:visible!important;
  }

  .io-dd-item,
  .io-dd-game-toggle{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    color:transparent!important;
    text-decoration:none!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  .io-dd-item strong,
  .io-dd-item small,
  .io-dd-icon,
  .io-dd-game-toggle strong,
  .io-dd-game-toggle small,
  .io-dd-game-toggle .io-dd-icon,
  .io-dd-game-toggle i{
    opacity:0!important;
    pointer-events:none!important;
  }

  /* keep original panel look, no extra game overlay */
  .io-dd-game-group:before{display:none!important;content:none!important}

  .io-dd-submenu{
    position:absolute!important;
    top:98%!important;
    left:calc(-100% + 6px)!important;
    width:calc(300% - 12px)!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
    padding:8px!important;
    border:1px solid rgba(220,196,248,.96)!important;
    border-radius:16px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    backdrop-filter:blur(10px)!important;
    z-index:100!important;
  }
  .io-dd-submenu[hidden]{display:none!important}
  .io-dd-submenu li{list-style:none!important;margin:0!important;min-width:0!important}
  .io-dd-submenu button{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-rows:20px auto auto!important;
    align-items:center!important;
    justify-items:center!important;
    width:100%!important;
    min-height:66px!important;
    padding:6px 4px!important;
    border:1px solid rgba(226,208,249,.96)!important;
    border-radius:12px!important;
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    text-align:center!important;
  }
  .io-dd-sub-icon{
    display:grid!important;
    place-items:center!important;
    width:22px!important;
    height:18px!important;
    margin:0 auto 2px!important;
    font-size:14px!important;
    line-height:1!important;
  }
  .io-dd-submenu strong{
    display:block!important;
    opacity:1!important;
    color:#7d47be!important;
    font-size:7.6px!important;
    font-weight:900!important;
    line-height:1.1!important;
    letter-spacing:0!important;
    white-space:normal!important;
  }
  .io-dd-submenu small{
    display:block!important;
    opacity:1!important;
    margin-top:1px!important;
    color:#8f6abf!important;
    font-size:6.2px!important;
    font-weight:800!important;
    line-height:1.04!important;
    white-space:normal!important;
  }
}
@media (max-width:380px){
  .io-design-d-mobile-menu{left:8px!important;right:8px!important;top:calc(68px + env(safe-area-inset-top))!important}
  .io-dd-submenu{gap:4px!important;padding:6px!important}
  .io-dd-submenu button{min-height:60px!important;padding:4px 2px!important}
}


/* v6.60: shift Design D panel upward so the top ribbon is fully visible */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    background:url("assets/images/menu-v660/menu-panel-v660.png") center/100% 100% no-repeat!important;
    border-radius:28px!important;
    overflow:hidden!important;
  }
}


/* v6.61: replace Design D frame image with the user-supplied exact panel */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    background:url("assets/images/menu-v661/menu-panel-v661.png") center/100% 100% no-repeat!important;
    background-color:transparent!important;
    border-radius:28px!important;
    overflow:hidden!important;
  }
}


/* v6.62: remove semi-transparent lower area and add floating shadow */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    background:url("assets/images/menu-v661/menu-panel-v661.png") center/100% 100% no-repeat, #ffffff!important;
    background-color:#ffffff!important;
    border-radius:28px!important;
    overflow:hidden!important;
    box-shadow:0 18px 42px rgba(122,83,180,.18), 0 6px 16px rgba(122,83,180,.10)!important;
  }
}


/* v6.63: keep PNG transparency and strengthen floating shadow */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    background:url("assets/images/menu-v661/menu-panel-v661.png") center/100% 100% no-repeat!important;
    background-color:transparent!important;
    border-radius:28px!important;
    overflow:hidden!important;
    box-shadow:0 28px 60px rgba(108,66,170,.30), 0 12px 28px rgba(108,66,170,.22)!important;
  }
}


/* v6.64: replace frame image with latest user-supplied PNG */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    background:url("assets/images/menu-v664/menu-panel-v664.png") center/100% 100% no-repeat!important;
    background-color:transparent!important;
    border-radius:28px!important;
    overflow:hidden!important;
    box-shadow:0 28px 60px rgba(108,66,170,.30), 0 12px 28px rgba(108,66,170,.22)!important;
  }
}


/* v6.65: remove semi-transparent blur from the minigame submenu */
@media (max-width:900px){
  .io-dd-submenu{
    background:#fffdfd!important;
    -webkit-backdrop-filter:none!important;
    backdrop-filter:none!important;
    box-shadow:0 14px 28px rgba(109,69,171,.18)!important;
  }
  .io-dd-submenu button{
    background:#fffdfd!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
  }
}


/* v6.66: make the area below the frame transparent */
@media (max-width:900px){
  .io-dd-submenu{
    background:transparent!important;
    -webkit-backdrop-filter:none!important;
    backdrop-filter:none!important;
    box-shadow:none!important;
    border-color:rgba(212,185,244,.85)!important;
  }
  .io-dd-submenu button{
    background:transparent!important;
    box-shadow:none!important;
    border-color:rgba(220,197,248,.92)!important;
  }
}


/* v6.67: restore submenu translucency and remove frame-bottom haze */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    box-shadow:none!important;
  }
  .io-dd-submenu{
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,241,255,.96))!important;
    -webkit-backdrop-filter:blur(10px)!important;
    backdrop-filter:blur(10px)!important;
    box-shadow:0 12px 28px rgba(109,69,171,.18)!important;
    border-color:rgba(220,196,248,.96)!important;
  }
  .io-dd-submenu button{
    background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,242,255,.96))!important;
    box-shadow:0 6px 12px rgba(135,93,188,.08)!important;
    border-color:rgba(226,208,249,.96)!important;
  }
}


/* v6.69: diagnostic fix - disable backdrop blur on the Design D frame only */
@media (max-width:900px){
  .io-design-d-mobile-shell{
    -webkit-backdrop-filter:none!important;
    backdrop-filter:none!important;
  }
}


/* v6.70: use the provided 3-icon submenu card design */
@media (max-width:900px){
  .io-dd-submenu,
  .io-mini-game-submenu{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:8px!important;
    padding:0!important;
    margin:8px 0 0!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
  }
  .io-dd-submenu li,
  .io-mini-game-submenu li{
    list-style:none!important;
    margin:0!important;
    min-width:0!important;
    border-right:0!important;
  }
  .io-dd-submenu button,
  .io-mini-game-submenu button{
    display:block!important;
    width:100%!important;
    min-height:0!important;
    aspect-ratio:429 / 530!important;
    padding:0!important;
    border:0!important;
    border-radius:20px!important;
    background-color:transparent!important;
    background-repeat:no-repeat!important;
    background-position:center!important;
    background-size:100% 100%!important;
    box-shadow:none!important;
    overflow:hidden!important;
    text-indent:-9999px!important;
    font-size:0!important;
    line-height:0!important;
    position:relative!important;
  }
  .io-dd-submenu button[data-io-open-game-battle],
  .io-mini-game-submenu button[data-io-open-game-battle]{
    background-image:url("assets/images/minigame-submenu-v670/battle-card-v670.png")!important;
  }
  .io-dd-submenu button[data-io-open-game-wall],
  .io-mini-game-submenu button[data-io-open-game-wall]{
    background-image:url("assets/images/minigame-submenu-v670/wall-card-v670.png")!important;
  }
  .io-dd-submenu button[data-io-open-game-fight],
  .io-mini-game-submenu button[data-io-open-game-fight]{
    background-image:url("assets/images/minigame-submenu-v670/walk-card-v670.png")!important;
  }
  .io-dd-sub-icon,
  .io-mini-game-submenu-icon,
  .io-dd-submenu button strong,
  .io-dd-submenu button small,
  .io-mini-game-submenu button strong,
  .io-mini-game-submenu button small{
    display:none!important;
  }
}
