@charset "utf-8";
/* サイト全体
----------------------------------------------------*/
body{
margin:119px 0px 0px;
overflow:hidden;
color:#303030;
font-size:80%;
line-height:1.6;
-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;
}
.clear-type{
-webkit-transform-origin: 0 0;
-webkit-transform: scale(1, 1.01);
-moz-transform-origin: 0 0;
-moz-transform: scale(1, 1.01);
-ms-transform-origin: 0 0;
-ms-transform: scale(1, 1.02);
-o-transform-origin: 0 0;
-o-transform: scale(1, 1.01);
}
/* ヘッダー
----------------------------------------------------*/
#header{
overflow:hidden;
position: fixed;
top: 0;
z-index: 999;
padding:16px 0px 32px;
width:100%;
height:71px;
background:#fff;
box-shadow: 0 0 20px 0 rgba(0,0,0,0.1);
}
#header .inner{
margin:0px auto;
padding:0px 18px 0px 30px;
width:952px;
}
.logoarea{
float:left;
/*padding:7px 0px 0px;*/
width:352px;
}
.navarea{
float:right;
width:600px;
}
.utility{
float:left;
width:385px;
text-align:right;
}
.utility a,
.utility a:link,
.utility a:visited,
.utility a:hover,
.utility a:active{
display:inline-block;
padding:6px 10px 5px;
background:#c69b1f;
border-radius:3px;
font-size:110%;
color:#fff;
}
.tel{
float:left;
padding:0px 3px 0px 0px;
width:212px;
text-align:right;
}
.gnav{
clear:left;
float:right;
padding:21px 0px 0px;
}
.gnav li{
float:left;
}
.gnav li img:hover{
opacity:0.7;
}
.i_navi{
display:none;
}
/* メイン
----------------------------------------------------*/
#contents{
padding:5px 0px 0px;
background:url(../images/premium/p_main.jpg) 50% 0 no-repeat;
}

/* MainImage */
.mainimage{
position:relative;
margin:0px auto;
width:1000px;
height:652px;
}
.mainimage h2,
.mainimage p{
position:absolute;
}
.mainimage h2{
/* top:37px; */
top:200px;
left:40px;
}
.mainimage p.im1{
top:270px;
left:40px;
/* right:30px; */
}
.mainimage p.im2{
top:270px;
left:280px;
/* right:30px; */
}


/* CatchArea */
.catcharea{
position:relative;
width:100%;
text-align:center;
}
.catcharea:before{
content: "";
position:absolute;
top:-100px;
left:0;
width: 0;
height: 0;
border-top: 70px solid transparent;
border-right: 50vw solid #f0d5b6;
border-bottom: 30px solid #f0d5b6;
border-left: 50vw solid #f0d5b6;
}
.catcharea:after{
content: "";
position:absolute;
bottom:-100px;
left:0;
width: 0;
height: 0;
border-top: 70px solid #f0d5b6;
border-right: 50vw solid transparent;
border-bottom: 30px solid transparent;
border-left: 50vw solid transparent;
z-index:1;
}
.catcharea .inner{
position:relative;
background:#f0d5b6;
}
.catcharea h4{
margin:15px auto 18px;
padding:0px 0px 5px;
width:683px;
border-bottom:1px solid #303030;
font-size:250%;
}
.catcharea p{
font-size:120%;
font-weight:bold;
}
.note_left,
.note_right{
position:absolute;
z-index:100;
}
.note_left{
top:-80px;
left:0px;
margin:0px 0px 0px -100px;
}
.note_right{
top:-75px;
right:0px;
margin:0px -130px 0px 0px;
}

@media screen and (min-width:1480px) and ( max-width:1600px) { 
.note_left img,
.note_right img{
width:500px;
height:auto;
}
}
@media screen and (min-width:1280px) and ( max-width:1479px) { 
.note_left img,
.note_right img{
width:450px;
height:auto;
}
}
@media screen and (min-width:1120px) and ( max-width:1279px) { 
.note_left img,
.note_right img{
width:350px;
height:auto;
}
}
@media screen and (min-width:769px) and ( max-width:1119px) { 
.note_left img,
.note_right img{
width:250px;
height:auto;
}
}

/* プロローグ1 */
.prlgarea{
margin:0px auto;
padding:140px 0px 0px;
width:1150px;
}
.prlgarea h3{
position:relative;
margin:0px auto 48px;
padding:23px 0px 0px;
width:600px;
height:65px;
border:1px solid #000;
text-align:center;
font-size:220%;
}
.prlgarea h3:before{
content: "";
position:absolute;
bottom:-4px;
right:-4px;
width: 600px;
height: 88px;
border:1px solid #000;
}
.imgarea_first,
.imgarea_second{
overflow:hidden;
position:relative;
float:right;
margin:0px 0px 95px;
width:470px;
height:480px;
}
.imgarea_first img{
position:absolute;
top:-20px;
right:-100px;
width:877px;
height:auto;
}
.txtarea_first{
float:left;
padding:18px 0px 95px 31px;
width:595px;
}
.txtarea_first p{
margin:0px 0px 20px;
line-height:2.0;
}
.imgarea_second{
clear:both;
float:left;
margin:0px 0px 450px;
padding-bottom:0;
height:auto;
overflow:visible;
}
.imgarea_second img{
position:relative;
top:0;
width:100%;
height:auto;
}
.txtarea_second{
float:left;
/*padding:0px 0px 0px 72px;
width:585px;*/
padding: 0px 0px 150px 20px;
width: 440px;
}
.txtarea_second p{
margin:0px 0px 20px;
line-height:1.5;
}

.txtarea_second img {
    width: 80%;
}

.fmarea{
display:table;
margin:0px 0px 15px;
padding:6px 0px;
width:98%;
border:1px solid #bb823b;
border-radius:3px;
}
.fmarea h4{
display:table-cell;
width:163px;
border-right:1px solid #bb823b;
text-align:center;
vertical-align:middle;
color:#bb823b;
}
.fmarea ul{
display:table-cell;
width:auto;
vertical-align:middle;
}
.fmarea ul li{
margin:0px 0px 0px 37px;
line-height:2.0;
}

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

.point_center{
text-align:center;
margin:0px 0px 0px 37px;
}

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;
}

@media screen and (min-width: 768px){
	.br-sp {display: none; }
	}

/* プロローグ2 */
.conceptarea{
clear:both;
position:relative;
}
.conceptarea:before{
content: "";
position:absolute;
top:-160px;
left:0;
width: 0;
height: 0;
border-top: 80px solid #f8f3ec;
border-right: 50vw solid #fdfbf9;
border-bottom: 80px solid #fff;
border-left: 50vw solid #fdfbf9;
}
.conceptarea .inner{
width:100%;
text-align:center;
}
.conceptarea h3{
position: relative;
margin:0px auto;
width:470px;
}
.conceptarea h3 .brdr{
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;
}
.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:30px 0px 10px;
font-size:220%;
}
.conceptarea p{
line-height:2.0;
}
.illarea{
margin:0px auto;
width:700px;
}
.illarea p{
float:right;
}
.illarea .ill{
float:left;
padding:50px 0px 0px;
}
.conceptlist{
margin:0px auto;
padding:0px 0px 0px;
width:940px;
text-align:left;
}
.conceptlist dt{
padding:10px 28px;
background:#e2cbaf;
color:#57453f;

font-size:220%;
}
.conceptlist dd{
padding:30px 0px;
background:#fff;
}
.conceptlist .imgarea{
float:left;
width:250px;
text-align:right;
}
.conceptlist .txtarea{
float:right;
padding:10px 18px 0px 0px;
width:650px;
line-height:2.0;
}


/*Price*/
.pricebox{
margin:20px auto 0px;
padding:25px;
width:886px;
border:2px solid #bb823b;
}
.t_price{
position: relative;
margin:0px auto;
width:470px;
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{
display:table;
margin:25px 0px 0px;
}
.price_left,
.price_right{
display:table-cell;
text-align:left;
font-size:125%;
}
.price_left{
padding:3px 10px 3px 0px;
width:309px;
border-right: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:3px 10px 3px 30px;
width:526px;
}
.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;
}
.price_right dd.lastchild{
margin:5px 3px 0px;
}
.price_right dd span{
font-size:80%;
}
.areabox{
margin:0px auto;
padding:25px;
width:886px;
border:2px solid #bb823b;
border-top:none;
text-align:left;
}
.areabox p{
position:relative;
padding:0px 0px 0px 30px;
font-size:140%;
}
.areabox p:before{
position:absolute;
top:50%;
left:0px;
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:-160px;
left:0;
width: 0;
height: 0;
border-top: 80px solid transparent;
border-right: 50vw solid #fdfbf9;
border-bottom: 80px solid #f8f3ec;
border-left: 50vw solid #fdfbf9;
}
.servicearea .inner{
width:100%;
background:#f8f3ec;
text-align:center;
padding:0px 0px 180px;
}
.servicearea h3{
position: relative;
margin:0px auto;
width:470px;
}
.servicearea h3 .brdr{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
background-color: #f8f3ec;
font-size:180%;
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:220%;
}
.p_service{
margin:45px 0px 65px;
}
.p_service img{
width:100%;
height:auto;
}
.servicelist{
display:table;
margin:0px auto 18px;
padding:10px 0px;
width:938px;
border:1px solid #000;
text-align:left;
}
.servicelist dt{
display:table-cell;
padding:0px 0px 0px 40px;
width:335px;
border-right:1px solid #000;
vertical-align:middle;
font-size:180%;
}
.servicelist .t_service1{
color:#00491f;
}
.servicelist .t_service2{
color:#c14612;
}
.servicelist .t_service3{
color:#226f91;
}
.servicelist dd{
display:table-cell;
padding:10px 20px;
width:auto;
vertical-align:middle;
line-height:2.0;
}

/* Results */
.resultarea{
clear:both;
position:relative;
margin:220px 0px 0px;
}
.resultarea:before{
content: "";
position:absolute;
top:-160px;
left:0;
width: 0;
height: 0;
border-top: 80px solid #fff;
border-right: 50vw solid #fdfbf9;
border-bottom: 80px solid #f8f3ec;
border-left: 50vw solid #fdfbf9;
}
.resultarea .inner{
width:100%;
background:#f8f3ec;
text-align:center;
}
.resultarea h3{
position: relative;
margin:0px auto;
width:470px;
}
.resultarea h3 .brdr{
position: relative;
z-index: 2;
display: inline-block;
margin: 0 2.5em;
padding: 0 1em;
background-color: #f8f3ec;
font-size:180%;
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:220%;
}
.result_first h5{
margin:0px auto 25px;
padding:6px 0px 5px;
width:540px;
background:#fff;
border:1px solid #bb823b;
border-radius:3px;
color:#bb823b;
font-size:160%;
}
.result_first p{
margin:0px auto 35px;
width:682px;
line-height:2.0;
text-align:left;
}
.result_second h5 img{
width:100%;
height:auto;
}
/* Voice */
.voicelist{
margin:0px auto;
padding:0px 0px 225px;
width:940px;
line-height:2.0;
}
.voicelist li{
padding:50px 0px;
border-bottom:1px solid #bd813b;
}
.profarea{
float:left;
width:325px;
}
.profarea .prof{
margin:10px 0px 0px;
padding:8px 25px;
background:#efe2d2;
border-radius:3px;
text-align:left;
}
.itvarea{
float:right;
width:595px;
text-align:left;
}
.t_int{
margin;0px 0px 10px;
font-size:160%;
}
.itvarea dd{
padding:0px 0px 20px;
}
.itvarea dd.lastchild{
padding:0px;
}

/* Access */

.accessarea{
margin:0px auto;
padding:0px 0px 225px;
width:940px;
line-height:2.0;
}

.accessarea .access_first{
width:50%;
float:left;
}

.access_first iframe {
    width: 100%;
}

.accessarea .access_second{
width:50%;
float:left;
}

.accessarea .access_second img{
width:100%;
}

/* Contact */
.contactarea{
clear:both;
position:relative;
}
.contactarea:before{
content: "";
position:absolute;
top:-160px;
left:0;
width: 0;
height: 0;
border-top: 80px solid #f8f3ec;
border-right: 50vw solid #fdfbf9;
border-bottom: 80px solid #fff;
border-left: 50vw solid #fdfbf9;
}
.contactarea .inner{
width:100%;
text-align:center;
}
.contactarea h3{
position:relative;
margin:0px auto 48px;
padding:23px 0px 0px;
width:600px;
height:65px;
border:1px solid #000;
text-align:center;
font-size:220%;
}
.contactarea h3:before{
content: "";
position:absolute;
bottom:-4px;
right:-4px;
width: 600px;
height: 88px;
border:1px solid #000;
}

/* フォーム */
.formbasic{
margin:0px auto 24px;
width:940px;
}
.formbasic th{
padding:15px 15px 22px 30px;
width:200px;
vertical-align:top;
text-align:right;
border-bottom:1px solid #bd813b;
}
.formbasic th span{
color:#f00;
font-weight:normal;
}
.formbasic td{
padding:15px 15px 22px 15px;
width:auto;
text-align:left;
border-bottom:1px solid #bd813b;
}
.formbasic td p{
margin:0px 0px 10px;
}
.formbasic .sizes{
width:300px;
}
.formbasic .sizem{
width:400px;
}
.formbasic .txtm{
width:500px;
height:200px;
}
.wpcf7c-elm-step2 .conm{
margin:0px auto 14px;
padding:15px 0px;
width:938px;
background:#ceeffd;
border:1px solid #4890d3;
font-size:130%;
}
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 auto;
padding:60px 50% 180px 5%;
/*width:940px;*/
color:white;
}
.fdarea p{
margin:0px 0px 20px;
}

/* フッター
----------------------------------------------------*/
footer{
clear:both;
margin:70px 0px 0px;
width:100%;
background:#e2cbaf;
}
footer .inner{
margin:0px auto;
padding:17px 0px 12px;
width:940px;
}
.footnav ul{
padding:0px 0px 0px 14px;
background:url(../images/premium/line_footer.gif) 0 50% no-repeat;
}
.footnav li{
float:left;
padding:5px 34px 5px 20px;
background:url(../images/premium/line_footer.gif) 100% 50% no-repeat;
}
.footnav li a{
color:#57453f;
}
.copy{
padding:14px 0px 0px;
font-size:80%;
}
.page-top p{
position: fixed ;
right: 16px ;
bottom: 16px ;
}
.move-page-top{
display: block ;
background: #57453f ;
border-radius:3px;
width: 50px ;
height: 50px ;
color: #fff ;
line-height: 50px ;
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;
}
input, textarea {
}
/* for IE6 */
* html body {
}
* html input, * html textarea {
}
ul,li{
list-style:none;
}
h1{
	font-weight:normal;
	}

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

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

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

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

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

/* よく使いそうな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,
#contents_shiten: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;
}
.clr{
clear:both;
}
h1,h2,h3,h4,h5,h6{
font-weight:normal;
}

/* ============================================================
   Special Seminar Section (#seminar-notice.seminararea) — PC
   ============================================================ */

/* prlgarea 末尾フロートの過大な下余白を詰めて seminararea を近づける */
.prlgarea .imgarea_second { margin-left: 120px; margin-bottom: 40px; padding-bottom: 0; }

.seminararea {
    clear: both; /* 直前の .prlgarea のフロート(.txtarea_second 等)を解除 */
    padding: 70px 0 200px; /* 上70px: 前セクションとの余白。下200px: conceptarea::before(top:-160px)回避のため160px以上確保 */
    background: #f8f3ec;
    position: relative;
}

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


.seminar-inner {
    margin: 0 auto;
    padding: 0 20px;
    max-width: 1100px;
}

/* 2カラムレイアウト */
.seminar-columns {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}

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

/* ---------- キャッチフレーズ（☀をテキスト直左右に） ---------- */
.seminar-catch {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4em;
    text-align: center;
    font-size: 115%;
    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: 145%;
    color: #57453f;
    margin: 5px 0 20px;
    line-height: 1.5;
}

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

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

/* ---------- 「講座の概要」リボン見出し ---------- */
/*
   border-trick でリボン型の矢印バナーを作る。
   高さを height + line-height で 44px 固定にし、
   ::before / ::after の border-top/bottom をその半分 (22px) にそろえる。
*/
.seminar-overview-title {
    position: relative;
    display: block;
    background: #c69b1f;
    color: #fff;
    text-align: center;
    font-size: 130%;
    height: 44px;
    line-height: 44px;
    padding: 0 30px;
    margin: 25px 22px 18px;
    box-sizing: border-box;
}

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

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

/* ---------- 概要：1枚の大きなカード（dl 全体が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: 110px;
    padding: 10px 12px;
    background: #e2cbaf;
    color: #57453f;
    font-size: 100%;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

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

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

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

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

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

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

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

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

.schedule-table th,
.schedule-table td {
    padding: 6px 8px;
    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: 28px;
    color: #fff;
}

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

/* ---------- CTA：ボタン→地図→住所を中央寄せで縦積み ---------- */
.seminararea .point_center {
    text-align: center;
    margin: 30px 0 0; /* 既存 .point_center の margin-left:37px を打ち消す */
}

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

.seminararea .point_center img {
    display: block;
    margin: 40px auto 0;
    max-width: 100%; /* 大きな画像が overflow:hidden に引っかかるのを防ぐ */
}

.seminararea .point_center p {
    display: block; /* 明示的に表示 */
    margin-top: 8px;
    color: #303030;
}
