@font-face {
	font-family: "GarGo";
	font-weight: normal;
	src: url("GarGo-Regular.woff2") format("woff2");
}

@font-face {
	font-family: "GarGo";
	font-weight: bold;
	src: url("GarGo-Bold.woff2") format("woff2");
}

@font-face {
	font-family: "GarLogo";
	font-weight: normal;
	src: url("GarLogo-Regular.woff2") format("woff2");
}

#root {
	--base-font: "GarGo", sans-serif;
	--logo-font: "GarLogo";
	--white: 255, 255, 255;
	--black: 35, 25, 22;
	--key-color: 255, 241, 0;
	--C-dark: 12, 102, 56;
	--C-light: 228, 240, 212;
	--H-dark: 36, 164, 206;
	--H-light: 209, 239, 239;
	--A-dark: 237, 96, 147;
	--A-light: 252, 225, 234;
	--K-dark: 236, 143, 10;
	--K-light: 255, 244, 209;
	--AK-dark: 194, 29, 47;
	--AK-light: 250, 213, 217;
	--B-dark: 144, 81, 22;
	--B-light: 241, 233, 226;
	--N-dark: 133, 45, 111;
	--N-light: 241, 233, 239;
	--pocket-dark: 81, 149, 69;
	--pocket-light: 220, 234, 218;
	--other-dark: 67, 132, 191;
	--other-light: 229, 242, 254;
	--default-dark: 13, 66, 132;
	--default-light: 227, 234, 243;
	--logo-ga-cap: 0, 91, 172;
	--logo-ru: 234, 85, 6;
	--logo-ga: 0, 164, 150;
	--logo-n: 0, 161, 233;
	--logo-ti: 232, 82, 152;
	--logo-yu: 148, 94, 42;
	--logo-a: 146, 9, 131;
	--logo-on: 0, 129, 204;
	--logo-gak: 230, 0, 19;
	--logo-sai: 0, 145, 68;
	--logo-text: var(--black);
	position: relative;
	display: block;
	font: normal normal normal 16px/1.5 var(--base-font);
	color: rgb(var(--logo-text));
	background: rgb(var(--white));
}
#root,
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
body {
	padding: 20px;
}
.GKB-root {
	font: normal normal normal 16px/1.5 var(--base-font);
	letter-spacing: 0;
	text-decoration: none;
	text-spacing-trim: space-all;
}
.GKB-layout-h {
	display: flex;
}
.GKB-layout-v {
	display: flex;
	flex-direction: column;
}
.GKB-layout-v > * {
	flex-shrink: 0;
}
.GKB-hidden,
.GKB-hide {
	display: none !important;
}
.GKB-root {
	display: flex;
	flex-direction: column;
	position: relative;
	padding: 20px;
	color: rgb(var(--white));
	overflow: hidden;
}
.GKB-root.GKB-screen-full {
	padding: 54px 20px 52px;
}
.GKB-layout-root {
	flex: 1;
	position: relative;
	z-index: 1;
	row-gap: 8px;
}
.GKB-head-banner-wrapper {
	width: 200px;
	margin-top: -20px;
	margin-inline: auto;
}
.GKB-screen-full .GKB-head-banner-wrapper {
	margin-top: 0;
}
.GKB-head-banner {
	justify-content: center;
	align-items: center;
	padding: 6px 1.2px 5.9px 0;
	background-color: rgb(var(--key-color));
	border-radius: 0 0 6px 6px;
	box-shadow: 0 5px 5px #00000026;
}
.GKB-screen-full .GKB-head-banner {
	border-radius: 6px;
}
.GKB-header {
	align-items: center;
	column-gap: 8px;
}
.GKB-header-age {
	width: 26.2px;
	height: 38px;
}
.GKB-header-type {
	min-width: 46px;
	padding: 2px 4px;
	font-size: 12px;
	line-height: 16px;
	font-weight: 700;
	text-align: center;
	color: rgb(var(--white));
	background: rgb(var(--black));
	border-radius: 2px;
}
.GKB-header-ticket {
	flex: 1;
	display: flex;
	align-items: center;
	column-gap: 5px;
	font-size: 11px;
	color: rgb(var(--white));
}
.GKB-header-ticket > img {
	width: 22px;
	height: 22px;
}
.GKB-letter-width-4-5 {
	white-space: nowrap;
}
.GKB-letter-width-4-5 > span {
	display: block;
	margin-inline: -0.5em;
	transform: scaleX(0.8);
}
.GKB-description-group {
	font-size: 14px;
	line-height: 18px;
	color: rgb(var(--dark-color));
	background: rgb(var(--white));
	border-radius: 8px;
	overflow: hidden;
}
.GKB-description-main {
	row-gap: 5px;
	padding: 14px 20px 18px;
}
.GKB-date-and-time {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	column-gap: 14px;
	row-gap: 3px;
	font-weight: 700;
}
.GKB-date {
	display: flex;
	justify-content: flex-start;
	align-items: baseline;
	text-align: center;
	gap: 1px;
}
.GKB-date > .--year {
	text-align: left;
}
.GKB-date > .--num {
	font-size: 20px;
}
.GKB-time {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	column-gap: 14px;
	row-gap: 3px;
}
.GKB-time > .--multi {
	font-weight: 400;
}
.GKB-title {
	font-size: 19px;
	line-height: 24px;
	font-weight: 700;
	text-decoration: underline;
}
.GKB-venue {
	margin-top: 2px;
	display: flex;
	align-items: flex-start;
	column-gap: 5px;
	font-size: 12px;
	line-height: 14px;
}
.GKB-venue-label {
	padding: 0 5px;
	font-size: 10px;
	line-height: 14px;
	color: rgb(var(--white));
	background: rgb(var(--dark-color));
	border-radius: 2px;
}
.GKB-copy {
	padding: 11px 20px 12px;
	font-size: 12px;
	line-height: 18px;
	color: rgb(var(--black));
	background: rgb(var(--light-color));
	white-space: pre-line;
}
.GKB-program-group {
	row-gap: 1px;
	color: rgb(var(--dark-color));
	border-radius: 8px;
	overflow: hidden;
}
.GKB-program-container {
	row-gap: 14px;
	padding: 15px 20px;
	background: rgb(var(--white));
}
.GKB-program-row {
	row-gap: 6px;
	color: rgb(var(--dark-color));
}
.GKB-program-composer {
	font-size: 12px;
	line-height: 14px;
}
.GKB-program-title {
	display: flex;
	align-items: flex-start;
	column-gap: 4px;
	font-size: 15px;
	line-height: 17px;
	font-weight: 700;
}
.GKB-program-title-icon {
	width: 10px;
	height: 14px;
	margin-top: 1.5px;
	margin-left: 1px;
}
.GKB-player-container {
	padding: 13px 20px 15px;
	font-size: 12px;
	line-height: 18px;
	background: rgb(var(--white));
}
.GKB-fee-group {
	row-gap: 8px;
	position: relative;
	padding: 15px 20px 14px;
	color: rgb(var(--dark-color));
	background: rgb(var(--light-color));
	border-radius: 8px;
	overflow: hidden;
}
.GKB-fee-list {
	row-gap: 5px;
	font-size: 14px;
	line-height: 18px;
	font-weight: 700;
}
.GKB-fee-item {
	column-gap: 5px;
}
.GKB-fee-icon {
	width: 20px;
	height: 20px;
	margin-block: -1px;
}
.GKB-discount-list {
	font-size: 10px;
	line-height: 12px;
}
.GKB-fee-note {
	font-size: 12px;
	line-height: 18px;
	white-space: pre-line;
}
.GKB-seat-label {
	position: absolute;
	top: 0;
	right: 0;
	padding: 3px 9px;
	font-size: 10px;
	line-height: 12px;
	color: rgb(var(--white));
	background: rgb(var(--black));
	border-bottom-left-radius: 6px;
}
.GKB-note-list {
	row-gap: 5px;
	margin: 4px 2px 0;
	font-size: 12px;
	line-height: 16px;
	list-style: none;
}
.GKB-note-item {
	display: flex;
	align-items: flex-start;
	gap: 6px;
}
.GKB-note-list-marker {
	height: 16px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.GKB-note-list-marker > img {
	width: 4px;
	height: 4px;
}
.GKB-spacer {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.GKB-spacer img {
	width: auto;
}
