/* Course */

.course_pane {
	position: relative;
    float: left;
    width: 48.5%;
}
.course_pane:nth-of-type(even) {
    float: right;
}
.course_pane:nth-of-type(2n + 1) {
    clear:anim both;
}
.course_pane:nth-last-of-type(n + 3) {
    margin-bottom: 2em;
}
.course_pane a {
	position: relative;
	display: block;
	height: 100%;
	text-decoration: none;
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
	z-index: 1;
}
.course_pane a::before {
	position: absolute;
	left: 0;
	top: 0;
	content: '';
	width: 100%;
	height: 100%;
	background: #fff;
	z-index: 10;
}
.course_v.course_pane a::before {
	background: var(--v);
}
.course_p.course_pane a::before {
	background: var(--p);
}
.course_pd.course_pane a::before {
	background: var(--pd);
}
.course_ad.course_pane a::before {
	background: var(--ad);
}
.course_i.course_pane a::before {
	background: var(--i);
}
.course_f.course_pane a::before {
	background: var(--f);
}

.course_pane.course_pane_reveal a::before {
	animation: name 650ms ease-in-out 0ms 1 forwards;
}

@keyframes name {
	0% {
		width: 100%;
	}
	100% {
		width: 0;
	}
}

.course_image {
	position: absolute;
	top: 0;
	left: 0;
	width: 200px;
	height: 100%;
	background: #ccc;
	z-index: 1;
}
.course_text {
	position: relative;
	float: right;
	padding: 2.5em 1.8em 1.7em 2.3em;
	width: calc(100% - 200px);
	z-index: 1;
}
.course_text h4,
.course_text p,
.course_text h5,
.course_text ul {
	position: relative;
	z-index: 10;
}
.course_text h6 {
	position: absolute;
	top: 10px;
	right: 22px;
	font-size: 8.13em;
	line-height: 1em;
	letter-spacing: -0.05em;
	color: #ccc;
	opacity: 0.18;
	z-index: 1;
}
.course_v .course_text h6 {
	color: var(--v);
}
.course_p .course_text h6 {
	color: var(--p);
}
.course_pd .course_text h6 {
	color: var(--pd);
}
.course_i .course_text h6 {
	right: 40px;
	color: var(--i);
}
.course_ad .course_text h6 {
	color: var(--ad);
}
.course_f .course_text h6 {
	color: var(--f);
}
.course_text h4 {
	margin-bottom: 0.5em;
	font-size: 1.15em;
	font-weight: 500;
}
.course_text p {
	padding-bottom: 0.8em;
	margin-bottom: 0.5em;
	border-bottom: 1px solid #eaeaea;
	font-size: 0.9em;
	line-height: 1.42em;
}
.course_text h5 {
	font-size: 0.73em;
	font-weight: 500;
}
.course_text li {
	float: left;
	padding: 0.2em 0.5em;
	margin-right: 0.35em;
	margin-bottom: 0.45em;
	font-size: 0.75em;
	line-height: 1.2em;
	color: #fff;
	background: #ccc;
	border-radius: 200px;
}
.course_v .course_text li {
	background: var(--v);
}
.course_p .course_text li {
	background: var(--p);
}
.course_pd .course_text li {
	background: var(--pd);
}
.course_i .course_text li {
	background: var(--i);
}
.course_ad .course_text li {
	background: var(--ad);
}
.course_f .course_text li {
	background: var(--f);
}


/* Single */

#course_summary_chart {
	float: right;
	position: relative;
    width: 50%;
    width: 44%;
	/* opacity: 0; */
}
@keyframes circle_show {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

.course_summary_chart_image {
	display: none;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: auto;
	opacity: 0.5;
	z-index: 10;
}

.venn_diagram {
	position: relative;
}
.venn_circle {
	color: #fff;
	border-radius: 50%;
}
.venn_circle h5 {
	font-weight: 500;
	line-height: 1.5em;
}

/** ビジュアルデザイン科 **/

#venn_diagram_v {
    height: 400px;
}
#venn_diagram_v .venn_circle {
	position: absolute;
    width: 165px;
    height: 165px;
	mix-blend-mode: multiply;
	opacity: 0;
}
#venn_diagram_v .venn_circle h5 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
}
#venn_diagram_v .venn_circle h6 {
    position: absolute;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    font-size: 1.4em;
    letter-spacing: 0.15em;
    line-height: 1em;
    height: max-content;
    top: 50%;
    transform: translateY(-50%);
}
#venn_diagram_v #venn_circle_top_left h6,
#venn_diagram_v #venn_circle_bottom_left h6 {
    left: -44px;
}
#venn_diagram_v #venn_circle_top_right h6,
#venn_diagram_v #venn_circle_bottom_right h6 {
    right: -44px;
}
#venn_diagram_v #venn_circle_top_left {
    top: 30px;
    left: calc(50% - 205px);
    background: rgba(205, 179, 205, 0.8);
}
#venn_diagram_v #venn_circle_top_left h6 {
    color: rgba(205, 179, 205, 1);
}
#venn_diagram_v #venn_circle_top_right {
    top: 30px;
    right: calc(50% - 205px);
    background: rgba(165, 212, 180, 0.8);
}
#venn_diagram_v #venn_circle_top_right h6 {
    color: rgba(165, 212, 180, 1);
}
#venn_diagram_v #venn_circle_bottom_left {
    bottom: 30px;
    left: calc(50% - 205px);
    background: rgba(243, 185, 165, 0.8);
}
#venn_diagram_v #venn_circle_bottom_left h6 {
    color: rgba(243, 185, 165, 1);
}
#venn_diagram_v #venn_circle_bottom_right {
    bottom: 30px;
    right: calc(50% - 205px);
    background: rgba(175, 197, 221, 0.8);
}
#venn_diagram_v #venn_circle_bottom_right h6 {
    color: rgba(175, 197, 221, 1);
}
#venn_diagram_v #venn_circle_center {
    top: 50%;
    left: 50%;
    width: 200px;
    height: 200px;
    transform: translate(-50%, -50%);
    background: rgba(253, 162, 157, 0.9);
    z-index: 5;
	opacity: 0;
}
#venn_diagram_v #venn_circle_center h5 {
    font-size: 1.1em;
}
.chart_revealed #venn_diagram_v #venn_circle_center {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_v #venn_circle_top_left {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_v #venn_circle_top_right {
	animation: circle_show 400ms 600ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_v #venn_circle_bottom_left {
	animation: circle_show 400ms 900ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_v #venn_circle_bottom_right {
	animation: circle_show 400ms 1200ms ease-in-out forwards;
}

/** 映像デザイン科 **/

#venn_diagram_p {
    height: 300px;
}
#venn_diagram_p .venn_circle {
	position: absolute;
	width: 180px;
	height: 180px;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0;
}
#venn_diagram_p .venn_circle h5 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 1.4em;
	font-size: 1.2em;
	line-height: 1.2em;
	width: max-content;
}
#venn_diagram_p #venn_circle_left {
    left: calc(50% - 240px);
    background: rgba(135, 98, 152, 0.75);
}
#venn_diagram_p #venn_circle_center {
    left: calc(50% - 90px);
    background: rgba(62, 113, 95, 0.75);
}
#venn_diagram_p #venn_circle_right {
    left: calc(50% + 60px);
    background: rgba(152, 95, 52, 0.75);
}
.chart_revealed #venn_diagram_p #venn_circle_left {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_p #venn_circle_center {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_p #venn_circle_right {
	animation: circle_show 400ms 600ms ease-in-out forwards;
}

/** プロダクトデザイン科 */

#venn_diagram_pd {
    height: 385px;
}
#venn_diagram_pd .venn_circle {
	position: absolute;
	width: 190px;
	height: 190px;
	text-align: center;
	padding-top: 55px;
	box-sizing: border-box;
	opacity: 0;
}
#venn_diagram_pd .venn_circle h5 {
    font-size: 1.4em;
    font-weight: 700;
    letter-spacing: 0.08em;
    letter-spacing: 0.1em;
    margin-bottom: 8px;
}
#venn_diagram_pd .venn_circle p {
    position: relative;
    font-size: 0.9em;
    line-height: 1.65em;
    letter-spacing: 0.03em;
    text-align: center;
}
#venn_diagram_pd #venn_circle_top {
    top: 0;
    left: calc(50% - 95px);
    background: rgba(108, 68, 132, 0.75);
}
#venn_diagram_pd #venn_circle_left {
    bottom: 45px;
    left: calc(50% - 180px);
    background: rgba(62, 115, 88, 0.75);
}
#venn_diagram_pd #venn_circle_right {
    bottom: 45px;
    left: calc(50% - 10px);
    background: rgba(148, 88, 62, 0.75);
}
.chart_revealed #venn_diagram_pd #venn_circle_top {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_pd #venn_circle_left {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_pd #venn_circle_right {
	animation: circle_show 400ms 600ms ease-in-out forwards;
}

/** インテリアデザイン科 **/

#venn_diagram_i {
	margin-top: -50px;
    height: 510px;
}
#venn_diagram_i .venn_circle {
	position: absolute;
	width: 150px;
	height: 150px;
	opacity: 0;
}
#venn_diagram_i .venn_circle h5 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: max-content;
    font-size: 1.1em;
    line-height: 1.2em;
}
#venn_diagram_i #venn_circle_center h5 {
    font-size: 1.3em;
}
#venn_diagram_i #venn_circle_top_center {
    top: 40px;
    left: calc(50% - 75px);
    background: rgba(100, 170, 140, 0.75);
}
#venn_diagram_i #venn_circle_top_right {
    top: 148px;
    left: calc(50% + 75px);
    background: rgba(218, 132, 145, 0.75);
}
#venn_diagram_i #venn_circle_bottom_right {
    top: 318px;
    left: calc(50% - -25px);
    background: rgba(150, 178, 212, 0.75);
}
#venn_diagram_i #venn_circle_bottom_left {
    top: 318px;
    left: calc(50% - 170px);
    background: rgba(218, 158, 138, 0.75);
}
#venn_diagram_i #venn_circle_top_left {
    top: 148px;
    left: calc(50% - 225px);
    background: rgba(170, 148, 198, 0.75);
}
#venn_diagram_i #venn_circle_center {
    top: 53.5%;
    left: 50%;
    width: 210px;
    height: 210px;
    transform: translate(-50%, -50%);
    background: rgba(138, 72, 95, 0.82);
    z-index: 5;
}
.chart_revealed #venn_diagram_i #venn_circle_center {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_i #venn_circle_top_center {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_i #venn_circle_top_right {
	animation: circle_show 400ms 600ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_i #venn_circle_bottom_right {
	animation: circle_show 400ms 900ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_i #venn_circle_bottom_left {
	animation: circle_show 400ms 1200ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_i #venn_circle_top_left {
	animation: circle_show 400ms 1500ms ease-in-out forwards;
}

/* 建築デザイン科 */

.page_ad #course_summary_chart {
	width: 45% !important;
}
#venn_diagram_ad {
	position: relative;
	padding-top: 60px;
}
#venn_diagram_ad h5 {
    position: absolute;
    top: 0;
	left: 50%;
	transform: translateX(-50%);
    font-size: 1.3em;
	line-height: 1.2em;
	letter-spacing: 0.1em;
    color: #78C8DC;
    border: 2px solid #78C8DC;
	background: #fff;
    width: max-content;
    padding: 10px 35px;
	opacity: 0;
}
.venn_diagram_line {
    position: relative;
	padding-left: 90px;
    overflow: hidden;
}
.venn_diagram_line:not(:first-of-type) {
	margin-top: -25px;
}
.venn_diagram_line h6 {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 1em;
    line-height: 1.2em;
    letter-spacing: 0.15em;
    color: #78C8DC;
	background: #fff;
    border: 1.5px solid #78C8DC;
    padding: 40px 10px 40px 8px;
    margin-right: 20px;
    height: max-content;
	opacity: 0;
}
.venn_diagram_line .venn_circles {
    overflow: hidden;
}
#venn_diagram_ad .venn_circle {
    float: left;
    position: relative;
    width: 160px;
    height: 160px;
	opacity: 0;
}
#venn_diagram_ad .venn_circle:nth-last-of-type(-n + 2) {
    margin-top: -25px;
}
#venn_diagram_ad .venn_circle:nth-of-type(even) {
    margin-left: -25px;
}
#venn_diagram_ad .venn_circle p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    font-size: 1em;
    font-weight: 500;
    line-height: 1.2em;
}
#venn_circle_1_1 {
	background: rgba(188,  82,  78, 0.75);
}
#venn_circle_1_2 {
	background: rgba(138,  98, 155, 0.75);
}
#venn_circle_1_3 {
	background: rgba(158, 112,  52, 0.75);
}
#venn_circle_1_4 {
	background: rgba(142, 152,  65, 0.75);
}
#venn_circle_2_1 {
	background: rgba( 78,  92, 128, 0.75);
}
#venn_circle_2_2 {
	background: rgba( 72, 118, 108, 0.75);
}
#venn_circle_2_3 {
	background: rgba( 85,  92, 138, 0.75);
}
#venn_circle_2_4 {
	background: rgba( 58, 118,  92, 0.75);
}
.chart_revealed #venn_diagram_ad h5 {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed .venn_diagram_line h6 {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_1_1 {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_1_2 {
	animation: circle_show 400ms 500ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_1_3 {
	animation: circle_show 400ms 700ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_1_4 {
	animation: circle_show 400ms 900ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_2_1 {
	animation: circle_show 400ms 1100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_2_2 {
	animation: circle_show 400ms 1300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_2_3 {
	animation: circle_show 400ms 1500ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_ad #venn_circle_2_4 {
	animation: circle_show 400ms 1700ms ease-in-out forwards;
}


/* 美術科 */

#venn_diagram_f {
    height: 385px;
}
#venn_diagram_f .venn_circle {
	position: absolute;
    width: 190px;
    height: 190px;
	opacity: 0;
}
#venn_diagram_f .venn_circle h5 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
    font-size: 1.2em;
    font-weight: 500;
    letter-spacing: 0.12em;
	text-align: center;
}
#venn_diagram_f #venn_circle_top {
    top: 0;
    left: calc(50% - 95px);
    background: rgba(118, 80, 132, 0.75);
}
#venn_diagram_f #venn_circle_left {
    bottom: 46px;
    left: calc(50% - 180px);
    background: rgba(75, 108, 108, 0.75);
}
#venn_diagram_f #venn_circle_right {
    bottom: 46px;
    left: calc(50% - 10px);
    background: rgba(145, 105, 68, 0.75);
}
.chart_revealed #venn_diagram_f #venn_circle_top {
	animation: circle_show 400ms 100ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_f #venn_circle_left {
	animation: circle_show 400ms 300ms ease-in-out forwards;
}
.chart_revealed #venn_diagram_f #venn_circle_right {
	animation: circle_show 400ms 600ms ease-in-out forwards;
}

#course_summary_slides {
    float: left;
    width: 40%;
}
.course_summary_slide {
    aspect-ratio: 25 / 33;
    background: #ccc;
    border-radius: 20px;
    overflow: hidden;
}
#course_summary_text {
    float: left;
    width: 53%;
    width: 44%;
}
.aspect_s #course_summary_chart {
	width: 44%;
}
.aspect_s #course_summary_text {
	width: 49%;
}
.aspect_h #course_summary_chart {
	width: 50%;
}
.aspect_h #course_summary_text {
	width: 45%;
}
.aspect_p #course_summary_chart {
	width: 45%;
}
.aspect_p #course_summary_text {
	width: 50%;
}
#course_summary_text .document_list {
	margin-top: 1.8em;
}
#course_summary_bar {
    margin-bottom: 5.5em;
    padding: 0.6em 0.8em 0.5em 0.8em;
    font-size: 0.8em;
    line-height: 1.2em;
	text-align: right;
    color: #fff;
	color: #c5c0ab;
	border-radius: 6px;
	background: #efebde !important;
}
.page_v h3#course_summary_bar {
    background: var(--v);
}
.page_p h3#course_summary_bar {
    background: var(--p);
}
.page_pd h3#course_summary_bar {
    background: var(--pd);
}
.page_i h3#course_summary_bar {
    background: var(--i);
}
.page_ad h3#course_summary_bar {
    background: var(--ad);
}
.page_f h3#course_summary_bar {
    background: var(--f);
}
#course_summary_text h4 {
    margin-bottom: 1.6em;
    margin-bottom: 1em;
    font-size: 1.6em;
    font-size: 1.2em;
    font-weight: 500;
    line-height: 1.6em;
    line-height: 1.8em;
}
.course_summary_image {
    margin-bottom: 3.3em;
}

/* News */

#course_news .news_list_color {
	display: none;
}
#course_news .news_list_title {
	width: calc(100% - 115px);
}

/* Studies */

.course_studies_block {
    padding: 2.7em 2.7em 1.5em 2.7em;
    background: #fff;
    border-radius: 15px;
}
.course_studies_block:not(:last-of-type) {
    margin-bottom: 4.4em;
}
.course_studies_block .heading {
    position: relative;
    padding-bottom: 0.5em;
    margin-bottom: 2em;
}
.course_studies_block .heading::before {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #000;
    border-radius: 200px;
    overflow: hidden;
}
.page_v .course_studies_block .heading::before {
    background: var(--v);
}
.page_p .course_studies_block .heading::before {
    background: var(--p);
}
.page_pd .course_studies_block .heading::before {
    background: var(--pd);
}
.page_i .course_studies_block .heading::before {
    background: var(--i);
}
.page_ad .course_studies_block .heading::before {
    background: var(--ad);
}
.page_f .course_studies_block .heading::before {
    background: var(--f);
}
.page_v .course_studies_block .heading h4,
.page_v .course_studies_time,
.page_v .course_studies_pane h5 {
    color: var(--v);
}
.page_p .course_studies_block .heading h4,
.page_p .course_studies_time,
.page_p .course_studies_pane h5 {
    color: var(--p);
}
.page_pd .course_studies_block .heading h4,
.page_pd .course_studies_time,
.page_pd .course_studies_pane h5 {
    color: var(--pd);
}
.page_i .course_studies_block .heading h4,
.page_i .course_studies_time,
.page_i .course_studies_pane h5 {
    color: var(--i);
}
.page_ad .course_studies_block .heading h4,
.page_ad .course_studies_time,
.page_ad .course_studies_pane h5 {
    color: var(--ad);
}
.page_f .course_studies_block .heading h4,
.page_f .course_studies_time,
.page_f .course_studies_pane h5 {
    color: var(--f);
}
.course_studies_block .heading h4 {
    float: left;
    font-size: 4.15em;
    font-size: 3.6em;
    font-weight: 500;
    line-height: 1em;
}
.course_studies_block .heading h4 .label {
    display: inline-block;
    margin-left: 0.2em;
    transform: translateY(-2px);
    font-size: 0.32em;
}
#course_studies_1 .heading h4 .label {
    margin-left: 0.4em;
}
.course_studies_time {
    float: right;
    font-size: 4.15em;
    font-size: 3.6em;
    font-weight: 500;
    line-height: 1em;
}
.course_studies_time span.label_after,
.course_studies_time span.label_before {
    display: inline-block;
    transform: translateY(-2px);
    font-size: 0.32em;
}
.course_studies_time span.label_before {
    margin-right: 0.3em;
}
.course_studies_time span.label_after {
    margin-left: 0.2em;
}

.course_studies_pane {
	float: left;
	margin-bottom: 1.25em;
	width: 30%;
}
.course_studies_pane:nth-of-type(3n - 1) {
	margin-left: 5%;
	margin-right: 5%;
}
.course_studies_pane:nth-of-type(3n + 1) {
	clear: both;
}

.course_studies_pane h5 {
    margin-bottom: 0.35em;
    font-size: 1.05em;
    font-weight: 500;
}
.course_studies_pane h5 span {
    font-size: 0.75em;
}
.course_study_image {
    margin-bottom: 0.75em;
    aspect-ratio: 106 / 65;
    background: #ccc;
    border-radius: 6px;
    overflow: hidden;
}
.course_study p {
    font-size: 0.85em;
    line-height: 1.7em;
}

/* Works */

.works_pane {
    float: left;
    width: 47%;
}
.works_pane:nth-of-type(even) {
    float: right;
}
.works_pane:nth-of-type(2n + 1) {
    clear: both;
}
.works_pane:nth-last-of-type(n + 2) {
    margin-bottom: 2.5em;

}
.works_image {
    position: relative;
    margin-bottom: 1.3em;
    aspect-ratio: 16 / 9;
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
}
.works_image.no_image {
    cursor: default;
    pointer-events: none;
}
.works_image.no_image .works_links {
    pointer-events: auto;
}
.works_links {
	position: absolute;
	bottom: 15px;
	right: 15px;
}
.works_links li {
	float: left;
}
.works_links li:not(:last-of-type) {
	margin-right: 0.5em;
}
.works_links li a {
	display: block;
	width: 38px;
	height: 38px;
	background: var(--students) url(../images/common/icon_link_white.png) no-repeat center / 20px;
	border-radius: 6px;
}
.works_links li.works_zoom a {
	background: #36cf73 url(../images/common/icon_zoom_white.png) no-repeat center / 20px;
}
.works_links li.works_video a {
	background: #00a2e7 url(../images/course/icon_play.png) no-repeat center / 15px;
}
.works_data {
    margin-bottom: 0.8em;
}
.works_data h5 {
	float: left;
	margin-right: 1em;
	padding: 0.3em 0.8em 0.2em 0.8em;
	font-size: 0.76em;
	font-weight: 500;
	letter-spacing: 0.07em;
	line-height: 1.4em;
	background: #fff;
}
.works_data h6 {
	float: left;
	margin-top: 3px;
	font-size: 0.8em;
	font-weight: 500;
	letter-spacing: 0.07em;
	line-height: 1.4em;
}
.works_pane h4 {
    margin-bottom: 0.5em;
    font-size: 1.13em;
    font-weight: 500;
    letter-spacing: 0.07em;
    line-height: 1.4em;
}
.works_pane p {
    font-size: 0.76em;
    letter-spacing: 0;
    line-height: 1.4em;
    line-height: 1.5em;
}
.works_award {
    margin-bottom: 1em;
    padding-bottom: 0.9em;
    border-bottom: 1px dashed #ccc;
}
.wo_desc .works_award {
    margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

/* Timetable */

#course_timetable .tabs ul {
    margin: 0 auto;
    width: 70%;
    width: 100%;
}
#course_timetable .tab_content {
    position: relative;
    min-height: 450px;
}
#course_timetable .tab_content p.empty {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#course_timetable table {
	width: 100%;
	border-collapse: collapse;
	border: solid 1px #ddd;
    background: #fff;
}
#course_timetable td,
#course_timetable th {
	padding: 1.5em 1em;
	text-align: center;
	font-size: 0.85em;
	line-height: 1.6em;
	border: solid 1px #ddd;
	border-collapse: collapse;
	vertical-align: middle;
}
#course_timetable thead th {
	padding: 1em 1em;
	text-align: center;
	font-weight: 500 !important;
	background: #f1eee4;
	background: #f3f3f3;
	font-size: 0.95em;
}
#course_timetable tbody th {
	width: 5%;
	font-weight: 500 !important;
	background: #f1eee4;
	background: #f3f3f3;
}
#course_timetable tbody td {
	width: 19%;
	font-size: 0.8em;
}
.page_p .timetable_specialized {
	position: relative;
	color: var(--p) !important;
}
.page_v .timetable_specialized {
	position: relative;
	color: var(--v) !important;
}
.page_pd .timetable_specialized {
	position: relative;
	color: var(--pd) !important;
}
.page_f .timetable_specialized {
	position: relative;
	color: var(--f) !important;
}
.page_i .timetable_specialized {
	position: relative;
	color: var(--i) !important;
}
.page_ad .timetable_specialized {
	position: relative;
	color: var(--ad) !important;
}
._timetable_specialized::before {
	position: absolute;
	right: 0px;
	top: 0px;
	display: block;
	content: '専門';
	padding: 0.35em 0.5em;
	font-size: 0.8em;
	line-height: 1em;
	background: #f1eee4;
}

/* Faq */

#course_faq .heading {
	margin-bottom: 2em;
}
#course_faq h3.title {
	float: left;
}
#course_faq .more {
	float: right;
}
.course_faq_card {
	position: relative;
	border-radius: 30px;
	cursor: pointer;
}
.course_faq_card {
	display: table;
	padding: 2.5em 2.5em 2.8em 2.8em;
	padding: 2em;
	width: 100%;
	min-height: 7em;
	background: #fff;
	z-index: 10;
}
.course_faq_card h4 {
	display: table-cell;
	font-size: 1em;
	font-size: 0.95em;
	line-height: 1.7em;
	line-height: 1.6em;
	letter-spacing: 0.03em;
	vertical-align: middle;
}
.course_faq_card p {
	font-size: 0.92em;
	letter-spacing: 0.07em;
	text-align: right;
}
.course_faq_card_under {
	transform: translate(50px, -25px);
	transform: translate(40px, -25px);
	padding: 3.6em 2.5em 2.8em 2.8em;
	padding: 3em 2em 2em 2em;
	color: #fff;
	background: #000;
	z-index: 1;
}
.page_v .course_faq_card_under {
	background: var(--v);
}
.page_p .course_faq_card_under {
	background: var(--p);
}
.page_pd .course_faq_card_under {
	background: var(--pd);
}
.page_i .course_faq_card_under {
	background: var(--i);
}
.page_ad .course_faq_card_under {
	background: var(--ad);
}
.page_f .course_faq_card_under {
	background: var(--f);
}
.course_faq_card_under::before {
	position: absolute;
	bottom: 16px;
	right: 17px;
	content: '';
	width: 26px;
	height: 26px;
	background: url(../images/common/icon_card_under.png) no-repeat center / 100%;
}
.course_faq_card_under h4 {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-line-clamp: 3;
	font-size: 1em;
	font-size: 0.95em;
	line-height: 1.7em;
	line-height: 1.6em;
	letter-spacing: 0.03em;
	min-height: 5.1em;
	min-height: 4.8em;
}
.course_faq_card_under ul {
	display: none;
}

#course_faq_overlay {
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.2);
	z-index: 100001;
}
#course_faq_detail {
	display: none;
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 580px;
	max-height: 600px;
	background: #fff;
	border-radius: 20px;
	z-index: 100002;
	overflow-y: scroll;
	box-shadow: 0px 0px 15px rgba(0,0,0,0.2);
}
#course_faq_detail_inner {
	position: relative;
	padding: 3em 3.5em;
	width: 100%;
	height: 100%;
}
#course_faq_detail h4 {
	margin-bottom: 1em;
	font-size: 1.1em;
	font-weight: 500;
	line-height: 1.6em;
}
#course_faq_detail h5 {
	line-height: 1.7em;
}
#course_faq_detail ul {
	margin-top: 1em;
	padding-left: 1.5em;
	font-size: 0.85em;
}
#course_faq_detail li {
	list-style-type: disc;
}
#course_faq_detail_close {
	position: absolute;
	right: 20px;
	top: 20px;
	width: 30px;
	height: 30px;
	background: url(../images/common/icon_close.png) no-repeat center / cover;
	cursor: pointer;
}

#course_graph {
	margin: 0 auto 4.5em auto;
	width: 65%;
	opacity: 0;
	animation: course_graph_motion 1000ms 1 ease-in-out forwards;
}

@keyframes course_graph_motion {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}


/* Voice */

#course_path_voice_panes {
	padding: 3em;
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
}
.course_path_voice_pane:not(:last-of-type) {
	margin-bottom: 3.5em;
	padding-bottom: 3em;
	border-bottom: 1px solid #e7e2cd;
}
.course_path_voice_pane_heading {
	float: left;
	width: 25%;
}
.course_path_voice_pane_main_image {
	position: relative;
	margin-bottom: 1em;
	margin-bottom: 1.2em;
	aspect-ratio: 1 / 1;
	background: #fff;
	border-radius: 10px;
	overflow: hidden;
}
.course_path_voice_pane_heading h6 {
	position: absolute;
	/* top: 15px; */
	bottom: 15px;
	right: 15px;
	right: auto;
	left: 50%;
	transform: translateX(-50%);
	padding: 0.5em 0.55em 0.55em 0.3em;
	padding: 0.55em 0.5em 0.5em 0.55em;
	width: max-content;
	font-size: 0.8em;
	font-size: 0.7em;
	line-height: 1.2em;
	line-height: 1em;
	color: #fff;
	background: var(--students);
	border-radius: 4px;
}
.page_v .course_path_voice_pane_heading h6 {
	background: var(--v);
}
.page_p .course_path_voice_pane_heading h6 {
	background: var(--p);
}
.page_pd .course_path_voice_pane_heading h6 {
	background: var(--pd);
}
.page_i .course_path_voice_pane_heading h6 {
	background: var(--i);
}
.page_ad .course_path_voice_pane_heading h6 {
	background: var(--ad);
}
.page_f .course_path_voice_pane_heading h6 {
	background: var(--f);
}
.course_path_voice_pane_heading h6 span {
	display: inline-block;
	margin: 0 0.15em;
	font-size: 1.15em;
	text-combine-upright: all;
}
.course_path_voice_pane_heading h5 {
	margin-left: 0.6rem;
	margin-bottom: 0.3em;
	padding: 0.3em 0.5em;
	padding: 0.3em 0;
	width: fit-content;
	font-size: 0.8em;
	font-weight: 500;
	background: #fff;
	border-radius: 5px;
	line-height: 1.2em;
	line-height: 1.35em;
	color: var(--students);
}
.course_path_voice_pane_heading h4 {
	margin-left: 0.6rem;
	font-size: 1.25em;
	font-weight: 500;
	line-height: 1.1em;
	color: var(--students);
}
.page_v .course_path_voice_pane_heading h5,
.page_v .course_path_voice_pane_heading h4 {
	color: var(--v);
}
.page_p .course_path_voice_pane_heading h5,
.page_p .course_path_voice_pane_heading h4 {
	color: var(--p);
}
.page_pd .course_path_voice_pane_heading h5,
.page_pd .course_path_voice_pane_heading h4 {
	color: var(--pd);
}
.page_i .course_path_voice_pane_heading h5,
.page_i .course_path_voice_pane_heading h4 {
	color: var(--i);
}
.page_ad .course_path_voice_pane_heading h5,
.page_ad .course_path_voice_pane_heading h4 {
	color: var(--ad);
}
.page_f .course_path_voice_pane_heading h5,
.page_f .course_path_voice_pane_heading h4 {
	color: var(--f);
}
.course_path_voice_pane_heading h4 .name_kana {
	display: block;
	font-size: 0.6em;
	font-weight: 400;
}
.course_path_voice_pane_heading h4 .label {
	margin-left: 0.3em;
	font-size: 0.8em;
	font-weight: 400;
}
.course_path_voice_pane_content {
	float: right;
	width: 70%;
}
.course_path_voice_pane_works_image {
	float: right;
	position: relative;
	margin-left: 25px;
	margin-bottom: 10px;
	width: 25%;
}
.course_path_voice_pane_works_image p {
	border-radius: 5px;
	overflow: hidden;
}
.course_path_voice_pane_works_image_caption {
	margin-top: 1em;
	padding-left: 0.3em;
	font-size: 0.75em;
	line-height: 1.2em;
	font-size: 0.8em !important;
	letter-spacing: 0.03em;
	line-height: 1.5em !important;
	color: var(--f);
	border-radius: 0;
	overflow: visible;
}
.course_path_voice_pane_desc {
	margin-top: -0.5em;
	font-feature-settings: normal;
}
.course_path_voice_pane_desc h4 {
	margin-bottom: 0.75em;
	font-size: 1.2em;
	font-weight: 500;
}
.course_path_voice_pane_desc p {
	font-size: 1.05em;
	line-height: 1.9em;
}

#course_path_summary h4.title .label {
	margin-left: 0.25em;
	font-size: 0.85em;
}
#course_path_summary_panes {
	padding: 2.5em 0;
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
}
.course_path_summary_pane {
	float: left;
	padding: 0 3%;
	width: 25%;
	width: 20%;
	text-align: center;
}
.course_path_summary_pane:not(:last-of-type) {
	border-right: solid 1px #ddd;
}
.course_path_summary_pane h3 {
	display: inline-block;
	padding: 0.45em 0.6em;
	font-weight: 500;
	color: var(--students);
	font-size: 0.9em;
	line-height: 1em;
	border-radius: 4px;
	border: solid 2px var(--students);
	background: #fff;
}
.course_path_summary_pane h4 {
	margin-bottom: 0.5rem;
	font-weight: 500;
	font-size: 3.5em;
	line-height: 1em;
}
.course_path_summary_pane h4 .labeled {
	font-family: 'Fragment Mono', monospace;
    font-weight: 400;
    font-style: normal;
}
.course_path_summary_pane h4 .label {
	display: inline-block;
	margin-left: 0.3em;
	font-size: 1.3rem;
}

#course_path_studies dl,
#course_path_works > ul {
    margin-bottom: 5em;
    padding: 2.5em 2.5em 2em 2.5em;
    background: #fff;
    border-radius: 10px;
}
#course_path_studies dt {
    float: left;
    width: 12rem;
    font-size: 1.15em;
    font-weight: 500;
}
#course_path_studies dd {
    margin-bottom: 2em;
    padding-bottom: 2em;
    padding-top: 4px;
    padding-left: 12rem;
    border-bottom: 1px solid #ddd;
}
#course_path_studies dd:last-of-type {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}
#course_path_studies dd li {
    float: left;
    margin-bottom: 0.8em;
    font-size: 0.9em;
    line-height: 1.4em;
}
#course_path_studies dd li:not(:last-of-type) {
    margin-right: 1em;
    padding-right: 1em;
    border-right: 1px solid #ddd;
}
#course_path_studies dd li span {
    display: inline-block;
    vertical-align: middle;
    margin-left: 0.5em;
    padding: 0.2em 0.05em 0.12em 0;
    padding: 0.19em 0.5em 0.12em 0.5em;
    transform: translateY(-2px);
    /* width: 35px; */
    font-size: 1.05em;
    font-weight: 500;
    letter-spacing: 0;
    color: #fff;
    background: var(--students);
    text-align: center;
    border-radius: 5px;
}
#course_path_works > ul > li {
    float: left;
    margin-bottom: 0.8em;
    line-height: 1.4em;
}
#course_path_works > ul > li:not(:last-of-type) {
    margin-right: 1em;
    padding-right: 1em;
    border-right: 1px solid #ddd;
}
#course_path_works > ul > li h5 {
    float: left;
    font-weight: 500;
    font-size: 0.9em;
    letter-spacing: 0.08em;
}
#_course_path_works > ul > li h5::after {
    margin: 0 0.2em;
    content: '：';
}
#course_path_works > ul > li ul {
    float: left;
    margin-left: 0.2em;
    transform: translateY(-1px);
}
#course_path_works > ul > li ul li {
    float: left;
    margin-left: 0.2em;
    font-size: 0.9em;
	color: #bbb;
}
#course_path_works > ul > li ul li span {
    display: inline-block;
    vertical-align: middle;
    margin-left: 0.3em;
    padding: 0.3em 0.3em 0.22em 0.3em;
    min-width: 18px;
    transform: translateY(-2px);
    font-size: 0.9em;
    letter-spacing: 0;
    color: #fff;
    background: var(--students);
    text-align: center;
    border-radius: 4px;
    line-height: 1em;
}

@media screen and (max-width: 1040px) and (min-width: 750px) {
	
	.course_path_summary_pane {
		padding: 0 2%;
	}
	
}