@charset "utf-8";
body{
overflow:hidden;
margin:0px 0px 40px;
color:#303030;
font-size:80%;
line-height:1.8;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "游明朝", "ＭＳ Ｐ明朝", "MS 明朝", serif;
}
img{
font-size:0px;
vertical-align:bottom;
line-height:1.0;
}
.brsp{
display:block;
}
.txt{
margin:0px 10px 20px;
}

/*----------------------------------------------------
	#page（ページ全体）
----------------------------------------------------*/
/* ヘッダー
----------------------------------------------------*/
#header{
width:100%;
background:url(../images/premium/bg_header.jpg) 0 100% repeat-x;
}
#header .inner{
padding:16px 0px 17px;
}
.logoarea{
padding:0px 0px 0px 15px;
}
.logoarea img{
width:200px;
height:auto;
}
.utility{
position:fixed;
bottom:0px;
left:0px;
z-index:999;
width:50vw;
}
@media screen and (min-width:481px) and ( max-width:768px) { 
.utility{
width:100vw;
}
}

.tel{
position:fixed;
bottom:0px;
right:0px;
z-index:999;
width:50vw;
}
.tel a:before,
.gnav li a:before{
content:attr(data-label);
}
.tel img,
.gnav li img{
display:none;
}
.tel a:link,
.tel a:visited,
.tel a:hover,
.tel a:active,
.utility a:link,
.utility a:visited,
.utility a:hover,
.utility a:active{
display:block;
padding:10px 0px;
text-align:center;
color:#fff;
}
.tel a{
background:#6daad5;
}
.utility a{
background:#eb785d;
}

.i_navi{
position:relative;
position:absolute;
top:10px;
right:5px;
}
#panel-btn{
display: inline-block;
position: absolute;
top:10px;
right:40px;
width:30px;
height:30px;
}
#panel-btn:hover{
}
#panel-btn-icon{
display: block;
position: absolute;
top: 50%;
left: 50%;
width: 30px;
height: 2px;
margin: 0;
background: #d4b457;
transition: .2s;
}
#panel-btn-icon:before, #panel-btn-icon:after{
display: block;
content: "";
position: absolute;
top: 50%;
left: 0;
width: 30px;
height: 2px;
background: #d4b457;
transition: .3s;
}
#panel-btn-icon:before{
margin-top: -10px;
}
#panel-btn-icon:after{
margin-top: 10px;
}
#panel-btn .close{
background: transparent;
}
#panel-btn .close:before, #panel-btn .close:after{
margin-top: 0;
}
#panel-btn .close:before{
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
}
#panel-btn .close:after{
transform: rotate(-135deg);
-webkit-transform: rotate(-135deg);
}
.panel{
display:none;
}
.gnav{
margin:10px 0px 0px;
}
.gnav li{
float:left;
width:50%;
}
.gnav li a{
display:block;
padding:15px 10px;
background:#f8f3ec;
border-bottom:1px solid #d4b457;
text-align:center;
}
/*----------------------------------------------------
	#contents（メインとサイド）
----------------------------------------------------*/
/* MainImage */
.mainimage{
width:100%;
height:350px;
background:url(../images/premium/p_main.jpg) 50% 50px no-repeat;
background-size:800px auto;
}
.mainimage h2{
/*padding:20px 0px 8px 20px;*/
padding:10px 0px 8px 20px;
}
@media screen and (min-width:481px) and ( max-width:768px) { 
.mainimage h2{
text-align:center;
}
}

.mainimage h2 img{
width:300px;
height:auto;
}
.mainimage p{
/*text-align:center;*/
text-align:left;
padding-left:5px
}
.mainimage p img{
/*width:280px;*/
width:40%;
height:auto;
}
/*----------------------------------------------------
	#main（メインコンテンツ）
----------------------------------------------------*/
/* CatchArea */
.catcharea{
position:relative;
width:100%;
text-align:center;
}
.catcharea:before{
content: "";
position:absolute;
top:-45px;
left:0;
width: 0;
height: 0;
border-top: 35px solid transparent;
border-right: 50vw solid #f0d5b6;
border-bottom: 15px solid #f0d5b6;
border-left: 50vw solid #f0d5b6;
}
.catcharea:after{
content: "";
position:absolute;
bottom:-49px;
left:0;
width: 0;
height: 0;
border-top: 35px solid #f0d5b6;
border-right: 50vw solid transparent;
border-bottom: 15px solid transparent;
border-left: 50vw solid transparent;
z-index:1;
}
.catcharea .inner{
position:relative;
padding:0px 0px 200px;
background:#f0d5b6;
}
.catcharea h3{
margin:0px 10px;
}
.catcharea h3 img{
width:80%;
height:auto;
}
.catcharea h4{
margin:15px 10px;
padding:0px 0px 5px;
border-bottom:1px solid #303030;
font-size:130%;
}
.catcharea p{
font-weight:bold;
}
.note_left,
.note_right{
position:absolute;
left:50%;
bottom:30px;
}
.note_left img,
.note_right img{
width:200px;
height:auto;
}
.note_left{
margin:0px 0px 0px -180px;
bottom:10px;
z-index:10;
}
.note_right{
margin:0px 0px 0px -20px;
z-index:5;
}
/* プロローグ1 */
.prlgarea{
padding:70px 0px 0px;
}
.prlgarea h3{
position:relative;
margin:0px auto 20px;
padding:18px 0px 0px;
width:310px;
height:45px;
border:1px solid #000;
text-align:center;
font-size:120%;
}
.prlgarea h3:before{
content: "";
position:absolute;
bottom:-4px;
right:-4px;
width: 310px;
height: 63px;
border:1px solid #000;
}
.imgarea_first,
.imgarea_second{
overflow:hidden;
position:relative;
margin:0px 0px 20px;
width:100%;
/*height:200px;*/
}
.imgarea_first img{
position:absolute;
top:-50px;
right:-70px;
width:600px;
height:auto;
}
/*
@media screen and (min-width:481px) and ( max-width:768px) { 
.imgarea_first img{
top:-50px;
right:0px;
width:100%;
height:auto;
}
}
*/
.txtarea_first{
padding:0px 0px 10px;
}
.txtarea_first p{
margin:0px 10px 20px;
}
.imgarea_second{
/* margin:0px 0px 20px; */
text-align:center;
}
.imgarea_second img{
/*position:absolute;
top:-80px;
left:-80px;
width:600px;
height:auto;*/
position:relative;
width:80%;
height;auto;
}
/*
@media screen and (min-width:481px) and ( max-width:768px) { 
.imgarea_second img{
top:-130px;
left:0px;
width:100%;
height:auto;
}
}
*/
.txtarea_second{
padding:0px 0px 40px;
}
.txtarea_second p{
margin:0px 10px 20px;
}

.txtarea_second img {
    width: 80%;
}

.fmarea{
margin:0px 10px 15px;
padding:8px;
border:1px solid #bb823b;
border-radius:3px;
}
.fmarea h4{
position:relative;
margin:0px 0px 14px;
text-align:center;
font-size:110%;
color:#bb823b;
}
.fmarea h4:after{
content: "";
position:absolute;
bottom:-2px;
left:50%;
margin:0px 0px 0px -40px;
width: 80px;
height: 1px;
background:#bb823b;
}
.fmarea ul{
}
.fmarea ul li{
margin:0px 0px 0px 27px;
list-style:disc;
}

.prlgarea .invite_txt{
border-radius:3px;
font-size:200%;
color:#c69b1f;
}

.point_center{
text-align:center;
}

a.btn_apply,
a:link.btn_apply,
a:visited.btn_apply,
a:hover.btn_apply,
a:active.btn_apply{
display:inline-block;
padding:20px 40px 20px;
background:#c69b1f;
border-radius:3px;
font-size:110%;
color:#fff;
margin:0px 0px 20px 0px;
}

/* プロローグ2 */
.conceptarea{
clear:both;
margin:80px 0px 0px;
position:relative;
}
.conceptarea:before{
content: "";
position:absolute;
top:-80px;
left:0;
width: 0;
height: 0;
border-top: 40px solid #f8f3ec;
border-right: 50vw solid #fdfbf9;
border-bottom: 40px solid #fff;
border-left: 50vw solid #fdfbf9;
}
.conceptarea .inner{
padding:0px 0px 100px;
width:100%;
text-align:center;
}
.conceptarea h3{
position: relative;
margin:0px 10px;
width:95%;
}
.conceptarea h3 .brdr{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
background-color: #fff;
font-size:130%;
line-height:1.0;
}
.conceptarea h3::before{
position: absolute;
top: 50%;
z-index: 1;
content: '';
display: block;
width: 100%;
height: 1px;
background-color: #666;
}
.conceptarea h3 .subti{
font-size:80%;
line-height:1.0;
}
.conceptarea h4{
margin:20px 0px 10px;
font-size:140%;
}
.illarea{
position:relative;
margin:0px auto;
width:300px;
height:150px;
}
.illarea p{
position:absolute;
right:0px;
bottom:0px;
}
.illarea .ill{
position:absolute;
left:-30px;
bottom:20px;
}
.illarea p img{
width:100px;
height:auto;
}
.illarea .ill img{
width:250px;
height:auto;
}
.conceptlist{
margin:0px 10px;
padding:0px 0px 20px;
text-align:left;
}
.conceptlist dt{
padding:10px 15px;
background:#e2cbaf;
color:#57453f;
font-size:130%;
}
.conceptlist dd{
padding:10px;
background:#fff;
}
.conceptlist .imgarea{
margin:0px 0px 10px;
text-align:center;
}
.conceptlist .imgarea img{
width:150px;
height:auto;
}

/*Price*/
.pricebox{
margin:0px 10px;
padding:15px 0px 0px;
width:95%;
border:2px solid #bb823b;
}
.t_price{
position: relative;
margin:0px auto;
width:90%;
color:#57453f;
}
.t_price span{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
/*background-color: #fff;*/
font-size:180%;
line-height:1.0;
background-color: #f8f3ec;
}
.t_price::before{
position: absolute;
top: 50%;
z-index: 1;
content: '';
display: block;
width: 100%;
height: 1px;
background-color: #e2cbaf;
}
.inner_price{
padding:15px 15px 1px;
}
.price_left,
.price_right{
text-align:left;
}
.price_left{
padding:0px 3px 10px 3px;
border-bottom:1px dashed #808080;
}

.price_left li{
position:relative;
list-style: disc;
margin: 0px 5px 0px 30px;
}
	

/* .price_left li:before{
position:absolute;
top:50%;
left:0px;
content: '';
display: block;
margin:-6px 0px 0px;
width: 12px;
height: 12px;
background-color: #e2cbaf;
} */


.price_left p{
padding:0px 0px 0px 30px;
}
.price_right{
padding:10px 3px 0px 3px;
}
.price_right dt{
display:inline-block;
padding:3px 15px;
background:#d49a55;
border-radius:7px;
color:#fff;
letter-spacing:3px;
}
.price_right dd{
display:block;
margin:5px 3px 14px;
}
.areabox{
margin:0px 10px;
width:95%;
border:2px solid #bb823b;
border-top:none;
text-align:left;
}
.areabox p{
position:relative;
padding:15px 15px 15px 45px;
}
.areabox p:before{
position:absolute;
top:50%;
left:15px;
content: '';
display: block;
margin:-6px 0px 0px;
width: 12px;
height: 12px;
background-color: #e2cbaf;
}





/* Service */
.servicearea{
clear:both;
position:relative;
}
.servicearea:before{
content: "";
position:absolute;
top:-80px;
left:0;
width: 0;
height: 0;
border-top: 40px solid transparent;
border-right: 50vw solid #fdfbf9;
border-bottom: 40px solid #f8f3ec;
border-left: 50vw solid #fdfbf9;
}
.servicearea .inner{
padding:0px 0px 20px;
width:100%;
background:#f8f3ec;
text-align:center;
}
.servicearea h3{
position: relative;
margin:0px 10px;
width:95%;
}
.servicearea h3 .brdr{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
background-color: #f8f3ec;
font-size:130%;
line-height:1.0;
}
.servicearea h3::before{
position: absolute;
top: 50%;
z-index: 1;
content: '';
display: block;
width: 100%;
height: 1px;
background-color: #666;
}
.servicearea h3 .subti{
font-size:80%;
line-height:1.0;
}
.servicearea h4{
margin:30px 0px 10px;
font-size:140%;
}
.p_service{
margin:0px 0px 25px;
}
.p_service img{
width:100%;
height:auto;
}
.servicelist{
margin:0px 10px 18px;
padding:10px 0px;
border:1px solid #000;
text-align:left;
}
.servicelist dt{
position:relative;
margin:0px 0px 14px;
text-align:center;
font-size:110%;
}
.servicelist dt:after{
content: "";
position:absolute;
bottom:-5px;
left:50%;
margin:0px 0px 0px -40px;
width: 80px;
height: 1px;
background:#000;
}

.servicelist .t_service1{
color:#00491f;
}
.servicelist .t_service2{
color:#c14612;
}
.servicelist .t_service3{
color:#226f91;
}
.servicelist dd{
padding:10px 20px;
width:auto;
}

/* Results */
.resultarea{
clear:both;
position:relative;
}
.resultarea:before{
content: "";
position:absolute;
top:-80px;
left:0;
width: 0;
height: 0;
border-top: 40px solid #fff;
border-right: 50vw solid #fdfbf9;
border-bottom: 40px solid #f8f3ec;
border-left: 50vw solid #fdfbf9;
}
.resultarea .inner{
width:100%;
background:#f8f3ec;
text-align:center;
}
.resultarea h3{
position: relative;
margin:0px 10px;
width:95%;
}
.resultarea h3 .brdr{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
background-color: #f8f3ec;
font-size:130%;
line-height:1.0;
}
.resultarea h3::before{
position: absolute;
top: 50%;
z-index: 1;
content: '';
display: block;
width: 100%;
height: 1px;
background-color: #666;
}
.resultarea h3 .subti{
font-size:80%;
line-height:1.0;
}
.resultarea h4{
margin:30px 0px 10px;
font-size:140%;
}
.result_first h5{
margin:0px 10px 25px;
padding:6px 0px 5px;
background:#fff;
border:1px solid #bb823b;
border-radius:3px;
color:#bb823b;
font-size:110%;
}
.result_first p{
margin:0px 10px 35px;
text-align:left;
}
.result_second h5{
overflow:hidden;
position:relative;
width:100%;
height:150px;
}
.result_second h5 img{
position:absolute;
top:0px;
left:-150px;
width:700px;
height:auto;
}
@media screen and (min-width:481px) and ( max-width:768px) { 
.result_second h5 img{
top:0px;
left:0px;
width:100%;
height:auto;
}
}

/* Voice */
.voicelist{
margin:0px 10px;
padding:0px 0px 120px;
}
.voicelist li{
padding:25px 0px;
border-bottom:1px solid #bd813b;
}
.profarea{
}
.profarea .name{
margin:0px auto;
width:150px;
}
.profarea .name img{
width:150px;
height:auto;
}
.profarea .prof{
margin:10px 0px;
padding:8px 10px;
background:#efe2d2;
border-radius:3px;
text-align:left;
}
.itvarea{
text-align:left;
}
.t_int{
margin;0px 0px 10px;
font-size:110%;
}
.itvarea dd{
padding:0px 0px 20px;
}
.itvarea dd.lastchild{
padding:0px;
}

/* Access */

.access_first iframe {
    width: 90%;
    height:auto;
}

.access_second img {
    width: 90%;
    height: auto;
}

.access_second_u2{
    margin-bottom:100px;
}

/* Contact */
.contactarea{
clear:both;
position:relative;
}
.contactarea:before{
content: "";
position:absolute;
top:-80px;
left:0;
width: 0;
height: 0;
border-top: 40px solid #f8f3ec;
border-right: 50vw solid #fdfbf9;
border-bottom: 40px solid #fff;
border-left: 50vw solid #fdfbf9;
}
.contactarea .inner{
width:100%;
text-align:center;
}
.contactarea h3{
position:relative;
margin:0px auto 20px;
padding:18px 0px 0px;
width:310px;
height:45px;
border:1px solid #000;
text-align:center;
font-size:120%;
}
.contactarea h3:before{
content: "";
position:absolute;
bottom:-4px;
right:-4px;
width: 310px;
height: 63px;
border:1px solid #000;
}

/* フォーム */
.formbasic{
margin:0px 10px 24px;
}
@media screen and (min-width:481px) and ( max-width:768px) { 
.formbasic{
margin:0px auto 24px;
width:600px;
}
}
.formbasic th{
padding:10px;
width:120px;
vertical-align:top;
text-align:right;
border-bottom:1px solid #bd813b;
}
.formbasic th span{
color:#f00;
font-weight:normal;
}
.formbasic td{
padding:10px;
width:auto;
text-align:left;
border-bottom:1px solid #bd813b;
}
.formbasic td p{
margin:0px 0px 10px;
}
.formbasic .sizes{
width:180px;
}
.formbasic .sizem{
width:180px;
}
.formbasic .txtm{
width:180px;
height:200px;
}
.wpcf7c-elm-step2 .conm{
margin:0px 10px 14px;
padding:10px;
background:#ceeffd;
border:1px solid #4890d3;
font-size:110%;
}
input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px white inset;
}
#contents .wpcf7c-conf{
background-color:#fff;
}
.b_submit input{
cursor:pointer;
display:block;
border-radius: 5px;
width:250px;
margin:15px auto 0px;
padding:10px 0px;
text-align:center;
text-decoration:none;
color:#320808;
font-size:110%;
font-weight:bold;
background:#efe2d2;
border:1px dashed #bd813b;
}

.b_submit input.wpcf7-submit{
display:inline-block;
margin:15px 0px 0px 10px;
width:125px;
background:#efe2d2;
border:1px dashed #bd813b;
}
.b_submit input.wpcf7-back{
display:inline-block;
width:125px;
border:1px dashed #000;
color:#000;
background:#e2e2e4;
}
.b_submit input:hover,
.b_submit input.wpcf7-submit:hover{
color:#fff;
background:#bd813b;
}
.b_submit input.wpcf7-back:hover{
color:#fff;
background:#000;
}

/* Thanks */
.fdarea{
margin:0px 10px;
padding:60px 0px 180px;
}
.fdarea p{
margin:0px 0px 20px;
}
/*----------------------------------------------------
	#footer（フッター）
----------------------------------------------------*/
footer{
clear:both;
margin:40px 0px 0px;
width:100%;
background:#e2cbaf;
}
footer .inner{
margin:0px 10px;
padding:17px 0px 12px;
}
.footnav ul{
}
.footnav li{
float:left;
padding:0px 5px;
}
.footnav li a{
color:#57453f;
}
.copy{
padding:14px 0px 0px;
font-size:80%;
}
.page-top p{
position: fixed ;
right: 16px ;
bottom: 86px ;
z-index:999;
}
.move-page-top{
display: block ;
background: #57453f ;
border-radius:3px;
width: 25px ;
height: 25px ;
color: #fff ;
line-height: 25px ;
text-decoration: none ;
text-align: center ;
-webkit-transition:all 0.3s ;
-moz-transition:all 0.3s ;
transition:all 0.3s ;
}
.move-page-top:link,
.move-page-top:visited,
.move-page-top:hover,
.move-page-top:active{
color:#fff;
text-decoration:none;
}
.move-page-top:hover{
opacity: 0.85 ;
}
.scriptarea{
height: 0;
line-height: 0;
margin:0;
padding: 0;"
}

/* ===================================================================
 style info : コンテンツエリア関係 他

fonts
 10px = 77%     11px = 85%     12px = 93%     13px = 100%
 14px = 108%    15px = 116%    16px = 123.1%  17px = 131%
 18px = 138.5%  19px = 146.5%  20px = 153.9%? 21px = 161.6%
 22px = 167%    23px = 174%    24px = 182%    25px = 189%
 26px = 197%
=================================================================== */

/*----------------------------------------------------
	共通
----------------------------------------------------*/
/* スクロールバーの有無によるズレ対策 */
html {
overflow-y: scroll;
}

body {
}

input, textarea {
}

li{
list-style:none;
}
/* for IE6 */
* html body {
}
* html input, * html textarea {
}

/* リンク
----------------------------------------------------*/
a {
color:#4890d3;
}

a:link {
color:#4890d3;
}

a:visited {
color:#4890d3;
}

a:hover {
color:#4890d3;
text-decoration:none;
}

a:active {
color:#4890d3;
}

/* よく使いそうなCSS3
----------------------------------------------------*/
#selectors {
/* 角丸 */
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;

/* 角丸個別 */
	-webkit-border-top-right-radius: 15px;
	-moz-border-radius-topright: 15px;
	border-top-right-radius: 15px;

/* ボックスに影 */
	-webkit-box-shadow: 1px 1px 3px #999;
	-moz-box-shadow: 1px 1px 3px #999;
	box-shadow: 1px 1px 3px #999;

/* テキストに影 */
	text-shadow: 1px 1px 0px #999;
}

/* 汎用
----------------------------------------------------*/
/* clerfix */
.clearfix:after,
#contents:after {
	content: "."; display: block; visibility: hidden; height: 0.1px; font-size: 0.1em; line-height: 0; clear: both;
}

.imgR {
	float: right;
	margin: 0 0 10px 10px;
}

.imgL {
	float: left;
	margin: 0 10px 10px 0;
}

.tC,
.btn {
	text-align: center;
}

.tR,
.sign {
	text-align: right;
}

/* ============================================================
   Special Seminar Section — Mobile / Tablet (max-width: 769px)
   ※ このファイルは style-premium.css とは排他読込のため、
     基本スタイルもすべて自己完結で記述すること。
   ============================================================ */

.seminararea {
    clear: both;
    padding: 10px 0 15px;
    background: #f8f3ec;
    position: relative;
}

.seminararea::before {
    content: "";
    position: absolute;
    top: -35px;
    left: 0;
    width: 0;
    height: 0;
    border-top: 25px solid transparent;
    border-right: 50vw solid #f8f3ec;
    border-bottom: 15px solid #f8f3ec;
    border-left: 50vw solid #f8f3ec;
}


.seminar-inner {
    margin: 0 auto;
    padding: 0 10px;
}

/* 縦並びレイアウト */
.seminar-columns {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.seminar-info,
.seminar-schedule {
    min-width: 0;
}

/* ---------- キャッチフレーズ（☀をテキスト直左右に） ---------- */
.seminar-catch {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4em;
    text-align: center;
    font-size: 105%;
    color: #57453f;
    padding: 5px 0;
    margin-bottom: 5px;
}

.seminar-catch::before,
.seminar-catch::after {
    content: '☀';
    color: #c69b1f;
    font-size: 1.5em;
    line-height: 1;
}

/* ---------- タイトル ---------- */
.seminar-title {
    text-align: center;
    font-size: 120%;
    color: #57453f;
    margin: 5px 0 18px;
    line-height: 1.5;
}

/* ---------- タイトル直下の画像 ---------- */
.seminar-title-img {
    text-align: center;
    margin: 0 0 16px;
}
.seminar-title-img img {
    width: 100%;
    max-width: 60%;
    height: auto;
}

/* ---------- 本文 ---------- */
.seminar-body {
    font-size: 100%;
    line-height: 1.8;
    margin-bottom: 10px;
    color: #303030;
}

/* ---------- 「講座の概要」リボン見出し ---------- */
.seminar-overview-title {
    position: relative;
    display: block;
    background: #c69b1f;
    color: #fff;
    text-align: center;
    font-size: 115%;
    height: 38px;
    line-height: 38px;
    padding: 0 30px;
    margin: 20px 18px 15px;
    box-sizing: border-box;
}

.seminar-overview-title::before {
    content: '';
    position: absolute;
    left: -19px;
    top: 0;
    width: 0;
    height: 0;
    border-top: 19px solid transparent;
    border-bottom: 19px solid transparent;
    border-right: 19px solid #c69b1f;
}

.seminar-overview-title::after {
    content: '';
    position: absolute;
    right: -18px;
    top: 0;
    width: 0;
    height: 0;
    border-top: 19px solid transparent;
    border-bottom: 19px solid transparent;
    border-left: 19px solid #c69b1f;
}

/* ---------- 概要：1枚の大きなカード（各項目は行） ---------- */
.seminar-cards {
    margin: 0;
    padding: 0;
    border: 1px solid #bb823b;
    border-radius: 3px;
    background: #fff;
    overflow: hidden;
}

.seminar-card {
    display: flex;
    margin: 0;
    background: transparent;
    border-bottom: 1px solid #c5a06b; /* 行区切り（#e2cbaf より少し濃いめ） */
}

.seminar-card:last-child {
    border-bottom: none;
}

.seminar-card dt {
    flex-shrink: 0;
    width: 80px;
    padding: 8px;
    background: #e2cbaf;
    color: #57453f;
    font-size: 90%;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.seminar-card dd {
    padding: 8px 10px;
    line-height: 1.7;
    color: #303030;
    font-size: 90%;
}

/* ---------- 科目テキスト＋ボーダー ---------- */
.seminar-subjects {
    display: block;
    width: fit-content;
    margin: 15px 0 0 1.5em;
    font-size: 110%;
    font-weight: bold;
    color: #303030;
    border-bottom: 3px solid #5b9bd5;
    padding-bottom: 3px;
}

/* カードラッパー（画像の絶対配置基準） */
.seminar-cards-wrapper {
    position: relative;
    margin-top: 10px;
}

/* 右上に絶対配置、clamp() で画面幅に比例して徐々に縮小 */
.seminar-subjects-img {
    position: absolute;
    top: 0;
    right: 0;
    width: clamp(35px, 9vw, 80px);
    height: auto;
    z-index: 1;
    pointer-events: none;
}

/* ---------- スケジュール ---------- */
.schedule-subtitle {
    font-size: 120%;
    color: #57453f;
    border-bottom: 2px solid #bb823b;
    padding-bottom: 5px;
    margin: 20px 0 10px;
}

.schedule-subtitle:first-child {
    margin-top: 0;
}

.schedule-table-wrap {
    margin-bottom: 5px;
}

.schedule-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 78%;
    line-height: 1.5;
}

.schedule-table th,
.schedule-table td {
    padding: 4px 5px;
    border: 1px solid #bb823b;
    vertical-align: middle;
    text-align: center;
    white-space: nowrap; /* 短い列はそのまま */
}

/* 単元・内容は左寄せ＆折り返し（rowspan の列ずれ対策でクラス指定） */
.schedule-table .unit-cell {
    text-align: left;
    white-space: normal;
}

/* ヘッダはベージュ維持 */
.schedule-table th {
    background: #e2cbaf;
    color: #57453f;
    font-weight: bold;
}

/* データセルは全て白（科目セルを除く）。日付 rowspan セルも白・太字維持 */
.schedule-table tbody td:not(.subject-cell) {
    background: #fff;
}

.schedule-table td[rowspan] {
    font-weight: bold;
    vertical-align: middle;
}

/* 科目セルのみ色付き＋白文字 */
.subject-cell {
    font-weight: bold;
    min-width: 24px;
    color: #fff;
}

.subject-sci  { background: #a7ec89; } /* 淡めの緑 */
.subject-math { background: #8bbce9; } /* 淡めの青 */

/* ---------- CTA：ボタン→地図→住所を中央寄せで縦積み ---------- */
.seminararea .point_center {
    text-align: center;
    margin: 25px 0 0;
}

.seminararea .point_center .btn_apply {
    display: block;
    width: fit-content;
    margin: 0 auto 18px;
}

.seminararea .point_center img {
    display: block;
    margin: 20px auto 0;
    max-width: 100%;
}

.seminararea .point_center p {
    display: block;
    margin-top: 8px;
    color: #303030;
}

/* タブレット (481px–768px) では文字を少し大きく */
@media screen and (min-width: 481px) and (max-width: 768px) {
    .schedule-table {
        font-size: 85%;
    }
}
