/* A Modern CSS Reset */
*,*::before,*::after{box-sizing:border-box}ul[class],ol[class]{padding:0}body,h1,h2,h3,h4,h5,h6,p,ul[class],ol[class],figure,blockquote,dl,dd{margin:0}body{min-height:100vh; min-height:100lvh; scroll-behavior:smooth;/*text-rendering:optimizeSpeed;*/line-height:2}ul[class],ol[class]{list-style:none}a:not([class]){/*text-decoration-skip-ink:auto*/}img{max-width:100%;display:block}article>*+*{margin-top:1rem}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}




html { scroll-behavior:auto; overflow-x:clip; }
body { font-family: "Zen Kaku Gothic New", sans-serif; color:#333; /*font-weight:300;*/ position:relative; font-size:clamp(0.9rem, 1.6vw, 1rem); line-height:2; letter-spacing:0.04rem; margin:0; padding:0; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; font-feature-settings:"palt"; box-sizing:border-box; overflow-x:clip; }

title span { display: none; }
a { color:#333; transition:0.15s; outline-style:none; cursor: pointer; }
a:hover { color:#333; } 


.tc { text-align: center; }
.tr { text-align: right; }
.tl { text-align: left; }
.vt { vertical-align: top; }
.img_pc { display:block; }
.img_sp { display:none; }
.clearfix { display: block; clear: both; }
.clearfix::after { content: ""; display: block; clear: both;}
.clearfix::before { content: ""; display: block; clear: both;}
.f_ll { font-size:clamp(1.25rem, 2.4vw, 1.5rem); }
.f_l { font-size:clamp(1rem, 2vw, 1.25rem); }
.f_m { font-size:clamp(0.9rem, 1.6vw, 1rem); }
.f_s { font-size:clamp(0.75rem, 1.4vw, 0.875rem); }
span.f_s { display: inline-block; }
.lh100 { line-height: 1; } 
.lh125 { line-height: 1.25; } 
.lh150 { line-height: 1.5; } 
.lh200 { line-height: 2; } 
strong { font-weight:600; }

.pc_no, .pc_no2, span.pc_no2, .dis_no { display:none; }
.sp_no { display:block; }
span.sp_no { display:inline; }
br.sp_no { display:inline; }
br.sp_no2 { display:inline; }


.green {color:#6b8;}
.orange {color:#d70;}
.yellow {color:#db5;}
.red {color:#d66;}
.blue { color:#09c;}
.gray { color:gray;}

p { margin-bottom: clamp(1rem,3vw,2rem); }
p:empty { display:none; }
hr { background: none; border: none; border-bottom: 1px solid #ccd; }
ul { padding:0 0 0 1.25rem; margin:0 0 1rem 0; }

.full { margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.full_r { margin-left:0; margin-right:calc(50% - 43vw); }
.full_l { margin-left:calc(50% - 43vw); margin-right:0; }
.full_bg { padding-left:calc(50vw - 50%); padding-right:calc(50vw - 50%); }

.flex { display:flex; flex-flow:row wrap; justify-content:space-between; position:relative; }
.flex.rowre { flex-flow: row-reverse wrap; }
.flex.jcfs { justify-content:flex-start; }
.flex.jcfe { justify-content:flex-end; }
.flex.jcc { justify-content:center; }
.flex.aic { align-items: center; }
.flex.aifs { align-items: flex-start; }
.flex.aife { align-items: flex-end; }
.flex .fg1 { flex-grow: 1; }

.fadein { opacity : 0; transform : translate(0, 0); transition :all 0.75s ease 0.15s;}
.fadein.show { opacity : 1; transform : translate(0, 0); }

.fadeinUp, .fadeinUp_once { opacity : 0; transform : translate(0, 50px); transition :all 0.75s ease 0.15s;}
.fadeinUp.show, .fadeinUp_once.show { opacity : 1; transform : translate(0, 0); }

.fadeinDown, .fadeinDown_once { opacity : 0; transform : translate(0, -50px); transition :all 0.75s ease 0.15s;}
.fadeinDown.show, .fadeinDown_once.show { opacity : 1; transform : translate(0, 0); }

.fadeinLeft { opacity : 0; transform : translate(-50px, 0); transition :all 0.75s ease 0.15s;}
.fadeinLeft.show { opacity : 1; transform : translate(0, 0); }

.fadeinRight { opacity : 0; transform : translate(50px, 0); transition :all 0.75s ease 0.15s;}
.fadeinRight.show { opacity : 1; transform : translate(0, 0); }


.mb0 { margin-bottom:0 !important; }
.mb4 { margin-bottom:0.25rem !important; }
.mb8 { margin-bottom:0.5rem !important; }
.mb16 { margin-bottom:1rem !important; }
.mb24 { margin-bottom:1.5rem !important; }
.mb32 { margin-bottom:2rem !important; }
.mb48 { margin-bottom:3rem !important; }
.mb64 { margin-bottom:4rem !important; }

.mr0 { margin-right:0 !important; }
.mr4 { margin-right:0.25rem !important; }
.mr8 { margin-right:0.5rem !important; }
.mr16 { margin-right:1rem !important; }
.mr24 { margin-right:1.5rem !important; }
.mr32 { margin-right:2rem !important; }
.mr48 { margin-right:3rem !important; }
.mra { margin-right:auto; }

.ml0 { margin-left:0 !important; }
.ml4 { margin-left:0.25rem !important; }
.ml8 { margin-left:0.5rem !important; }
.ml16 { margin-left:1rem !important; }
.ml24 { margin-left:1.5rem !important; }
.ml32 { margin-left:2rem !important; }
.ml48 { margin-left:3rem !important; }
.mla { margin-left:auto; }

.mt0 { margin-top:0 !important; }
.mt4 { margin-top:0.25rem !important; }
.mt8 { margin-top:0.5rem !important; }
.mt16 { margin-top:1rem !important; }
.mt24 { margin-top:1.5rem !important; }
.mt32 { margin-top:2rem !important; }
.mt48 { margin-top:3rem !important; }

.ma { margin: auto; }

.multiply { mix-blend-mode: multiply; }
.en { font-family: "Saira Condensed", sans-serif; font-weight: 600; font-style: normal; letter-spacing:normal; }
.ja { font-family:"Noto Sans JP", sans-serif; font-style: normal; letter-spacing:normal; }
.place-en { display:none; }

html[lang="en"] rt, html[lang="en"] .no_en { display: none; }
/*html:not([lang="ja"]) rt { display: none; }*/



/*TEST用*/
div.test { display:none;}
body.test div.test { display:block; }


.article { width:100%; max-width:80rem; padding:0 clamp(1rem, 3vw, 2rem); margin:0 auto; box-sizing:border-box; position:relative; }
body.top .article { padding-top:0;}

/*--HEADER--*/
.header { margin:0 auto; position:sticky; top:0; left:0; right:0; transition:0.2s; display:flex; z-index: 1000; padding:clamp(0.5rem,1.6vw,1rem) clamp(1.5rem,3vw,2rem); height:4rem; }
body.top .header { margin-bottom:-4rem; }
.header .t_title { z-index:100; position: absolute; left:clamp(0.1rem,0.5vw,0.5rem); top:clamp(0.1rem,0.5vw,0.5rem); }
.header .t_title a { display:block; font-family: "Zen Old Mincho", serif; width:clamp(8rem,19vw,12rem); height:clamp(8rem,19vw,12rem);  /*background: url("../img/title.png") center center /cover no-repeat;*/ }

.header.bg::after, body.temp .header::after { content:""; position:absolute; top:0; right:0; bottom:0; left:0; z-index:-1; background:rgba(255,255,255,1); }
.header.bg .t_title a, body.temp .header .t_title a { width:clamp(5rem,12vw,7rem); height:clamp(5rem,12vw,7rem);}


.header .tel_box { line-height:1rem; margin:0 auto 0 clamp(0.75rem,2.5vw,1.5rem); }
.header .address { font-size:clamp(0.75rem,1vw,0.8125rem); line-height:1.25;}
.header .tel strong, .header .tel strong a { font-size:clamp(1rem, 2.2vw, 1.375rem); font-weight:normal;  }
.header .tel .material-symbols-outlined, .tel .material-symbols-outlined, .fax .material-symbols-outlined { margin:-0.5rem 0.15rem 0 0; }

.tel, .fax { display:inline-block; position: relative; line-height:1.25; padding-right:1.5rem;  }
.tel strong, .fax strong { font-size:clamp(1.25rem, 2.8vw, 1.75rem); font-weight: 500; }
.tel strong a, .fax strong a {  }
.tel .tel_hours { font-size: 0.8125rem; margin-top: 0.4rem; }

body.logged-in .header {top:32px;}


/*--HEADER MENU--*/
.hm { position:absolute; top:0; right: 0; z-index: 10000; }
/*body.logged-in .hm { top:calc(0rem + 32px);}*/
.hm.bg, body.temp .hm { background: none; }

.hm > ul { padding:0 1rem 0 0; margin:0; display:flex; flex-flow:row nowrap; list-style: none; }
.hm > ul > li { display:block; margin: 0; position: relative; transition:0.25s;}
.hm > ul > li > a { display: flex; flex-flow: row nowrap; justify-content: center; align-items: center; padding:1rem 0.75rem; width:100%; text-decoration: none; letter-spacing:1px; position: relative; filter: drop-shadow(1px 1px 0 rgba(0,0,0,0.2)); }
.hm > ul > li:hover > a, .hm > ul > li.active > a, .hm > ul > li > a.active, body.top .hm.bg > ul > li > a.active { color:#6b8; }
.hm > ul > li:hover > a::before { /*background-position: center bottom 0.5rem;*/ }
body.top .hm > ul > li > a { color:#fff; }
body.top .hm.bg > ul > li > a, body.temp .hm > ul > li > a { color:#333; filter: drop-shadow(1px 1px 0 rgba(255,255,255,0.2)); }
.hm li .sub { visibility: hidden; opacity: 0; position:absolute; top:6rem; left:calc(50% - 6.5rem); left:-0.5rem; width:13rem; z-index:100000; box-shadow:0 1rem 0.5rem -0.75rem rgba(0,0,0,0.05); transition:0.25s; }
.hm li:hover .sub { visibility: visible; opacity:1; top:4rem; }
.hm li .sub > ul { display:flex; flex-flow:column wrap; margin:0; padding:0.5rem; text-align: left; background: rgba(255,255,255,1); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); width:100%; box-shadow:0 0 0.25rem -0.75rem rgba(34,34,34,0.05); list-style: none; border: 1px solid rgba(17,85,51,0.1); /*border-radius: 0.75rem;*/ }
.hm li .sub ul li { width: 100%; margin: 0; }
.hm li .sub ul li a { display:flex; align-items:center; width:100%; padding:0.25rem 0.5rem; text-align: left; text-decoration: none; position:relative; line-height: 1.5;  /*background:url(../img/i_arrow_r.svg) left -0.5rem center /2rem no-repeat;*/}
.hm li .sub ul li a:hover { /*background-position:left -1rem center; color:#6355a1;*/ }
.hm li .sub ul li a[target='_blank']::after { top:-0.1rem; }
.hm li .sub ul li ul { list-style: none; padding-left:1.25rem; margin-bottom:0.5rem; }
.hm li .sub ul li ul li a::before { content:""; display: block; position: absolute; top:50%; left:-0.5rem; width: 1rem; border-top: 1px solid rgba(34,34,34,0.2); }
.hm li.hm_home { display: none; }

.hm li.hm_contact { background:#09e; margin-left:1rem; }
.hm li.hm_contact.active { background:#6b8; }
.hm li.hm_contact a, .hm li.hm_contact a:hover, .hm li.hm_contact.active a { padding:1rem 2rem; color:#fff; }

.hm li.hm_ig a { width:3rem; }
body.top .hm li.hm_ig a { background:url(../img/i_ig_w.svg) center center /1.5rem no-repeat; }
body.top .hm.bg li.hm_ig a, body.temp .hm li.hm_ig a { background:url(../img/i_ig.svg) center center /1.5rem no-repeat;}

.hm > ul > li.hm_lang { display:flex; align-items:center; padding:0 0.5rem;}
.hm_lang select { background:rgba(255,255,255,0.9) url(../img/i_lang.svg) left 0.25rem center /1.5rem no-repeat; border-radius: 2rem; padding: 0.25rem 0.75rem 0.25rem 2rem; border:1px solid rgba(0,0,0,0); font-size:1rem; }
.hm.bg .hm_lang select, body.temp .hm_lang select { background:rgba(0,0,51,0.05) url(../img/i_lang.svg) left 0.25rem center /1.5rem no-repeat; }
.hm_lang select:focus { border:1px solid rgba(0,0,0,0); box-shadow:none; }

.hm > ul > li.sp { display: none; }

.lang_sp, .sns_sp { display:none; }

h1, h2, h3, h4, h5, h6 { font-family: "Zen Old Mincho", serif; line-height:1.3; letter-spacing:clamp(0.1rem, 0.2vw, 0.3rem); position: relative; padding:0; text-align:left; font-weight: 500; }
h1 { font-size:clamp(2rem, 4.8vw, 3rem); margin-bottom:clamp(1rem, 2.4vw, 1.5rem); }
h2 { font-size:clamp(1.75rem, 4vw, 2.5rem); margin-bottom:clamp(1rem, 2.4vw, 1.5rem); position: relative; }
h3 { font-size:clamp(1.5rem, 3.2vw, 2rem); margin-bottom:clamp(1rem, 1.6vw, 1rem); position: relative; }
h4 { font-size:clamp(1.25rem, 2.8vw, 1.75rem); margin-bottom:clamp(1rem, 1.6vw, 1rem); position: relative; }
h5 { font-size:clamp(1.125rem, 2.4vw, 1.5rem); margin-bottom:clamp(0.5rem, 1.2vw, 0.75rem); position: relative; }
h6 { font-size:clamp(1.0rem, 1.8vw, 1.125rem); margin-bottom: 0.5rem;  letter-spacing:clamp(0.05rem, 0.15vw, 0.1rem); }
.tate { writing-mode: vertical-rl; font-feature-settings:normal; }

body.modal h1, body.modal h2, body.modal h3, body.modal h4, body.modal h5, body.modal h6 {letter-spacing:0.05rem; }
h1 .comment, h2 .comment, h3 .comment, h4 .comment, h5 .comment { display: block; font-size:clamp(0.875rem, 1.6vw, 1.0rem); letter-spacing:0.1rem; margin-top:0.5rem; font-family: "Zen Kaku Gothic New", sans-serif; color:#333; font-weight:normal; }
br + .comment { display: block; }

h3.title_box + .date { display: block; text-align: right; margin-top:clamp(-1rem,-1.6vw,-0.5rem); }
h3.title_box + .comment { margin-top:clamp(-1rem, -1.6vw, -0.5rem); margin-bottom:clamp(0.5rem, 3.2vw, 2rem); font-size: clamp(0.875rem, 1.4vw, 0.9rem); }
.page_title br { display: none; }

body.temp h2.cate_title {font-size:clamp(1rem,2.4vw,1.5rem); /*color:#6b8;*/ display:flex; align-items:center; }
body.temp h2.cate_title + .comment { margin-bottom:clamp(1rem, 2.4vw, 1.5rem); }
body.temp h3.page_title {font-size:clamp(2rem,6vw,3rem); margin-bottom:1rem; }


.material-symbols-outlined { font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24; vertical-align: middle; margin:-0.3rem 0.25rem 0 0; font-size: inherit; color:#6b8; unicode-bidi: isolate; }
.f_ll .material-symbols-outlined { font-size:clamp(1.5rem, 3.2vw, 2rem); margin-top:-0.4rem; }
h2 .material-symbols-outlined { font-size:clamp(2rem, 5vw, 3rem);; margin:0 0.25rem 0 0; color:#6b8; }
h3 .material-symbols-outlined, h4 .material-symbols-outlined { font-size:2.5rem; margin:-0.8rem 0.25rem 0 0; color:#6b8; }
.comment .material-symbols-outlined { color:#778; opacity:0.6; }
.hm .material-symbols-outlined { margin-top:0; color:#fff; }
.hm.bg .material-symbols-outlined, body.temp .hm .material-symbols-outlined { color:#6b8; }



h3 hr, h4 hr, h5 hr { border-bottom: 1px solid rgba(29,32,136,0.2); }
.blue_box h3 hr, .blue_box h4 hr, .blue_box h5 hr { border-bottom: 1px solid rgba(255,255,255,0.2); }

.blue_box { background:#6b8; color:#fff; padding-top:clamp(2rem,6vw,4rem); padding-bottom:clamp(2rem,6vw,4rem); }
.skyblue_box { background:#09e; color:#fff; padding-top:clamp(2rem,6vw,4rem); padding-bottom:clamp(2rem,6vw,4rem); }
.lightblue_box { background:rgba(0,153,238,0.07); padding-top:clamp(2rem,6vw,4rem); padding-bottom:clamp(2rem,6vw,4rem); }
.skyblue_box a, .blue_box a { color:#fff; }
.skyblue_box a.link::before, .blue_box a.link::before { border-color:#fff; }


/*--MAIN--*/
.main { text-align: center; /*aspect-ratio:16/9;*/ position:relative; display: flex; flex-flow: column nowrap; align-items: center; justify-content: center; margin:0 calc(50% - 50vw) clamp(3rem,9vw,6rem) calc(50% - 50vw); padding:0 calc(50vw - 50%); height:calc(100vh - 5rem); /*min-height:30vw;*/ max-height:60vw; overflow:hidden; }
.main .inner { width:100vw; height:calc(100vh - 5rem); /*min-height:30vw;*/ max-height:60vw; position:relative; }
.main .copy { width:clamp(7.5rem,32vw,28rem); position: absolute; left:clamp(1.5rem,6vw,8rem); mix-blend-mode: multiply; }

.main_video iframe { width: 110%; height:110%; margin:-5%; overflow: hidden; filter: hue-rotate(0deg) brightness(110%); pointer-events: none; }
.main .inner video,
.main .inner img { width:100%; height:100%; object-fit: cover; object-position:center; }
.main .inner::before { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:rgba(0,0,0,0.12);}

.main .corner { width:1rem; height:1rem; display: block; position: absolute; bottom: 0; left:-1rem; overflow: hidden;}
.main .corner:nth-of-type(2) { left:auto; right:0; bottom:auto; top:-1rem; }
.main .corner::before { content: ""; width: 200%; height: 200%; display: block; border-radius: 50%; box-shadow: 1rem 1rem 0 0 #FFF; transform: translate(-50%, -50%);
}


.section { margin-bottom:clamp(3rem,9vw,6rem); position:relative; z-index:0; }
.section .flex {}
.section .more { display:inline-block; /*text-align:center;*/ background:rgba(102,187,136,0.1) url(../img/i_arrow_r.svg) right 1rem center /1rem no-repeat; text-decoration:none; letter-spacing:0.1rem; font-size:clamp(0.8125rem,1.6vw,1rem); padding:0.5rem 3.5rem 0.5rem clamp(0.75rem,2.5vw,1.5rem); /*max-width:16rem;*/ border-radius: 3rem; }
.section .more:hover { opacity:0.8; }
.section a.more[href*=".pdf"]::after { margin-top:0 !important; }
.section h2.en { font-size:clamp(3rem,10vw,6rem); margin-top:clamp(-1.5rem,-2.5vw,-0.75rem);}
.section h2.en .ja { font-size:clamp(1rem,2.5vw,1.5rem); display:block; letter-spacing:0.2rem; }
.section .description { font-size:clamp(1rem,2.5vw,1.75rem); line-height:1.5; }

.anchor { height:clamp(6rem,12vw,8rem); margin-top:clamp(-8rem,-12vw,-6rem); position:relative; z-index:-10; width:1px; }
body.logged-in .anchor { height:calc(clamp(6rem,12vw,8rem) + 32px); margin-top:calc(clamp(-8rem,-12vw,-6rem) - 32px); }
.sticky { position: sticky; top:5rem; }
body.logged-in .sticky { top:calc(5rem + 32px);}



/*--ABOUT/--*/
.about_box { }
.about_box::before { content:"";  position:absolute; z-index:-1; left:calc(50% - 50vw); top:clamp(-15rem,-18vw,-6rem); width:clamp(18rem,36vw,45rem); height:clamp(6rem,12vw,15rem); background: url("../img/bg01.webp") center center /contain no-repeat; }
.about_box h2 { text-shadow:1px 1px 0.5rem rgba(255,255,255,0.8); }
.about_box h2.en .ja { border-top:1px solid #09e; padding:clamp(0.5rem,1.6vw,1rem) 0; }
.about_box .copy_box { font-size:clamp(1.75rem,7vw,3.5rem); line-height:1.25; font-weight:600; margin-bottom:clamp(1rem,3vw,2rem); margin-right:-20vw; letter-spacing:clamp(0.1rem,0.2vw,0.3rem);}
.about_box .text { position:relative; z-index:10; }
.about_box .text p { margin-bottom:clamp(1.5rem,5vw,3rem); }
.about_box .more { margin-bottom:clamp(1rem,3vw,2rem); }
.about_box .photo { background:#fff; position:relative; left:0; border-radius:0.75rem; overflow:hidden; }
.about_box .photo img, .about_box .photo video { width:100%; height:100%; object-fit:cover; margin-right:-20vw; }
 


/*--VIDEO/--*/
.video_box {}
.video_box .video_wrap { width:100%; aspect-ratio:16/9; max-width:54rem; border-radius:clamp(1rem,3vw,2rem); overflow:hidden; margin:auto; border-radius: 1rem; }
.video_box .video_wrap iframe { width:100%; height:100%; }

.youtube { width:100%; max-width:60rem; background:#fff; aspect-ratio:16/9; border-radius:0; overflow: hidden; margin-bottom:clamp(0.5rem,1.2vw,0.75rem); border-radius: 1rem; }
.youtube iframe{ aspect-ratio:16/9; width:100%; height:100%; filter: brightness(1.1) saturate(120%);}
.youtube::before { content: "SAMPLE"; color: rgba(255,255,255,0.4); position: absolute; right:0; bottom:clamp(0.5rem,1.2vw,0.75rem); z-index: 30; font-size:clamp(1rem,5vw,3rem); font-weight: bold; line-height: 1; }



/*--NEWS/--*/

.main .news_box { position:absolute; bottom:0; right:0; background:#fff; width:clamp(18rem,25vw,30rem); padding:1.5rem 1.5rem 0 1.5rem ; border-radius: 1.5rem 0 0 0; margin:0; }
.main .news_box h2 { font-size:clamp(1.25rem, 2.8vw, 1.75rem); margin-bottom:0.5rem; }
.main .news_box h2 .material-symbols-outlined { margin-top:-0.7rem; }
.main .news_box .more { position:absolute; top:1rem; right:0; min-width:1rem; letter-spacing:normal;}
.main .news_box a[href$='#']{ pointer-events:none; text-decoration:none; }
.main .news_box .more { background:#fff; padding-right:1.5rem;}
.main .news_box .index_area { display: flex; flex-flow: row wrap; justify-content: flex-start; overflow-x: auto; padding:0; margin:0; border:none; gap:0; } 

.main .news_box .index_area .index_box, .main .news_box .index_area .index_box:first-of-type { width: 100%; position: relative; padding:0; border-top:1px solid rgba(102,187,136,0.2); }
.main .news_box .index_area .index_box a { text-decoration: none; display: flex; flex-flow: row nowrap; align-items: flex-start; border:none; padding:0.75rem 0;} 
.main .news_box .index_area .index_box .photo { /*display:none;*/ width:6rem; min-width:6rem; margin:0 clamp(0.5rem,1.6vw,1rem) 0 0; max-width:none; aspect-ratio:3/2 !important; }
.main .news_box .index_area .index_box .date { padding: 0 clamp(1rem,2.4vw,1.5rem) 0.25rem 0; line-height:1.2; }
.main .news_box .index_area .index_box .title { font-size:clamp(0.8125rem,1.5vw,0.9375rem); font-weight:400; height:calc(clamp(0.8125rem,1.5vw,0.9375rem)*2.6); font-family: "Zen Kaku Gothic New", sans-serif; margin:0; }
.main .news_box .index_area .index_box .title::after { background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 70%, rgba(255,255,255,1) 100%); bottom:0; content: ""; height: calc(clamp(0.8125rem,1.5vw,0.9375rem)*1.3); position: absolute; right: 0; width: 2rem;}

.news_box, .news_box .w70 { position:relative; }
.news_box .index_area .index_box .photo, body.news .index_area .index_box .photo, body.archive .index_area .index_box .photo { border-radius:0.75rem 0.75rem 0,75rem 0; overflow:hidden;}
.news_box .index_area .index_box .photo img { width:100%; height:100%; object-fit: cover; }
.news_box .index_area .index_box .date, body.archive .index_area .index_box .date, body.news .index_area .index_box .date { display:block; font-size:clamp(0.6875rem,1.4vw,0.875rem); padding: 0 clamp(1rem,2.4vw,1.5rem) clamp(0.25rem,0.8vw,0.5rem) 0; color:#333; width:clamp(5.5rem,10vw,6rem); color:#6b8;}
.news_box .index_area .index_box .date { width:100%; }
.news_box .index_area .index_box .date span { color:#333; }
.news_box .index_area .index_box .text , body.archive.news .index_area .index_box .text { flex-grow:2;}
.main .news_box .index_area .index_box .cate { padding: 1rem 1.875rem; border-right:1px solid #333; }
.news_box .index_area .index_box .cate span { display: block; width: 5rem; font-size:0.75rem; background:rgba(255,255,255,0.3); text-align: center; font-weight: bolder; }
.news_box .index_area .index_box .title, body.archive .index_area .index_box .title, body.news .index_area .index_box .title { padding:0; color:#333; font-size:clamp(1rem,1.8vw,1.25rem); overflow: hidden; }

.news_box .index_area .index_box .comment, body.archive .index_area .index_box .comment { line-height:1.75; font-size: 0.875rem; }
.news_box .index_area .index_box a:not(.nolink):hover .title, .event_area .index_area .index_box a:not(.nolink):hover .title, .body.archive .index_area .index_box a:not(.nolink):hover .title {  }
.news_box .index_area .comment, .event_area .index_area .comment { display:none; }

.news_box .more { position:absolute; top:0; right:0; }

.pamph_box { }
.pamph_box .photo { border:1px solid #ddd; margin-bottom:1rem; }
.pamph_box .more { position:relative; }

.purpose_box { margin-bottom:clamp(3rem,9vw,6rem); }
.purpose_box .more { margin:auto; }
.purpose_box ul { flex-flow:row wrap; gap:2%; row-gap:0; justify-content:flex-start; width:100%; height:auto; position:relative; }
.purpose_box ul li { width:15%; position:relative; margin-bottom:clamp(1rem,3vw,2rem); }
.purpose_box ul li a { width:100%; display:block; writing-mode: vertical-rl; text-decoration:none; position:relative; }
.purpose_box ul li .photo { width:100%; aspect-ratio:2/3; border-radius: 0.5rem; overflow:hidden; min-width:2rem; }
.purpose_box ul li .photo img { width:100%; height:100%; object-fit:cover; }
.purpose_box ul li .text { position:absolute; background:#fff; top:-0.5rem; left:0; border-radius:0 0 0.25rem 0; padding:0 0.5rem 0.5rem 0; line-height:1; font-size:clamp(1rem,2vw,1.25rem); max-height:100%; }
.purpose_box ul li .text .corner { width:0.5rem; height:0.5rem; display: block; position: absolute; bottom:-0.5rem; left:0; overflow: hidden; z-index:100;}
.purpose_box ul li .text .corner:nth-of-type(2) { left:auto; right:-0.5rem; top:0.5rem; bottom:auto; }
.purpose_box ul li .text .corner::before { content: ""; width: 200%; height: 200%; display: block; border-radius: 50%; box-shadow: -0.5rem -0.5rem 0 0 #FFF; transform: translate(50%, 0); }


.spot_box { background: url('../img/bg02.webp') left 0.5rem bottom /clamp(12rem,40vw,45rem) no-repeat; }

/*タブ*/
.tab { display: flex; flex-flow:row nowrap; margin:0; position: relative; z-index: 0; background: linear-gradient(to bottom, rgba(221,221,2221,0) 50%,rgba(221,221,221,0.15) 100%); overflow:hidden; overflow-x:auto }
.tab::after { content:""; display:block; position:absolute; bottom:0; left:0; right:0; border-bottom:1.5px solid #6b8; z-index:10; }
.tab li { position: relative; z-index: 10; padding:clamp(0.5rem, 1.2vw, 0.75rem) clamp(0.75rem, 1.6vw, 1rem) clamp(0.25rem, 0.8vw, 0.5rem) clamp(0.75rem, 1.6vw, 1rem); text-decoration:none; line-height: 1.25; white-space: nowrap; cursor: pointer; border:1.5px solid rgba(0,0,0,0); border-bottom:none; margin-right:clamp(0.25rem,0.8vw,0.5rem); background:rgba(221,221,221,0.2); border-radius: 1rem 1rem 0 0; z-index:0; }
.tab li span.f_ll { font-size: clamp(1.5rem, 3.2vw, 2rem); letter-spacing:0.25rem; }
.tab li.active { border-color: #6b8; margin-bottom:-1.5px; /* border-color:rgba(143,194,31,1); color: #6b8;*/ background:#fff; color:#6b8; z-index:50; }

.tab_content { overflow:hidden; padding:0; margin:0; list-style:none !important; transition:0.5s; display:none; position:relative; }
.tab_content.active { display:block; }

.tab_content#highlights { /*margin-right:calc(50% - 45vw);*/ }
.tab_content#highlights .index_area, .tab_content#ranking .index_area, .news_box .index_area { display:grid; grid-template-areas: "block1 block2 block3" "block1 block4 block5"; grid-template-columns: 2fr repeat(2,1fr); margin-bottom:0;  }
.tab_content#highlights .index_area .index_box, .tab_content#ranking .index_area .index_box, .news_box .index_area .index_box { width:auto;}
.tab_content#highlights .index_area .index_box:first-of-type, .tab_content#ranking .index_area .index_box:first-of-type, .news_box .index_area .index_box:first-of-type { grid-area: block1; width:auto; }
.tab_content#highlights .index_area .index_box:first-of-type .photo, .tab_content#ranking .index_area .index_box:first-of-type .photo, .news_box .index_area .index_box:first-of-type .photo { aspect-ratio:4/3; }
.tab_content#highlights .index_area .index_box:nth-of-type(2), .tab_content#ranking .index_area .index_box:nth-of-type(2) { grid-area: block2; }
.tab_content#highlights .index_area .index_box:nth-of-type(3), .tab_content#ranking .index_area .index_box:nth-of-type(3) { grid-area: block3; }
.tab_content#highlights .index_area .index_box:nth-of-type(4), .tab_content#ranking .index_area .index_box:nth-of-type(4) { grid-area: block4; }
.tab_content#highlights .index_area .index_box:nth-of-type(5), .tab_content#ranking .index_area .index_box:nth-of-type(5) { grid-area: block5; }

.tab_content .more { position:absolute; top:0; right:0; }

.tab_content#ranking .index_area .index_box::before,
body.page-ranking .index_area .index_box::before { content:"\ecb3"; display:block; position:absolute; top:-1.5rem; font-family:"Material Symbols Outlined"; font-size:clamp(3rem,6vw,4rem); font-variation-settings:'FILL' 1,'wght'250,'GRAD' 0,'opsz' 24; line-height:1; z-index:10; color:#da3; text-shadow:1px 1px rgba(255,255,255,0.8); }
.tab_content#ranking .index_area .index_box::after,
body.page-ranking .index_area .index_box::after { content:""; color:#fff; display:flex; align-items:center; justify-content:center; position:absolute; top:-1.5rem; z-index:20; font-size:clamp(1rem,2.4vw,1.5rem); width:clamp(3rem,6vw,4rem); height:clamp(3rem,6vw,4rem); text-align:center; font-weight:600; }
.tab_content#ranking .index_area .index_box:nth-of-type(1)::after { content:"1"; }
.tab_content#ranking .index_area .index_box:nth-of-type(2)::after { content:"2"; }
.tab_content#ranking .index_area .index_box:nth-of-type(3)::after { content:"3"; }
.tab_content#ranking .index_area .index_box:nth-of-type(4)::after { content:"4"; }
.tab_content#ranking .index_area .index_box:nth-of-type(5)::after { content:"5"; }

body.page-ranking .index_area .index_box:nth-of-type(1)::after { content:"1"; }
body.page-ranking .index_area .index_box:nth-of-type(2)::after { content:"2"; }
body.page-ranking .index_area .index_box:nth-of-type(3)::after { content:"3"; }
body.page-ranking .index_area .index_box:nth-of-type(4)::after { content:"4"; }
body.page-ranking .index_area .index_box:nth-of-type(5)::after { content:"5"; }
body.page-ranking .index_area .index_box:nth-of-type(6)::after { content:"6"; }
body.page-ranking .index_area .index_box:nth-of-type(7)::after { content:"7"; }
body.page-ranking .index_area .index_box:nth-of-type(8)::after { content:"8"; }
body.page-ranking .index_area .index_box:nth-of-type(9)::after { content:"9"; }
body.page-ranking .index_area .index_box:nth-of-type(10)::after { content:"10"; }

body.page-ranking .index_area .index_box:nth-of-type(n+7) {width:calc((100% - clamp(1rem,4vw,2.5rem)*3)/4); }


ul.sub_link { padding-bottom:1.5rem; }
ul.sub_link ul.sub_link { padding-bottom:0; }
ul.sub_link li a { display:block; padding:0.5rem 0 0.5rem 1.5rem; background:url(../img/i_arrow_r.svg) left top 0.8rem /1rem no-repeat; text-decoration:none; line-height:1.5; }


/*--cyclestation_box--*/
.cyclestation_box { padding-top:clamp(3rem,9vw,6rem); padding-bottom:clamp(3rem,9vw,6rem); background:#fbf7e7; background:rgba(17,34,85,0.2); margin-bottom:0; align-items:center; }
.cyclestation_box .photo { width:70%; aspect-ratio:3/2; overflow:hidden; position:relative; border-radius: 1rem; }
/*.cyclestation_box .photo::before { content:"SAMPLE"; font-size:clamp(2rem,6vw,4rem); color:rgba(255,255,255,0.6); position:absolute; left:0; top:0; line-height:1; z-index:10; font-weight:600; }*/
.cyclestation_box .photo img { width:100%; height:100%; object-fit:cover; object-position:center bottom; }
.cyclestation_box .text { width:45%; margin-left:-15%; margin-right:-5%; position:relative; /*right:clamp(-3rem,-5vw,-1rem); top:50%; transform:translate(0, -50%);*/ color:#fff; padding:clamp(1rem,3vw,2rem); z-index:10; }
.cyclestation_box .text::after { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:rgba(0,85,68,0.85); background:rgba(17,34,85,0.9); mix-blend-mode: multiply; z-index:-1;border-radius: 1rem; }
.cyclestation_box .text .notice { background:rgba(255,255,255,0.1); border-radius: 0.5rem; }
.cyclestation_box .text li::marker { color:#fff; }



/*--PRODUCTS--*/
.products_box { padding-top:clamp(3rem,9vw,6rem); padding-bottom:clamp(3rem,9vw,6rem); background-image: radial-gradient(rgba(102,187,136,0.1) 2px, transparent 1px); background-color:rgba(102,187,136,0.05); background-image: radial-gradient(rgba(102,187,136,0.15) 2px, transparent 1px); background-color:rgba(102,187,136,0.1); background-size: 20px 20px; margin-bottom:0; }

.furusato_nozei { display:flex; justify-content:flex-start; gap:2%;}
.furusato_nozei .more { width:32%; margin:0; max-width:30rem; margin-bottom:0.75rem;  display:inline-block; background:rgba(102,187,136,0.1) url(../img/i_arrow_r.svg) right 1rem center /1rem no-repeat; text-decoration:none; letter-spacing:0.1rem; font-size:clamp(0.8125rem,1.6vw,1rem); padding:0.5rem 3.5rem 0.5rem clamp(0.75rem,2.5vw,1.5rem); /*max-width:16rem;*/ border-radius: 3rem; }
.furusato_nozei .more:hover { opacity:0.8; }
.furusato_nozei a.more[href*=".pdf"]::after { margin-top:0 !important; }


/*--IJU_TEIJU--*/
.iju_box { padding-top:clamp(3rem,9vw,6rem); padding-bottom:clamp(3rem,9vw,6rem); padding:clamp(0.75rem,2.5vw,1.5rem); background:#e9f124; /*margin-bottom:0;*/ align-items:center; border-radius: 2.5rem; margin-left:clamp(-3rem,-5vw,-1.5rem); margin-right:clamp(-3rem,-5vw,-1.5rem); }
.iju_box .inner { background:#fff; max-width:80rem; margin:auto; padding:clamp(1rem,2.5vw,1.5rem); border-radius: 1rem;}



/*--ACCESS/--*/
.access_box { background:#fbf7e7; padding-top:clamp(3rem,9vw,6rem); padding-bottom:clamp(3rem,9vw,6rem); }


/*--BANNER--*/
.b_box { display:flex; flex-flow:row wrap; gap:2%; }
.b_box div { width:23.5%; margin-bottom:2%; }
.b_box ul { list-style:none; padding:0; margin:0; display:flex; flex-flow:row wrap; justify-content:flex-start;}
.b_box ul li { padding:1.5%; }
.b_box a.banner { display:flex; width:100%; max-width:25rem; margin:auto; border:1px solid rgba(34,51,85,0.2); text-align:center; text-decoration:none; align-items:center; justify-content:center; }

.b_box_slick { /*position:absolute; left:clamp(1rem,3vw,2rem); bottom:1rem;  width:calc(90% - clamp(18rem,25vw,30rem));*/ position:relative; opacity:0; transition:0.5s; width:100%; }
.b_box_slick.slick-initialized { opacity:1;}
.b_box_slick .slick-slide { padding:1%;}
.b_box_slick a, .b_box a  { display:block; aspect-ratio:5/2; border-radius: 0.5rem; overflow:hidden; }
.b_box_slick a img, .b_box a img { width:100%; height:100%; object-fit:contain; object-fit:cover; }



/*--CONTACT/--*/
.contact_box {}


/*--FOOTER--*/
.footer { line-height: 1.7; margin: auto; ; position: relative; display:flex; flex-flow:row nowrap; justify-content: flex-start; align-items: flex-start; padding-top:clamp(1rem,3vw,2rem); padding-bottom:clamp(1rem,3vw,2rem); margin-top:clamp(1rem,3vw,2rem); }

.footer .title { width:clamp(6rem,40%,8rem); /*margin-top:-0.5rem;*/ margin-right:2.5rem; margin-bottom:1rem;  }
.footer .logo img { width: 100%; height: auto; }
.footer .address_box { flex-grow: 2; position: relative; }

.copyright { padding:0.25rem 2rem 0 0; font-size:clamp(0.6125rem,1.2vw,0.75rem); position:absolute; right:0; bottom:0; z-index:-1; }

.footer a.link { display: block; padding:0.75rem 0.75rem 0.75rem 1.5rem; text-decoration: none; }
.footer a.link::before { content:""; position:absolute; display:block; left:0; top:calc(50% - 0.3rem); width:0.6rem; height:0.6rem; margin:0; border-top:2px solid #6b8; border-right:2px solid #6b8; transform:rotate(45deg); box-sizing:border-box; }

body.temp .footer { border-top:1px solid rgba(102,187,136,0.5); }



.pagetop { position:fixed; /*display:flex; flex-flow:column nowrap; justify-content:center;*/ bottom:0; right:0; width: 3rem; font-size:0.875rem; height:7.5rem; padding-top:0.75rem; border-radius: 1rem 0 0 0; text-decoration: none; writing-mode:vertical-rl; z-index:10000; color:rgba(0,0,0,0.7); display: flex; flex-flow: column nowrap; justify-content: center; }
.pagetop::before { content:"TOP"; text-shadow:1px 1px 0 rgba(255,255,255,0.8); }
.pagetop::after { content:""; position:absolute; top:1rem; left:1.5rem; bottom:0; margin-top:2rem; border-right:1px solid rgba(0,34,51,1); box-shadow:1px 0 0 rgba(255,255,255,0.8); }
.pagetop:hover { opacity: 0.7; }



/*-- TEMPLARE CONTENTS --*/
body.temp .article > .inner { width:100%; max-width:80rem; margin:0 auto; }
body.temp .article > .inner > .w85 { margin-right:auto; align-self:flex-start; }
body.page-contact .article > .inner { max-width:60rem;}


.text_area { width:100%; max-width:75rem; /*margin: auto;*/ }

.navibar { margin-bottom:0; padding:1rem 0; align-self:flex-start; color:#666; margin-left:auto; }
.navibar ul { display: flex; flex-flow:row wrap; justify-content: flex-end; margin:0; padding:0; font-size:clamp(0.75rem, 1.5vw, 0.8125rem); line-height:1.5; }
.navibar ul li { list-style-type:none; padding:0; max-width: 15rem; display: inline-block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-feature-settings: initial; }
.navibar ul li::before { content:"／"; margin:0.5rem 0.25rem; }
.navibar ul li:first-child::before { display:none; }
.navibar a { border:none !important; color:#666; }
.navibar br { display:none; }
.navibar rt { display:none; }


.col2 { column-count:2; column-gap:2rem; }
.col3 { column-count:3; column-gap:2rem; }
.col4 { column-count:4; column-gap:2rem; }


.caption { line-height: 1.5; font-size: clamp(0.8125rem,1.4vw,0.9rem); padding-top:0.5rem; letter-spacing:0.025rem; }
.LR_box img + .caption, .LCR_box img + .caption { margin-top:-1rem; }



a.link, a span.link { padding:0.5rem 0.15rem 0.5rem 1rem; margin:0; text-decoration:underline; box-sizing:border-box; position:relative; overflow:hidden; }
a.link::after, a span.link::after { content: "."; width: 0; color: transparent; margin-right: 1px; white-space:nowrap; }
a.link::before, a span.link::before { content:""; position:absolute; left:0; top:calc(50% - 0.2rem); display:block; width:0.4rem; height:0.4rem; margin:0; border-top:1px solid #333; border-right:1px solid #333; transform:rotate(45deg); box-sizing:border-box; vertical-align: middle; }
a.link.active::after { border-top:1px solid #fff; border-right:1px solid #fff; transform:rotate(45deg); }
a.link.red { color:#d66; }
a.link .icon { display: inline-block; margin-right: 0.5rem; vertical-align: middle; }

h5 a.link::before { top:1.3rem; }


ul.page-link { display: flex; justify-content: flex-start; flex-flow: row wrap; text-align: left; margin:0 -0.5rem clamp(2rem,6vw,4rem) -0.5rem !important; padding:1rem; position: relative; z-index: 0; transition:0.25s; width:calc(100% + 1rem); /*overflow-x: auto;*/ background:rgba(229,222,179,0.3); }
ul.page-link li { display: block; width: auto; padding:0; margin: 0; box-sizing:border-box; position:relative; z-index:100; white-space:nowrap; }
ul.page-link li a { display: block; padding:0.5rem 1rem 0.5rem 1.5rem; text-decoration: none; position: relative; z-index:100; line-height: 1.5; font-size:clamp(0.875rem, 1.5vw, 0.9rem); }
ul.page-link li a:hover { color:#6b8;} 
ul.page-link li.active a, .index_box.active a .title { }
ul.page-link a::before { content:""; position:absolute; display:block; left:0.5rem; top:0.8rem; width:0.5rem; height:0.5rem; margin:0; border-bottom:1px solid #333; border-right:1px solid #333; transform:rotate(45deg); box-sizing:border-box; }
ul.page-link li.active a::before { }
.f_s ul.page-link a::before { top:0.9rem; }
.hero + ul.page-link li.active { border-top: none; }
.hero + ul.page-link li.active a { margin-bottom:-2px; border-top: none; }
ul.page-link.bottom { max-width:70rem; margin:2rem auto 4.5rem auto !important; padding:1rem 0 0 0; border-top:1px solid rgba(34,34,34,0.2); }
ul.page-link.bottom a::before { top:1.1rem; transform:rotate(-135deg); }
ul.page-link li a.index { display: block; pointer-events: none; padding-left:1rem; color:#6b8; position:absolute; top:-2.25rem; left:-1rem;  }
ul.page-link li a.index::before { display: none; }
ul.page-link::before { content: "INDEX"; display: block; padding-left:1rem; color:#6b8; position:absolute; top:-1rem; left:0; }

ul.page-link.bg { position: sticky; top:10rem; z-index: 2000; background:rgba(255,255,255,0.8); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); flex-flow:row nowrap; padding-right:20rem; }
ul.page-link.bg::after { content: ""; position: absolute; top:0; right:0; }
h3.page_title + ul.page-link { margin:0 -0.5rem clamp(2rem,6vw,4rem) -0.5rem !important; }



/*-- INDEX --*/
.index_area { display:flex; flex-flow:row wrap; justify-content:flex-start; /*align-items: flex-start;*/ padding:0; margin:0; margin-bottom:clamp(2rem,6vw,4rem); position: relative; gap:clamp(1rem,4vw,2.5rem); }

.index_box { position:relative;  width:calc((100% - clamp(1rem,4vw,2.5rem)*2)/3); vertical-align:top; box-sizing:border-box; text-align:left; padding:0; transition:0.15s; margin-bottom:0.5rem; }
.index_box a { display:block; text-decoration: none; }
.index_box .photo { width: 100%; aspect-ratio:3/2; min-width: 8rem; margin-bottom:clamp(0.5rem,1.2vw,0.75rem); position:relative; border-radius: 0.75rem; overflow:hidden; }
.index_box .photo a { width:100%; height:100%; object-fit: cover; font-family:'object-fit:cover;'; border-radius: 0.75rem; overflow:hidden; }
.index_box .photo img { width:100%; height:100%; object-fit: cover; font-family:'object-fit:cover;'; transition:0.15s; object-position:top center; }
.index_box a:hover { text-decoration:none; opacity:1; color:#333; }

.index_box p { margin:0; text-decoration:none; }
.index_box .photo .cate_box { font-size:clamp(0.75rem,1.4vw,0.8125rem); position:absolute; bottom:-0.4rem; left:0; background:rgba(255,255,255,1); border-radius:0 0.5rem 0 0; padding:0.25rem 0.5rem 0.25rem 0.25rem; line-height: 1.5; }
.index_box .cate_box .cate { display:inline-block; background:#6b8; color:#fff; padding:0 0.5rem; margin:0 0.5rem 0.5rem 0; border-radius:0.25rem; white-space:nowrap; }
.index_box .new { font-size:clamp(0.75rem, 1.3vw, 0.8rem); display:inline-block; padding:0 0.5rem; background:#ff8e65; color:#fff; text-align:center; z-index:10; }
.index_box .text { display:flex; flex-grow:1; flex-flow:column nowrap; padding:0; line-height: 1.5; }
.index_box .date { display: none; line-height:1.5;  }
.index_box .title { font-size:clamp(1rem,1.8vw,1.25rem); display:block; align-items:flex-start; position: relative; color:#333; line-height:1.5; font-weight:normal; flex-grow:1; font-weight:600; margin-bottom:clamp(0.25rem,0.8vw,0.5rem); line-height:1.3; font-family: "Zen Old Mincho", serif; }

.index_box .comment{ font-size:clamp(0.75rem, 1.4vw, 0.875rem); display: block; line-height: 1.7; color:#777; margin-bottom:clamp(0.25rem,0.8vw,0.5rem); font-weight:400; height:calc(clamp(0.75rem, 1.4vw, 0.875rem)*1.7); overflow:hidden; position:relative; mask-image: linear-gradient(to right, #000 90%, transparent 100%); mix-blend-mode:multiply; }
/*.index_box .comment::after {background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 70%, rgba(255,255,255,1) 100%); bottom:0; content: ""; height: calc(clamp(0.75rem, 1.4vw, 0.875rem)*1.7); position: absolute; right: 0; width: 2rem;}*/

.index_box .text br, .hm li a br { display: none; }
.index_box .text br.br, .index_box .text .comment br, .hm li a br.br { display: inline-block; }

.index_box .route, a.route, .text_area .index_box a.route, .text_area .index_box a.review-link { display:inline-block; background:#6b8; color:#fff; border-radius:2rem; padding:0 clamp(0.5rem,1.2vw,0.75rem) 0 clamp(0.25rem,0.8vw,0.5rem); margin-right:clamp(0.25rem,0.8vw,0.5rem); border:1px solid #6b8; font-size:clamp(0.75rem,1.4vw,0.8125rem); text-decoration:none; letter-spacing:normal; }
.index_box .route:hover { color:#fff; }
.index_box .route .material-symbols-outlined { color:#fff; font-size:1.125rem; margin-right:0.1rem; }
.index_box .detail { display:inline-block; background:#fff; border-radius:2rem; padding:0 clamp(0.5rem,1.2vw,0.75rem); margin-left:auto; border:1px solid #cdc; font-size:clamp(0.75rem,1.4vw,0.8125rem); letter-spacing:normal; }

.text_area a.route, .text_area a.review-link { display:inline-block; background:#6b8; color:#fff; border-radius:2rem; padding:0.25rem 1.25rem 0.25rem 0.75rem; margin-right:0.5rem; border:1px solid #6b8; font-size:1.125rem; text-decoration:none; line-height:1.6; }
.text_area a.route .material-symbols-outlined, .text_area a.review-link .material-symbols-outlined { color:#fff; font-size:1.5rem; }
.text_area a.route::after, .text_area a.review-link::after { display:none !important; }

.page-tags { display:flex; flex-flow:row wrap; justify-content:flex-start; margin-bottom:0; background:rgba(255,255,255,1); border-radius:0 0.5rem 0 0; }
.page-tags a { display:block; padding:0; color:#777; text-decoration:none; line-height:1.5; font-size:clamp(0.75rem,1.4vw,0.8125rem); /*pointer-events:none;*/ }
/*.page-tags a + a::before { content:"/"; margin:0 0.25rem 0 0; color:#777; }*/
.tag-link.tag-highlight { display:none;}
.index_box .page-tags, .event_slick .page-tags { position:absolute; padding:0.3rem 0.3rem 0 0; bottom:-0.4rem; margin-bottom:0; gap:0; max-width:70%;}
.index_box .photo .page-tags a { width:auto; overflow:visible; }
.index_box .photo .corner, .event_slick .photo .corner { width:0.5rem; height:0.5rem; display: block; position: absolute; top:-0.5rem; left:0; overflow: hidden; z-index:100;}
.index_box .photo .corner:nth-of-type(2), .event_slick .photo .corner:nth-of-type(2) { left:auto; right:-0.5rem; top:auto; bottom:0.4rem; }
.index_box .photo .corner::before, .event_slick .photo .corner::before { content: ""; width: 200%; height: 200%; display: block; border-radius: 50%; box-shadow: -0.5rem 0.5rem 0 0 #FFF; transform: translate(0, -50%); }

.index_box .page-tags a::before { color:#6b8; font-family:"Material Symbols Outlined"; fill:1; margin-right:0.5rem; font-size:1.5rem; font-variation-settings:'FILL' 1,'wght'250,'GRAD' 0,'opsz' 24; margin-right:0.25rem; line-height:1; }
.index_box .page-tags a.tag-highlights::before { content:"\f298"; }
.index_box .page-tags a.tag-history::before{ content:"\ea3e"; }
.index_box .page-tags a.tag-art::before { content:"\efcb"; font-variation-settings:'FILL' 0,'wght'250,'GRAD' 0,'opsz' 24; }
.index_box .page-tags a.tag-nature::before { content:"\ea99";}
.index_box .page-tags a.tag-eat_shopping::before { content:"\f3e4"; }
.index_box .page-tags a.tag-enjoy::before { content:"\e92c";}
.index_box .page-tags a.tag-stay::before { content:"\e53a";}
.index_box .page-tags a.tag-season_event::before { content:"\e614"; }


.event_slick .page-tags { font-weight:600; }
.event_slick .page-tags .spring { padding:0 0.3rem 0.3rem 0.3rem; color:rgba(204, 96, 128,1);}
.event_slick .page-tags .summer { padding:0 0.3rem 0.3rem 0.3rem; color:rgba(64, 128, 96,1);}
.event_slick .page-tags .autumn { padding:0 0.3rem 0.3rem 0.3rem; color:rgba(176, 112, 64,1);}
.event_slick .page-tags .winter { padding:0 0.3rem 0.3rem 0.3rem; color:rgba(96, 128, 160,1);}

.index_box .photo .copyright { position:absolute; z-index:100; color:#fff; right:0; bottom:0; padding:0 0.5rem;}


.products_box .page-tags { background:#eff8f3; }
.products_box .index_box .photo .corner::before { box-shadow: -0.5rem 0.5rem 0 0 #eff8f3; }

body.page-feature .index_box .photo { aspect-ratio:5/2;}
/*body.page-spot .index_box { width:calc((100% - clamp(1rem,4vw,2.5rem)*3)/4); }*/




.index_box a[target='_blank'] .title::after,
.LCR_box a[target='_blank']::after,
body.link .article li a[target='_blank']::after,
body.link .article a:link[target='_blank']::after,
.article a:link[target='_blank']::after,
.hm li .sub ul li a[target='_blank']::after
{ content:""; position:relative; display:inline-block; vertical-align:middle; width:1rem; height:1rem; margin:-0.35rem 0.2rem 0 0.5rem; background:url(../img/i_blank.svg) center bottom /100% no-repeat; /*mix-blend-mode:multiply;*/ }
.index_box a[target='_blank']::after { display:none !important; }
a[target='_blank'].banner::after { display:none !important; }

.index_box a[href*='.pdf'] .title::after, 
a[href*='.pdf']::after, 
.index_box ul li a[href*='.pdf']::after { content:"PDF" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#e55; font-weight:bold; background:#fff !important; margin:0 0.25rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); vertical-align:middle; }

.index_box a[href*='.pdf']::after { display:none !important; }

.index_box a[href*='.xls'] .title::after, 
.index_box a[href*='.xlsx'] .title::after, 
a[href*='.xls']::after, 
a[href*='.xlsx']::after, 
.index_box ul li a[href*='.xls']::after, 
.index_box ul li a[href*='.xlsx']::after { content:"Excel" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#7da52b; font-weight:bold; background:#fff !important; margin:0 0.25rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); }

.index_box a[href*='.xls']::after,
.index_box a[href*='.xlsx']::after { display:none !important; }

.index_box a[href*='.doc'] .title::after, 
.index_box a[href*='.docx'] .title::after, 
a[href*='.doc']::after, 
a[href*='.docx']::after, 
.index_box ul li a[href*='.doc']::after, 
.index_box ul li a[href*='.docx']::after { content:"Word" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#7b8d42; font-weight:bold; background:#fff !important; margin:0 0.5rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); }

.index_box a[href*='.doc']::after,
.index_box a[href*='.docx']::after { display:none !important; }

.index_box a[href*='.pdf'] .title::after,
.index_box a[href*='.xls'] .title::after, 
.index_box a[href*='.docx'] .title::after { /*top:0.5rem;*/ }

.news_box ul li a[href*='.pdf']::after,
.news_box ul li a[href*='.xlsx']::after,
.news_box ul li a[href*='.docx']::after { position: absolute; top:0.35rem; right:0; }

.b_box a[target="_blank"]::after, .b_box a[href$=".pdf"]::after, .b_box a[href$=".docx"]::after { display:none !important; }



body.archive .contents { display: flex; flex-flow:row wrap; justify-content: space-between; /*align-items:flex-start; max-width:70rem;*/ margin:0 auto clamp(2.5rem,8vw,5rem) auto; }
body.archive .index_area { margin-bottom:clamp(1.5rem,5vw,3rem); }
body.archive .aside { display: inline-block; vertical-align: top; box-sizing:border-box; margin-right: auto; position: relative; z-index: 1000; margin:0 ; }
body.archive .aside h5 { margin-top:0; margin-bottom:0.5rem; }
body.archive .aside ul { display: flex; flex-flow: row wrap; justify-content: flex-start; margin:0; padding:0 0 0 1.5rem; }
body.archive .aside ul li { padding: 0; width:100%; position:relative; }
body.archive .aside ul li::marker { color:rgba(99,85,161,0.2); }
body.archive .aside ul li::before { content:"●"; color:#057; position:absolute; left:-1.5rem; }

body.archive .aside ul li.info::before { color:#ffbe00; }
body.archive .aside ul li.recruit::before { color:#6b8; }

body.archive .aside ul li.season_event a::before {}


.siblings { margin-bottom:clamp(1.5rem,5vw,3rem);}
body.parent-pageid-39 .siblings .comment, .siblings .comment { font-size: clamp(0.75rem, 1.4vw, 0.875rem); margin-bottom:clamp(0.25rem,0.8vw,0.5rem);}


.side ul.category > li > a, .mean-container .mean-nav .sub li a { display:flex; align-items:center; text-decoration:none; padding:0.25rem 0;}
.side ul.category > li > a::before, .cate_title::before, .siblings h4.page-category-title::before, .hm li .sub ul li a::before, .mean-container .mean-nav .sub li a::before { color:#6b8; font-family:"Material Symbols Outlined"; fill:1; margin-right:0.5rem; font-size:2rem; font-variation-settings:'FILL' 1,'wght'250,'GRAD' 0,'opsz' 24; margin-right:0.25rem; line-height:1; }
.siblings h4.page-category-title { display:flex; align-items:center; }
.cate_title::before, .siblings h4.page-category-title::before { font-size:2.5rem; }

body.page-id-42 .cate_title::before ,body.parent-pageid-42 .cate_title::before { content:"\f6b9";}
body.page-id-39 .cate_title::before ,body.parent-pageid-39 .cate_title::before { content:"\e0c8";}
.side ul.category > li.highlights > a::before, .hm .sub ul li.highlights a::before, 
body.term-highlights .cate_title::before { content:"\f298"; }
.side ul.category > li.history > a::before, .hm .sub ul li.history a::before, 
body.term-history .cate_title::before, .siblings h4.page-category-title.history::before,
.mean-container .mean-nav .sub li.history a::before { content:"\ea3e"; }
.side ul.category > li.art > a::before, .hm .sub ul li.art a::before, 
body.term-art .cate_title::before, .siblings h4.page-category-title.art::before,
.mean-container .mean-nav .sub li.art a::before { content:"\efcb"; font-variation-settings:'FILL' 0,'wght'250,'GRAD' 0,'opsz' 24; }
.side ul.category > li.nature > a::before, .hm .sub ul li.nature a::before, 
body.term-nature .cate_title::before, .siblings h4.page-category-title.nature::before,
.mean-container .mean-nav .sub li.nature a::before { content:"\ea99";}
.side ul.category > li.eat_shopping > a::before, .hm .sub ul li.eat a::before, 
body.term-eat_shopping .cate_title::before, .siblings h4.page-category-title.eat_shopping::before,
.mean-container .mean-nav .sub li.eat a::before { content:"\f3e4"; }
.side ul.category > li.enjoy > a::before, .hm .sub ul li.enjoy a::before, 
body.term-enjoy .cate_title::before, .siblings h4.page-category-title.enjoy::before,
.mean-container .mean-nav .sub li.enjoy a::before { content:"\e92c";}
.side ul.category > li.stay > a::before, .hm .sub ul li.stay a::before, 
body.term-stay .cate_title::before, .siblings h4.page-category-title.stay::before,
.mean-container .mean-nav .sub li.stay a::before { content:"\e53a";}
.side ul.category > li.season_event > a::before, .hm .sub ul li.season_event a::before,
body.term-season_event .cate_title::before,
.mean-container .mean-nav .sub li.season_event a::before { content:"\e614"; }

.mean-container .mean-nav > ul > li.hm_lang { display:none; }
.mean-container .mean-nav ul li.hm_ig a { background:url(../img/i_ig.svg) left 0.2rem center /1.2rem no-repeat; padding-left:1.75rem;}

body.links .index_box a { padding-left: 1.25rem; position: relative; }
body.links .index_box a[target='_blank']::after { display: inline-block !important; }
body.links .index_box a::before { content:""; position:absolute; display:block; left:0; top:calc(50% - 0.25rem); width:0.5rem; height:0.5rem; margin:0; border-top:1px solid #333; border-right:1px solid #333; transform:rotate(45deg); box-sizing:border-box; }


ul.disc { list-style: disc; padding-left: 1rem; }
ul.disc li { line-height:1.5; padding:0 1rem 0.5rem 0; margin-left:0.25rem; }

.date_box { position:relative; margin:-1.5rem 0 1rem 0; text-align:right; }
.date_box .date { font-size:0.9rem; margin:0 0.5rem 0.5rem 0; }

img.radius { border-radius:clamp(0.5rem,1.6vw,1rem); overflow:hidden; vertical-align: bottom; }
.left_img { position: relative; left:calc(20% - 12vw); width:calc( 100% + 10vw ); }
.right_img { position: relative; right:calc(20% - 12vw); width:calc( 100% + 10vw ); }
.left_img img, .right_img img { width: 100%; }



.i-prev, .i_next { }
.i-next::after { content:""; position:absolute; display:block; left:calc(50% - 6px); top:calc(50% - 4.5px); width:0.5rem; height:0.5rem; margin:0; border-top:1px solid #333; border-right:1px solid #333; transform:rotate(45deg); box-sizing:border-box; }
.i-prev::after { content:""; position:absolute; display:block; left:calc(50% - 3px); top:calc(50% - 4.5px); width:0.5rem; height:0.5rem; margin:0; border-bottom:1px solid #333; border-left:1px solid #333; transform:rotate(45deg); box-sizing:border-box; }

.pager { width:100%; margin:clamp(1.5rem,5vw,3rem) auto; }
.pagenavi { /*text-align:center;*/ }
.pagenavi .page, .pagenavi .prev, .pagenavi .next, .pagenavi .current, .pagenavi .last, .pagenavi .page.s , .pagenavi .page.s:hover { display:inline-block; margin:0 5px; width:40px; height:40px; line-height:38px; background:rgba(0,0,0,0.03); color:#333; letter-spacing:1px; text-align:center; vertical-align:middle; border-radius:2rem; transition-duration:0.5s; transition-property:background-color, color; transition-timing-function:ease, ease; box-sizing:border-box; text-decoration:none; position:relative; }
.pagenavi .page.s { box-shadow:0 3px 0 rgba(0, 0, 0, 0.1); transition-delay:0s; transition-duration:0.25s; }
.pagenavi .prev.disable, .pagenavi .next.disable, .pagenavi .prev.disable:hover, .pagenavi .next.disable:hover { background:rgba(0, 0, 0, 0.03); box-shadow:none; cursor:default; color:#fff; }
.pagenavi .current, .pagenavi .page:hover, .pagenavi .prev:hover, .pagenavi .next:hover, .pagenavi .current:hover, .pagenavi .last:hover { background:#6b8; color:#fff; transition-property:background-color, color; transition-timing-function:ease, ease; }
.pagenavi .next:hover .i-next::after, .pagenavi .next.disable .i-next::after { border-color:#fff; }
.pagenavi .prev:hover .i-prev::after, .pagenavi .prev.disable .i-prev::after { border-color:#fff; }



/*-- FORM/ --*/
form { margin:0; padding:0; border:0; font-size:100%; vertical-align:middle; background:transparent; }
form label { vertical-align:middle; }

select, input, textarea, button { width:auto; max-width:100%; -webkit-appearance:none; vertical-align:middle; position:relative; line-height:1.5; font-size:1.2rem; margin:0 5px 0 0; padding:0.5rem 0.75rem; border:1px solid #666; box-shadow:none; z-index:0; box-sizing:border-box; border-radius: 0.25rem; background: rgba(255,255,255,0.5); }
input[type="text"] { margin:0 0.25rem 0 0; }
input.long { width:100%; margin:0; position:relative; }
button, a.btn, input[type="button"], input[type="submit"] { display:inline-block !important; vertical-align:middle; -webkit-appearance:none; overflow:visible; width:auto; min-width:8rem; line-height:1.6rem; letter-spacing:0.1rem; margin:0.5rem 0.25rem 0.5rem 0; border:none; color:#fff !important; position:relative; text-decoration:none; text-align:center; transition:all .2s; box-sizing:border-box; cursor:pointer; border-radius: 2rem; padding:0.5rem 2rem; background:#6b8 url(../img/i_arrow_rw.svg) left 1rem center /0.75rem no-repeat;}
input::placeholder, textarea::placeholder { color:#777; }

button.b_back, a. z.b_back, input[type="button"].b_back { background:#ddd !important; border:none; color:#333 !important; }
.b_back::after { content:""; position:absolute; display:inline-block; left:10px; top:18px; width:10px; height:10px; border-top:2px solid #333; border-right:2px solid #333; transform:rotate(45deg); box-sizing:border-box; }

button:hover, a.btn:hover, input[type="button"]:hover, input[type="submit"]:hover { text-decoration:none; filter: brightness(85%); color:#fff; }

button[disabled], a.btn[disabled], .button[disabled], input[type="button"][disabled], input[type="submit"][disabled],
button[disabled]:hover, a.btn[disabled]:hover, .button[disabled]:hover, input[type="button"][disabled]:hover, input[type="submit"][disabled]:hover { background:#eee; border:none; color:#fff; opacity:1.0; cursor:default; position:relative; }

a.btn { padding-right:1.5rem; position: relative; }
a.btn[target='_blank']::after { /*right:-1rem; visibility: hidden;*/ }

button.mini, .button.mini { min-width:0; }
input:focus, select:focus, textarea:focus { outline:none; box-shadow:0 0 3px #6b8; border:1px solid #6b8;}

input.button { width:15rem; display:flex; align-items: center; justify-content:center; text-align: center; text-decoration:none; position: relative; white-space: nowrap; margin: 0 auto; padding:0.5rem 2rem; background:#6b8 url("../img/arrow_rw.svg") right 0.75rem center /1.25rem no-repeat; color: #fff; border-radius:0.25rem; }
input.button:hover { background:#6b8 url("../img/arrow_rw.svg") right 0.75rem center /40px no-repeat; }




/*-- Radio and Checkbox/ --*/
input[type="radio"], input[type="checkbox"] { margin:0 0.25rem 0 0; width:1.25rem; height:1.25rem; display:none; }
input[type="radio"] + span, input[type="checkbox"] + span { padding-left:1.5rem; position:relative; margin-right:1rem; display:inline-block; white-space:nowrap; min-height: 1.35rem; }
input[type="radio"] + span::before{ content:""; display:block; position:absolute; top:calc(50% - 0.6rem); left:0; width:1.2rem; height:1.2rem; border:1px solid #333; border-radius:50%; z-index:5; margin-right:0.25rem; box-sizing:border-box; }
input[type="radio"] + span::after{ content:""; display:block; position:absolute; top:calc(50% - 0.1rem);; left:0.5rem ; width:0.2rem; height:0.2rem; background:#6b8; border-radius:50%; z-index:10; transition:0.25s; opacity:0; }
input[type="radio"]:checked + span, input[type="checkbox"]:checked + span { color:#6b8; }
input[type="radio"]:checked + span::before { border:1px solid #6b8; }
input[type="radio"]:checked + span::after{ content:""; display:block; position:absolute; top:calc(50% - 0.4rem); left:calc(0.25rem - 1px); width:0.8rem; height:0.8rem; background:#6b8; border-radius:50%; z-index:10; transition:0.25s; opacity:1; }
input[type="checkbox"] + span::before { content:""; display:block; position:absolute; top:calc(50% - 0.6rem); left:0; width:1.2rem; height:1.2rem; border:1px solid #666; border-radius:0.25rem; margin-right:0.25rem; box-sizing:border-box; }
input[type="checkbox"]:checked + span::after { content:""; display:block; position:absolute; top:calc(50% - 0.9rem); left:0.5rem; width:0.5rem; height:1.2rem; transform:rotate(40deg); border-bottom:2px solid #6b8; border-right:2px solid #6b8; box-sizing:border-box; }

input[type="checkbox"] + span:empty { margin: 0; padding: 0; }

button.i_delete { min-width:0 !important; }
button.i_delete::before { display:none; }

/*-- SELECT/ --*/
select { -webkit-appearance:none; -moz-appearance:none; position:relative; z-index:auto !important; text-align:left; background: rgba(255,255,255,0.5) url(../img/i_pulldown.svg) right center /24px no-repeat; border:1px solid #666; padding:0.25rem 2rem 0.25rem 0.5rem; margin:0 2px 0 0; box-sizing:border-box; display:none; display:inline-block; border-radius: 0.25rem; color:#333;}
select:disabled, select.disabled { border:1px solid rgba(0,0,0,0.2); color:rgba(0,0,0,0.2); color:silver; background:none; z-index:auto; }

/*.error, .required, .alert { color:#d66; }*/
div.error { background:rgba(238,102,102, 0.1); padding:0 0.5rem; margin:0; color:#d66; }
span.error { background:rgba(238,102,102, 0.1); padding:0 0.5rem; color:#d66; display:block; }

td.error input[type="text"], 
td.error textarea,
td.error select,
td.error label { border:1px solid #d66; color:#333; border-radius: 0.25rem; }
td.error label { padding: 0.25rem; }

td.error input:focus, td.error select:focus, td.error textarea:focus { outline:none; box-shadow:0 0 3px rgba(238,102,102, 1); border:1px solid #d66;}

.example { color:#777; white-space:nowrap; }


.hissu { display: inline-block; background:#d66; color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.25rem 0.25rem 0; border-radius: 0.25rem; line-height:1.5; }
.hissu::before { content:"必須";}
.ninni {display: inline-block; background:rgba(34,34,34,0.3); color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.25rem 0.25rem 0; border-radius: 0.25rem; line-height:1.5; }
.ninni::before { content:"任意";}

.notice { background:rgba(0,153,238,0.05); padding: 1rem 1.5rem; }
.notice.red_box { background: rgba(204,51,85,0.05);}
.bg01 .notice { background: #fff; box-shadow:0 1rem 0.5rem -0.75rem rgba(34,34,34,0.05); }
.bg01 .grade { text-shadow: 0 0.5rem 0.5rem rgba(34,34,34,0.05);}


/*--CONTACT--*/
body.contact .tab_menu,
body.contact .f_title,
body.contact .corp { display:none; }

.wpcf7 form .wpcf7-response-output { margin: 1rem 0 0; padding: 0.5rem 1rem; text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output { color: #c35; background-color: #f9e3e9 !important; border:none !important; }
.wpcf7 form.sent .wpcf7-response-output { color: #3A87AD; background-color: #E1F5FE !important; border:none !important; }
.wpcf7 form .wpcf7-not-valid { background:#f9e3e9; }
.wpcf7 form .wpcf7-not-valid-tip { color:#c35; }
.wpcf7 form .wpcf7-spinner { display:block; margin:auto; }
form.wpcf7-form > br:first-of-type { display:none; }
.wpcf7-list-item { margin:0 !important; }
.wpcf7-form-control-wrap { display:inline-block; width:100%;}
.wpcf7-form-control-wrap input, .wpcf7-form-control-wrap textarea { width:100%;}
.button-wrap .back_button.b_back { margin-top:2rem; }

/*--Privacy Policy--*/
.pp_box { text-align: left; max-height:400px; overflow-y: auto; padding: 1.5rem; border:1px solid #333; line-height:1.7; }
.pp_box ol { /*padding-left:1.5rem;*/ }

.grecaptcha-badge { opacity:0; }

.invisible { display: none; transition:0.5s ease; }


.w100 { width: 100%; margin-right:0 !important; margin-left:0 !important; }

.w95 { width: 95%; }
.w90 { width: 90%; }

.w85 { width: 85%; }
.w80 { width: 80%; }

.w75 { width: 75%; }
.w70 { width: 70%; }

.w69 { width: 69%; }
.w68 { width: 68%; }
.w67 { width: 67%; }
.w66 { width: 66%; }
.w65 { width: 65%; }
.w64 { width: 64%; }
.w63 { width: 63%; }
.w62 { width: 62%; }
.w61 { width: 61%; }
.w60 { width: 60%; }

.w59 { width: 59%; }
.w58 { width: 58%; }
.w57 { width: 57%; }
.w56 { width: 56%; }
.w55 { width: 55%; }
.w54 { width: 54%; }
.w53 { width: 53%; }
.w52 { width: 52%; }
.w51 { width: 51%; }
.w50 { width: 50%; }

.w49 { width: 49%; }
.w48 { width: 48%; }
.w47 { width: 47%; }
.w46 { width: 46%; }
.w45 { width: 45%; }
.w44 { width: 44%; }
.w43 { width: 43%; }
.w42 { width: 42%; }
.w41 { width: 41%; }
.w40 { width: 40%; }

.w39 { width: 39%; }
.w38 { width: 38%; }
.w37 { width: 37%; }
.w36 { width: 36%; }
.w35 { width: 35%; }
.w34 { width: 34%; }
.w33 { width: 33%; }
.w32 { width: 32%; }
.w31 { width: 31%; }
.w30 { width: 30%; }

.w29 { width: 29%; }
.w28 { width: 28%; }
.w27 { width: 27%; }
.w26 { width: 26%; }
.w25 { width: 25%; }
.w24 { width: 24%; }
.w23 { width: 23%; }
.w22 { width: 22%; }
.w21 { width: 21%; }
.w20 { width: 20%; }

.w19 { width: 19%; }
.w18 { width: 18%; }
.w17 { width: 17%; }
.w16 { width: 16%; }
.w15 { width: 15%; }
.w14 { width: 14%; }
.w13 { width: 13%; }
.w12 { width: 12%; }
.w11 { width: 11%; }
.w10 { width: 10%; }

.w9 { width: 9%; }
.w8 { width: 8%; }
.w7 { width: 7%; }
.w6 { width: 6%; }
.w5 { width: 5%; }
.w4 { width: 4%; }
.w3 { width: 3%; }
.w2 { width: 2%; }
.w1 { width: 1%; }
.w0 { width: 0%; }


input.w75 { min-width:15rem; }
input.w50 { min-width:10rem; }
input.w33 { min-width:6.5rem; }
input.w25 { min-width:5rem; }
input.w20 { min-width:4rem; }
input.w10 { min-width:2rem; }
input.w5 { min-width:1rem; }


.r04 { border-radius:0.25rem; }
.r08 { border-radius:0.5rem; }
.r16 { border-radius:1rem; }



/*-- LIST/ --*/
ol { margin:0 0 2rem 0; padding:0 0 0 1.5rem; }
ol::marker { }
ol li{ padding:0; }
.value { background:#333; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; font-size:1rem; font-weight:bolder; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 0; }
ol li ol.kakko { }
ol li ol.kakko li { list-style: none; position: relative; margin-left: 1.5rem; }
ol li ol.kakko li::before { content: attr(value)')'; counter-increment: li; position: absolute; top: 0; left: -1.5rem; }

ul li::marker { color:#6b8; } 

ul.marker { list-style:disc; margin:0; padding-left:1rem; }
ul.marker li::marker { color:rgba(34,34,34, 0.3); }

ul.li_half { display:flex; flex-flow:row wrap; justify-content:space-between; }
ul.li_half li { width:calc((100% - 2rem)/2);}

ol.faq { counter-reset:q; list-style:none; margin:0; padding:0; }
ol.faq >li::before { counter-increment:q; content:'Q'counter(q); content:'Q'attr(value); background:#f77; vertical-align:middle; display:inline-block; width:2.4rem; height:2.4rem; line-height:2.2rem; font-weight:bold; text-align:center; border-radius:50%; color:#fff; margin:0 0.4rem 0 -2.4rem; }
ol.faq >li { margin-bottom:1rem; }
ol.faq .a { padding:0.5rem 0 0.5rem 0.4rem; }
ol.faq .a h4 { display:inline-block; width:2.4rem; height:2.4rem; line-height:2.2rem; font-weight:bold; text-align:center; border-radius:50%; margin:0 0.4rem 0 -2.8rem; }
ol.faq li ol { display:inline-block; vertical-align:top; }
ol.faq >li h6.i_close { color:#e70; }

ol.val > li::before { content:attr(value); background:#001A43; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; letter-spacing:normal; font-size:0.8rem; font-weight:bold; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 -2rem; position:relative; }

ul.kome { list-style: none; padding:0; }
ul.kome li { display: block; margin-left:1rem; }
ul.kome li::before { content:"※"; margin:0 0 0 -1rem; }

.q, .q_open { margin:0; padding:0.5rem 2rem 0.5rem 0; position:relative; border-top: 1px solid rgba(0, 0, 0, 0.1); cursor: pointer; }
.q_open { padding:0.25rem; }
.q:hover { background: rgba(255,255,255,0.2); }
.q::before, .q_open::before { content:"Q. "; display:inline-block; font-weight:bold; margin-right:0.25rem; color:#0ae; }
.q::after { content:"＋"; position:absolute; right:0.5rem; display:inline-block; transition:0.1s; font-size:clamp(0.9rem, 1.8vw,1.125rem); top:1rem; line-height:1; color:#f4577a;}
.q.i_close { font-weight: bold; color:#0ae; }
.m.i_close { font-weight: bold; background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(237,96,174,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.a, .a_open, .t, .t_open { display: none; margin-bottom: 1.5rem; padding:0.25rem 0; }
.a_open, .t_open { display: block; }
.a::before, .a_open::before { content:"A. "; display:inline-block; font-weight:bold; margin-right:0.25rem; color:#f4577a; font-size:1.2rem; }

.m, .m_open { margin:0; padding:0.5rem 0.5rem 0.5rem 1rem; position:relative; cursor: pointer; font-size:clamp(0.9rem, 1.8vw,1.125rem); line-height:1.5; font-weight: bold; }
.m::after { content:"＋"; position:absolute; top:calc(50% - 0.6rem); left:-0.25rem; display:inline-block; transition:0.1s; font-size:clamp(0.9rem, 1.8vw,1.125rem); line-height:1; color:#f4577a; z-index: 10;}
.q.i_close::after, .m.i_close::after { transform:rotate(45deg); -webkit-text-fill-color:#f4577a; }
.m.link { padding:0.25rem 1rem; }
.m + .t { padding:0.25rem 0; }
.m.no_open { color:rgba(34,34,34,0.5); pointer-events:none; }


/*-- TABLE/ --*/
caption { text-align:left; margin-bottom:10px; }

table { border-collapse:collapse; width:100%; margin:0 0 2rem 0; }
table th, table td { padding:clamp(0.5rem, 1.6vw, 1rem); letter-spacing:0.05rem; line-height:1.6; vertical-align:top; }

.table01 { border-bottom:1px dashed rgba(0, 38, 33, 0.1); }
.table01 th, .table01 td { border-top:1px dashed rgba(0,0,0,0.1); }
.table01 thead th { }
.table01 th {text-align:left; }
.table01 td { }

.table02 { border-bottom:1px solid rgba(0,0,0,0.15); }
.table02 th, .table02 td { border-top:1px solid rgba(0,0,0,0.15); }
.table02 thead th, .table02 thead td, .deco-tb thead th, .deco-tb thead td { background:rgba(255,255,255,0.05); }
.table02 th { text-align:left; background:rgba(255,255,255,0.05); vertical-align:top; font-weight:normal; }
.table02 td { }
.table02 th.tr, .table02 td.tr { width:auto; text-align: right;}

.table03 { background:rgba(255,255,255,0.5); border-spacing: 0; border:1px solid rgba(0,0,0,0.1); }
.table03 th, .table03 td { border-right:1px dashed rgba(0,0,0,0.1); border-bottom:1px solid rgba(0,0,0,0.1); vertical-align: top; }
.table03 thead th { background:rgba(0,0,0,0.05); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table03 thead td { background:rgba(0,0,0,0.05); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table03 tbody tr:last-of-type th, .table03 tbody tr:last-of-type td { border-bottom: none; }
.table03 tbody th { text-align:left; border:1px solid #ddd; background:rgba(0,153,238,0.05); color:#333; }
.table03 tbody td { border:1px solid #ddd; letter-spacing:normal; }

.table03 th.vm, .table03 td.vm, .table03 tr.vm th, .table03 tr.vm td { vertical-align: middle; }



/*-- TABLE ヘッダ・カラム固定 --*/
thead tr[class*="fixed-header-"] th { position:sticky; z-index:2; white-space: nowrap; border:1px solid #ddd; }
thead tr[class*="fixed-header-"] th[class*="fixed-column-"] { z-index:3; }
tbody th[class*="fixed-column-"], tbody td[class*="fixed-column-"] { background:#fff; position: -webkit-sticky; position: sticky; z-index:1; border:1px solid #ddd; }

table.number {}
table.number td { text-align: right; }

.l_double { border-top:3px double rgba(0,0,0,0.1) !important; }
.l_dashed th, .l_dashed td { border-top:1px dashed rgba(0,0,0,0.1) !important; }
th p, td p { /*margin:0;*/ }

.l_total th, .l_total td { padding:1px; }

table.fixed_column { background:#fff; }
.fixed01{ position: sticky; left: 0; background: rgba(255,255,255,0.95); border-collapse:separate; }
.fixed01:before{ content: ""; position: absolute; top: -1px; left: -1px; width:calc(100% + 2px); height:100%; border-top:1px solid rgba(0,0,0,0.1); border-left:1px solid rgba(0,0,0,0.1); border-right:1px dashed #e5e5e5; }
tr.l_double th.fixed01 { border-top:3px double rgba(0,0,0,0.1) !important; }
.table02 thead th.fixed01, .table03 thead th.fixed01 { background:#f2faf5; }


/*-- 幅の広いテーブルにスクロール表示 --*/
.scroll { overflow:auto; max-width:calc(100vw - 2rem); position: relative; }
.scroll::-webkit-scrollbar { height:6px;}
.scroll::-webkit-scrollbar-track { background:rgba(0,0,0,0); }
.scroll::-webkit-scrollbar-thumb { background:rgba(34,34,34,1); background: #bbb; border-radius:3px; opacity: 0.5; }
.scroll::-webkit-scrollbar-thumb:hover { background:rgba(34,34,34,1); background: #bbb; border-radius:3px; opacity: 0.5; }

.scroll table th, .scroll table td { /*white-space:nowrap;*/ }
/*.scroll::before { content:"→ 横スクロールしてご確認ください。"; display: block; font-size:0.8rem; margin-bottom:0.5rem;}*/


.aligncenter {display:block; margin:0 auto; }
.alignright { float:right; margin:0 0 1.5rem 1.5rem; position:relative; z-index:1; max-width:48%; }
.alignleft { float:left; margin:0 1.5rem 1.5rem 0; position:relative; z-index:1; max-width:48%; }
img[class*="wp-image-"],
img[class*="attachment-"] { max-width:100%; height:auto; }
img.alignright, img.alignleft { max-width:48%; }


.flex.full_l .text { width:56%; order:2; }
.flex.full_r .text { width:56%; order:1; }
.flex.full_l .photo { width:40%; order:1; position:relative; }
.flex.full_r .photo { width:40%; order:2; position:relative; }



#colorbox.teacher { width:100% !important; height:100% !important; max-width:58rem !important; min-height:300px; max-height: 85vh !important; top:50% !important; left: 50% !important; transform: translate(-50%,-50%); }
#colorbox.teacher #cboxWrapper { width:100% !important; height:100% !important; max-width:58rem !important; min-height:300px; max-height: 85vh !important; overflow: visible; }
#colorbox.teacher #cboxContent, #colorbox.alert #cboxLoadedContent, #colorbox.alert #cboxIframe { height:calc(100% - 3rem) !important; max-width:56rem !important; ; min-height:calc(300px - 3rem); max-height:calc(85vh - 3rem) !important; }
#colorbox.teacher #cboxContent { width:calc(100% - 2rem) !important; }
#colorbox.teacher #cboxLoadedContent, #colorbox.alert #cboxIframe { width:100% !important; margin: 0; height:calc(85vh - 3rem) !important; min-height:calc(300px - 3rem); max-height:calc(85vh - 3rem) !important; }
#colorbox.teacher #cboxMiddleLeft { height: 0 !important; }

#colorbox.img #cboxLoadedContent { padding: 1rem; background:#fff; height: auto !important; max-width:96vw; }
#colorbox.img #cboxLoadedContent img { width: 100% !important; height: auto !important; }

body.modal { border: none; }
body.modal .article { padding:1.5rem; display: block; }
body.modal .alignright { float: right; width:25vw; }
body.modal .text_area { padding:5vw; margin: 0 auto; }
body.modal h2 { line-height: 1.5; }
body.modal h2::after { display:none; }
body.modal h2 span.title { display: block; font-size: 1rem; margin-bottom:0.75rem; }
body.modal h2 rt { font-size: 0.75rem; margin-bottom:0.15rem }



/*--PAGENATION--*/
.pagination-holder { margin:0 auto 4rem auto; }

#page-1 { display:flex; }
.cnation-holder { width:100%; padding-top:4rem; }
.simple-pagination { display: block; overflow: hidden; padding: 0; margin: 0;}
.simple-pagination ul { list-style: none; padding:0; margin:0; display:flex; flex-flow:row wrap; justify-content:center;}
.simple-pagination ul li { padding:0.25rem; margin:0;}
.simple-pagination ul li a { display:block; background:#fff; }
span.ellipse.clickable { cursor: pointer; }
.ellipse input { width: 3em; }

.light-theme a, .light-theme span { cursor:pointer; display:block; text-align:center; color: #333; font-size:0.9rem; line-height:calc(2.5rem - 2px); font-weight: normal; letter-spacing:normal; border:1px solid #333; min-width: 2.5rem; height:2.5rem; padding:0 0.5rem; margin: 0; background:#fff; }
.light-theme a:hover, .light-theme li:not(.disabled):not(.active) span:hover { text-decoration: none; background: #FCFCFC; }
.light-theme .current { background: #333; color: #FFF; border-color: #333; cursor: default; }
.light-theme .ellipse { background: none; border: none; box-shadow: none; font-weight: bold; cursor: default; }
.light-theme .prev, .light-theme .next { background:#fff; padding: 0 0.75rem; color: #333; }
.light-theme .prev { border-radius: 2rem 0 0 2rem; }
.light-theme .next { border-radius: 0 2rem 2rem 0; }
.light-theme .disabled .prev, .light-theme .disabled .next { opacity:0.25; }


.bg01 { position: relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:100%; padding:0; right:0; }




.note { /*background: #eef5e7;*/ background: rgba(0,136,102,0.05); padding:1rem; }
.bg_blue { background: rgba(30,80,162,0.2); }
.bg_orange { background: rgba(241,141,95,0.2); }
.bg_red { background: rgba(190,52,85,0.2); }


noprint { pointer-events: none; }


video { vertical-align: bottom; }


.site_preview { background: rgba(99,85,161,0.15); padding:1.5rem 1rem; justify-content: space-around; margin: 0 -1.5rem; }
.site_preview div { border-radius:clamp(0.5rem, 1.6vw, 1rem); overflow: hidden; }



.greeting_photo { max-width:15rem;}

/*流れ*/
ul.flow_box {}
ul.flow_box > li { display: flex; flex-flow: row wrap; align-items: flex-start; position: relative; padding-left: 2rem; padding-bottom:2rem; }
ul.flow_box > li::after { content: ""; height:100%; position: absolute; left:calc(0.75rem - 2px); top:0.5rem; border-left: 4px dotted rgba(255,190,0,0.3); z-index: 1; }
ul.flow_box > li h4 { }
ul.flow_box > li::before { content: ""; width: 1.5rem; height: 1.5rem; position: absolute; left:0; top:0.4rem; border-radius: 4rem; background:#6b8; z-index: 10; }
ul.flow_box > li .w70, ul.flow_box > li .w75, ul.flow_box > li .w80 {  padding-bottom:clamp(1rem,3vw,2rem); border-bottom:1px dashed #ccd; }
ul.flow_box > li:last-of-type::after { display: none; }



/*イメージビューワー*/
.smartphoto { z-index:100000; background:none; }
.smartphoto::after { content:""; display:block; position:fixed; top:0; left:0; z-index:-99999; width:100%; height:100vh; background:rgba(0,0,0,0.85) }
.smartphoto-header { padding:0.5rem; height:4rem; background:none; }
.smartphoto-caption { top:0.5rem; font-size:1rem; line-height:3rem; }
.smartphoto-count{ font-size:0.8125rem; line-height:3rem; padding:0 0.5rem; }
.smartphoto-dismiss { top:0; min-width:3rem; width:3rem; height:3rem; right:0; }
.smartphoto-arrow-right, .smartphoto-arrow-left { background:none; }

#wpadminbar #adminbarsearch { display:none !important;}


/*MAP埋め込み、インスタ埋め込み*/
.map-embed iframe, .instagram-embed iframe { width:100% !important; min-width:100px !important; margin:auto !important; }
.side .instagram-embed { max-width:16rem;}
.map-embed, .instagram-embed { width:100%; margin-bottom:2rem; overflow-x:hidden; position:relative; }

ul.slick-dots { display:flex; justify-content:center;}
ul.slick-dots li { opacity:0.5; padding:0.25rem; }
ul.slick-dots li button { min-width:0.5rem; width:0.75rem; height:0.75rem;border-radius: 1rem;overflow:hidden; padding:0; text-indent:-5rem; font-size:0.5rem; color:#6b8; margin:0;}
ul.slick-dots li.slick-active { opacity:1;}


body.parent-pageid-39 .comment_box { font-size:clamp(1rem,2.5vw,1.5rem); margin-bottom:clamp(0.5rem,1.6vw,1rem); }


/*Googleレビュー 星表示*/

.google_reviw_box { display:none;}
body.parent-pageid-39 .google_reviw_box { display:block; }
body.parent-pageid-39.page-category-season_event .google_reviw_box { display:none;}

h5.google_reviw { background:url(../img/google_g_icon.png) left -0.25rem center /2.5rem no-repeat; padding-left:2.5rem; min-height:2.5rem; display:flex; align-items:center; margin-bottom:0; }
.google-rating-box .stars { --rate: 0; font-size:2rem; letter-spacing: 2px; }
.google-rating-box .stars::before { content: "★★★★★"; background: linear-gradient( 90deg, #fb0 calc(var(--rate) / 5 * 100%), #ddd calc(var(--rate) / 5 * 100%)); -webkit-background-clip: text; -webkit-text-fill-color: transparent;}
.google-rating-box .rate { font-size:2rem; line-height:1; }

.google-rating-box　.rating-bars { margin-top: .5em; font-size: 13px;}
.google-rating-box　.bar-row { display: flex;align-items: center; margin-bottom: 2px;}
.google-rating-box　.bar-row .label { width: 2em;}
.google-rating-box　.bar-row .bar { flex: 1; height: 6px; background: #eee; margin: 0.5rem; position: relative; }


/*ふるさと納税 index_box*/
.index_box#post-2165 { display:none;}


/*イベントカレンダー*/
.event_slick { position:relative; }
.event_slick .slick-list { margin:0 clamp(-1rem,-1.6vw,-0.5rem); }
.event_slick .slick-slide { margin:0 clamp(0.5rem,1.6vw,1rem) 1rem clamp(0.5rem,1.6vw,1rem); line-height:1.5; }
.event_slick button.slick-prev, .event_slick button.slick-next { height:3rem; width:3rem; min-width:3rem; padding:0.5rem; position:absolute; z-index:1000; }
.event_slick button.slick-prev { background: #6b8 url(../img/i_arrow_lw.svg) center center /0.75rem no-repeat; left:-1.5rem; top:clamp(2.5rem,6vw,4rem);  }
.event_slick button.slick-next { background: #6b8 url(../img/i_arrow_rw.svg) center center /0.75rem no-repeat; right:-1.5rem; top:clamp(2.5rem,6vw,4rem);  }
.event_slick .photo { border-radius: 0.75rem; overflow: hidden; margin-bottom:0.5rem; }
.event_slick .slick-slide .photo { aspect-ratio:3/2; position:relative; }
.event_slick .slick-slide .photo img { width:100%; height:100%; object-fit:cover; }
.event_slick .slick-slide .title { font-size:clamp(1rem,1.8vw,1.125rem); display:block; align-items:flex-start; position: relative; color:#333; line-height:1.5; font-weight:normal; flex-grow:1; font-weight:600; font-family: "Zen Old Mincho", serif; }
.event_slick .slick-slide a.route { display:inline-block; background:#6b8; color:#fff; border-radius:2rem; padding:0 clamp(0.5rem,1.2vw,0.75rem) 0 clamp(0.25rem,0.8vw,0.5rem); margin-right:clamp(0.25rem,0.8vw,0.5rem); border:1px solid #6b8; font-size:clamp(0.75rem,1.4vw,0.8125rem); text-decoration:none; letter-spacing:normal; line-height:2; margin-top:0.5rem;}


.season_tag { position:absolute; top:0; left:0; background:#fff; padding:0.25rem; z-index:10; }


/*eBook*/
html:not([lang^="ja"]) .b_ebook { display: none; }


@media screen and (max-width:1200px) {
/*body.page-spot .index_box { width:calc((100% - clamp(1rem,4vw,2.5rem)*2)/3); }*/
}

@media screen and (max-width:960px) {

	
/*.b_box_slick { display:none;}*/
 	
.pc_no { display:block; }
br.pc_no, span.pc_no { display:inline; }
.sp_no, br.sp_no { display:none; }
span.sp_no { display:none; }
	
.img_pc { display:none; }
.img_sp { display:block; }

.anchor { height:clamp(6rem,12vw,8rem); margin-top:clamp(-8rem,-12vw,-6rem); }
body.logged-in .anchor {  height:calc(clamp(6rem,12vw,8rem) + 32px); margin-top:calc(clamp(-8rem,-12vw,-6rem) - 32px);}	
.sticky { top:clamp(6rem,12vw,8rem); }
body.logged-in .sticky { top:calc(clamp(6rem,12vw,8rem) + 32px);}

.article { padding:0 1.5rem; }


.header { padding:0.75rem; }
.header.bg { /*background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(255,255,255,1) 90%,rgba(255,255,255,0) 100%);*/ }
.header.bg::before, body.temp .header.bg::before { display:none; }
.header .tel { display: none; }

.hm { display:none; }
.um, body.logged-in .um { top:auto; bottom:0; left:0; right:0; background:#fff; box-shadow: 0 -1rem 0.5rem -0.75rem rgba(0,0,0,0.05);}
.um > ul { /*justify-content:flex-end;*/ padding:0.6rem 2rem 0.6rem 4rem; }
.um > ul > li > a { padding:0.75rem;}
.um > ul > li.um_access > a, .um > ul > li.um_contact > a { padding:0.5rem; }
.um > ul > li > a .material-symbols-outlined { display:block; margin:0; font-size:1.6rem; }
.um > ul > li > a .text { display:none; }

.lang_sp{ display:block; position:fixed; right:3.5rem; top:0; z-index:1000 }
.lang_sp select { width:4rem; height:4rem; border:none; background:url(../img/i_lang_w.svg) top 0.5rem center /2rem no-repeat; padding:1.7rem 0 0 0; color:#fff; font-size:11px; text-align:center; text-align-last:center; }
/*.lang_sp::after { content:"LANGUAGE"; color:#fff; display:block; width:100%; font-size:10px; text-align:center; position:absolute; line-height: 1.25; bottom:1rem; left:0; font-weight:500; }*/
.lang_sp select:focus { border:none; outline-style:none; box-shadow:none; }
.lang_sp select option, .lang_sp option { font-size:1rem !important; }
body.logged-in .lang_sp{ top:32px; }
html.bg .lang_sp select, body.temp .lang_sp select { background:url(../img/i_lang.svg) top 0.5rem center /2rem no-repeat; color:#333; text-align:center; }
	
.sp_contact { display:flex;}

/*--MAIN--*/
.main { height:100vw; border-radius:0 0 1rem 1rem; }
.main .inner { width:100vw; height:100vw; max-height:100vw; position:relative; }
.main .news_box { display:none; }
	
/*--SCROLLNAVI--*/
.scrollnav > li a:hover { margin-left: 0; background: none; padding-left: 2rem; }
.section .w85 { margin-bottom:0;}


.purpose_box ul li { width:30%; }
.purpose_box ul { gap:5%; row-gap:0; }

/*--ABOUT/--*/
.about_box { margin-top:0;}
.about_box::before { right:0; }

.about_box .photo { margin-right:0;  }
.about_box .photo img { margin-right:0; }
.about_box .text { position:relative; z-index:10;  }


.tab_content#highlights .index_area, .tab_content#ranking .index_area, .news_box .index_area { display:grid; grid-template-areas: "block1 block1" "block2 block3" "block4 block5"; grid-template-columns: repeat(2,1fr);  }
.tab_content#highlights .index_area .index_box:first-of-type .photo, .tab_content#ranking .index_area .index_box:first-of-type .photo, .news_box .index_area .index_box:first-of-type .photo { aspect-ratio:3/2; }

	
	
/*--cyclestation_box--*/
.cyclestation_box .photo { width:100vw; margin:0 -1.5rem; aspect-ratio:3/2; overflow:hidden; position:relative; border-radius:0; }
.cyclestation_box .text { width:100%; max-width:30rem; left:0; right:0; margin:auto; position:relative; top:-4rem; transform:translate(0,0); }


/*--IJU_TEIJU--*/
.iju_box { margin:0 -1.5rem; align-items:center; border-radius:0; }


/*--BANNER--*/
.b_box div { width:49%; }


/*--FOOTER--*/
.footer { flex-flow: row wrap; }
.footer .title { margin-top: 0; }
.footer .address_box { width: 100%; }



ul.page-link { /*padding:0.5rem 0;*/ }
ul.page-link.bg { top:4rem; padding-right:0; }
ul.page-link li a { }
ul.page-link li a::before { top:0.8rem; }

ul.sub_list li { display: inline-block; }

/*--INFO--*/
body.news .text_area, body.news .index_area, body.news .side { width:100%; position: relative; margin:0;}
body.news .side { width:100%; margin:0 auto; border-top:1px solid rgba(34, 34, 34, 0.1); padding-top:1rem; }


h3.page_title + .date { margin-top: -1rem; } 


.left_img { position: relative; left:10%; width:80%; }


/*-- INDEX --*/
ul.index_area { }
body.page ul.index_area { }

.index_box, body.page-spot .index_box, body.page-ranking .index_area .index_box:nth-of-type(n+7) { width:calc((100% - clamp(1rem,4vw,2.5rem))/2); }
.index_box .tag { display:flex; flex-flow:row wrap; justify-content:flex-end; padding:1rem 1rem 1rem 0.5rem; }
.index_box .tag span { background:#333; color:#fff; padding:0 0.25rem 0 0.45rem; margin-left:0.5rem; text-align:center; line-height:1.8; }


/*
body.news .index_box, body.event .index_box { width:100%; padding:0; }
body.news .index_box a, body.event .index_box a { padding: 1rem 0; }
body.news .index_box .photo, body.event .index_box .photo { width:25vw; max-width:120px; margin-right:0.75rem; }
*/
body.links .index_box { width:100%; }


a.link::before, a span.link::before { top:0.6rem; }
.f_s a.link::before, .f_s a span.link::before { top:0.5rem; }
h5 a.link::before { top:0.7rem; }


.col2 { column-count:1; }
.col3 { column-count:2; }
.col4 { column-count:3; }
.resp_col2, .check_list.col2 { column-count:2 !important; }


/*WordPress*/
.aligncenter { display:block;margin: 0 auto; text-align: center; max-width:100%; }
.alignright { float:none; margin:0 auto 1rem auto; max-width:100%; }
.alignleft { float:none; margin:0 auto 1rem auto; max-width:100%; }
img[class*="wp-image-"],
img[class*="attachment-"] { max-width: 100%; height: auto; }
img.alignright, img.alignleft, .alignright img, .alignleft img { width:100%; max-width:100%; }
.alignright img, .alignleft img { margin: auto; }


.resp100 { width:100% !important; }
.resp95 { width:95% !important; }
.resp90 { width:90% !important; }
.resp85 { width:85% !important; }
.resp80 { width:80% !important; }
.resp75 { width:75% !important; }
.resp70 { width:70% !important; }
.resp65 { width:65% !important; }
.resp60 { width:60% !important; }
.resp55 { width:55% !important; }
.resp50 { width:50% !important; }
.resp48 { width:48% !important; }
.resp47 { width:47% !important; }
.resp45 { width:45% !important; }
.resp40 { width:40% !important; }
.resp35 { width:35% !important; }
.resp30 { width:30% !important; }
.resp25 { width:25% !important; }
.resp20 { width:20% !important; }
.resp15 { width:15% !important; }
.resp10 { width:10% !important; }

.resp66 { width:66.6% !important; }
.resp33 { width:33.3% !important; }
.resp49 { width:49% !important; }
.resp32 { width:32% !important; }

.resp_no { display: none; }
.resp_ma { margin:auto !important; }
.resp_column { flex-flow: column wrap; }

a.link, a span.link { padding:0.1rem 0.15rem 0.1rem 0.8rem;}

.m.link { padding:0.25rem 0 0.25rem 0.8rem; }


.notice { padding: 1rem; }



.table01:not(.noresp) th, .table02:not(.noresp) th,
.deco-tb:not(.noresp) th { display:inline-block; width:100%; padding:1rem 0 0 0; background:none; }
.table01:not(.noresp) td, .table02:not(.noresp) td,
.deco-tb:not(.noresp) td { display:inline-block; width:100%; border-top:none; padding:0.5rem 0; }

.deco-tb.noresp th, .deco-tb.noresp td { display: table-cell; width: auto; }

.scroll::before { content:"→ 横スクロールしてご確認ください。"; display: block; font-size:0.8rem; margin-bottom:0.5rem; }

.graph_box.drinking_scene img { width:1000px; min-width:1000px; margin-top:0.5rem; margin-bottom:1rem; }


body.modal .w25.resp50.resp_ma { width:25% !important; margin:0 !important; }
body.modal .w70.resp100 { width:70% !important; }

}



@media screen and (max-width:782px) {
body.logged-in .header { top:46px; }
body.logged-in .anchor { top:calc(clamp(6rem,12vw,-8rem) + 46px); }
body.logged-in .sticky { top:calc(clamp(6rem,12vw,-8rem) + 46px); }
body.logged-in .lang_sp { top:46px; }

}



@media screen and (max-width:640px) {

br.sp_no2 { display:none; }
br.pc_no2 { display:inline; }
span.pc_no2 { display:block; }


.main .corner { display:none; }
.main .news_box { position:relative; bottom:auto; right:0; background:#fff; width:100%; padding:1.5rem 0 0 0; border-radius: 1.5rem 0 0 0; margin:0; display:none;  }
.anchor#top_news { display:none; }
	
/*--ABOUT--*/
.about_box { flex-flow: column wrap;  }
.about_box .text { width:100% !important; order:1; }
.about_box .photo { width:100% !important; order:2; margin-bottom: 1.5rem; }


.copyright { position: relative; padding-top:1rem; }

table th, table td { padding:0.75rem 0.3rem; }





.LR_box { width:100% !important; padding:0 0 1rem 0 ; }
.LCR_box, .LCR_box2 { width:100% !important; padding:0 0 2rem 0; margin:0; overflow:visible !important; }



.flex.full_r .text, .flex.full_l .text { width:100%;}
.flex.full_r, .flex.full_l { display: block; }
.flex.full_l .photo { width:60%; margin:0 auto 1rem auto; }
.flex.full_r .photo { width:60%; margin:0 auto 1rem auto; }

.flex.noresp .w32 { width:32%; }
.flex.noresp .w49 { width:49%; }
.flex.noresp .w50 { width:50%; }
.flex.noresp .w66 { width:66%; }

body.modal .w25.resp50.resp_ma { width:50% !important; margin: auto !important; }
body.modal .w70.resp100 { width:100% !important; }

.col2 { column-count:1; }
.col3 { column-count:1; }
.col4 { column-count:2; }
}


@media screen and (max-width:600px) {
#wpadminbar { position:fixed !important; }

/*--MAIN./--*/
.main { background:none; }
.main .copy { margin-right:2rem; display:none; }
.main .copy_box { padding-left:0; }
.main .copy_box .caption { padding:1rem 2%;}
.main .copy_sp { display:block; writing-mode: vertical-rl; position:absolute; right:3%; bottom:2%; text-align:right; }
.main .copy_sp span { background: linear-gradient(to bottom, rgba(255,190,0,0.2) 0%,rgba(255,115,68,0.2) 100%) left /40% 100% no-repeat; text-shadow:1px 1px 0 rgba(252,255,2555,0.9);}
}


@media screen and (max-width:480px) {
.section, body.temp .article > .inner { justify-content:space-between;}

br.sp_no2, .sp_no2 { display:none; }
	
.col2 { column-count:1; }
.col3 { column-count:1; }
.col4 { column-count:1; }
}

@media screen and (max-width:400px) {
.section .title_box, body.temp .article > .inner .w10  { margin-left:-2.5%; }	
}



@media print {
body { background: none; }
.fadeinUp_once, .fadeinDown_once { opacity: 1; transform: translate(0, 0); }
.main { margin: 0; }
.info_area { }
.noprint { display: none; }
.header { display: none; }
.text_area { width: 100%; max-width: 100%; }
.mean-bar { display: none; }
.article { padding: 0; }
h2.page_title::after { display: none; }

}




.step {
      position: relative;
      padding-bottom: 40px;
      counter-increment: step-index;
    }
/* 全体設定 */
    .container_cose {
      width: min(100%, 760px);
      padding: 40px 0;
      counter-reset: step-index;
    }

    .step:not(:last-child)::before {
      position: absolute;
      /* 円の中心(50pxの半分)から線を開始 */
      top: 25px; 
      left: 23.5px; /* (50px / 2) - (3px / 2) = 23.5px で中央配置 */
      width: 3px;
      height: 100%; /* 次の要素の円の開始位置まで到達 */
      content: "";
      background-color: rgba(17, 34, 85, 0.2);
      z-index: 0;
    }

    .step-title {
      display: grid;
      grid-template-columns: 50px 1fr;
      gap: 20px;
      align-items: center;
      font-size: 1.5rem; /* レスポンシブな単位に変更 */
      font-weight: bold;
      color: #3b4252;
      margin-bottom: 10px;
      letter-spacing:normal;
    }

    .step-title::before {
      z-index: 1;
      display: grid;
      place-items: center;
      width: 50px;
      height: 50px;
      font-size: 18px;
      font-weight: bold;
      color: #fff;
      content: counter(step-index);
      background-color: #6b8;
      border-radius: 50%;
    }

    .step-text {
      /* 円の幅(50px) + gap(20px) + 微調整(3px) */
      padding-left: 73px;
      font-size: 1rem;
      line-height: 1.6;
      color: #4c566a;
      margin: 0 0 10px 0;
      letter-spacing: 0.04rem;
    }

    .step-text .material-symbols-outlined { font-size:24px; margin:0 0.25rem 0 0; }

    /* 画像のレスポンシブ対応 */
    .step-text img {
      max-width: 100%;
      height: auto;
      border-radius: 8px;
      display: block;
    }

    /* スマホ向け微調整 */
    @media (max-width: 480px) {
      .step-title {
        font-size: 1.2rem;
        gap: 15px;
      }
      .step-text {
        padding-left: 55px; /* gapが狭まった分調整 */
        font-size: 0.95rem;
      }
    }
	  .step-text span{
		  vertical-align: middle;
		  padding-bottom: 5px;
		  color: #6b8;
		  margin-right:5px;
	  }
 .samhero-area {
    position: relative;
    height: 600px;
background-image:
    url(/wp/wp-content/uploads/2025/12/p_cycling01.webp);
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
    overflow: hidden;
} 
/* 親要素（aタグ）の設定 */
.course-card {
    position: relative;
    display: block;
    overflow: hidden; 
}

/* 画像の上に重ねるブラウンのフィルター */
.course-card::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* さきほどのメインエリアと同じ色味を設定 
    background-color: rgba(80, 50, 20, 0.4); */
    z-index: 1; /* 画像(0)とテキスト(2)の間に配置 */
    transition: background-color 0.3s; /* マウスを乗せた時の変化を滑らかにする（任意） */
}
 
/* テキストを中央に配置する設定 */
.centered-text {
    /* 配置の指定 */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* 自身の幅・高さの半分だけ戻して真ん中へ */

    width: 100%;   
    margin: 0;
    padding: 10px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-shadow: 1px 1px 4px rgba(0,0,0,0.6); /* 読みやすくするための影 */
    z-index: 2;
}
 
.course-card img {
    display: block;
    width: 100%;
    height: auto;
}
 
@media screen and (max-width: 600px) {
.samhero-area {height: 300px;}
.samhero-content h2{text-align: center;}
.centered-text{line-height: 1.1;}
 }
blockquote {
    position: relative;
    padding: 30px 15px 8px 15px;
    box-sizing: border-box;
    font-style: italic;
    background: #efefef;
    color: #555;
}
blockquote:before{
    display: inline-block;
    position: absolute;
    top: 5px;
    left: 3px;
    content: "“";
    font-family: sans-serif;
    color: #cfcfcf;
    font-size: 90px;
    line-height: 1;
}
blockquote p {
    padding: 0;
    margin: 10px 0;
    line-height: 1.7;
}

blockquote cite {
    display: block;
    text-align: right;
    color: #888888;
    font-size: 0.9em;
}
