@charset "UTF-8";
/* ================================================
reset
================================================ */
* { -webkit-box-sizing: border-box; box-sizing: border-box;}
*::before, *::after { -webkit-box-sizing: border-box; box-sizing: border-box;}
html { -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent;}
html::-webkit-scrollbar { width: 1px;}
html::-webkit-scrollbar-thumb { background: #fff;}
body, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li { margin: 0; padding: 0; font-size: inherit;}
header, nav, footer, section { display: block;}
a { color: inherit; text-decoration: none; /* -webkit-transition: .2s; transition: .2s; */}
img { border: 0; width: 100%; max-width: 100%; height: auto; vertical-align: middle;}

/* ================================================
rem
================================================ */
html { font-size: 625%;}
@media (min-width: 751px) and (max-width: 750px) {
  html {
    font-size: calc(100vw / 12.8);
  }
}


@media (min-width: 751px) and (max-width: 1000px) {
  html {
    font-size: calc(100vw / 9.8);
  }
}




@media (max-width: 750px) {
  html {
    font-size: calc(100vw / 7.67);
  }
}

/* ================================================
text-shadow
================================================ */


/* ================================================
layout
================================================ */
body {
	height: 100%;
	line-height: 1.6;
	background: url("../images/common/bg.webp");
	/*font-family: -apple-system,BlinkMacSystemFont,'Helvetica Neue','Segoe UI','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','Meiryo UI',Meiryo,sans-serif;*/
    font-family: 'Roboto', "Segoe UI", "Helvetica Neue", sans-serif;
	font-size: .18rem;
	/* 
  background-attachment:fixed;
	background-size: cover;
  font-feature-settings: 'palt';
	letter-spacing: .08em;文字詰め
*/
}

@media (max-width: 750px) {
  body {
    font-size: .24rem;
  }
}

.wrapper {
  margin: 0 auto;
  position: relative;
  width: 100%;
  max-width: 1200px;
}

@media (min-width: 751px) {
  .wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.contents {/*bodyの背景色*/
  margin: 0 auto;
  width: 100%;
  height: 100%;
  min-height: 100vh;
  color: #fff;
  background: rgb(0,0,0,50%);
  box-shadow: 0 0 5px rgba(0,0,0,55%);
}

@media (min-width: 751px) {
  .contents {
    margin: 0 0 0 auto;
    padding: .25rem/*.3rem*/ .5rem;
    width: calc(100% - 240px);
  }
}

@media (max-width: 750px) {
  .contents {
    padding: 1.4rem .3rem;
  }
}
/*
.contents p, .contents dl, .contents ul {
  text-shadow: #000 2px 0 2px, #000 -2px 0 2px, #000 0 -2px 2px, #000 0 2px 2px, #000 2px 2px 2px, #000 -2px 2px 2px, #000 2px -2px 2px, #000 -2px -2px 2px, #000 1px 2px 2px, #000 -1px 2px 2px, #000 1px -2px 2px, #000 -1px -2px 2px, #000 2px 1px 2px, #000 -2px 1px 2px, #000 2px -1px 2px, #000 -2px -1px 2px;
}
*/
.sidebar {
 /* -webkit-box-shadow: 0 0 0.1rem 0 rgba(153,202,136, 0.7);
          box-shadow: 0 0 0.1rem 0 rgba(215,202,136, 0.7);
         */
  filter: drop-shadow(-2px -2px 4px rgb(230, 109, 29)) drop-shadow(2px 2px 4px rgb(138, 23, 203));
  position: fixed;
  z-index: 50;
  width: 100%;
/*画像を使用  background: url(../images/common/menu_bg.jpg);*/
  overflow-y: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none;
	background: rgba(0, 0, 0, 1);
	border: solid 1px #82240d;
}

.sidebar::-webkit-scrollbar {
  display: none;
}

@media (min-width: 751px) {
  .sidebar {
    width: 240px;
    height: 100%;
  }
}

.sidebar .qr {
  margin: 26px 0 0 0;
  color: #ccc;
  font-weight: bold;
  font-size: 12px;
  text-align: center;
}

@media (max-width: 750px) {
  .sidebar .qr {
    display: none;
  }
}

.sidebar .qr img {
  margin: 0 0 20px 0;
  width: 82px;
}


/* ================================================
nav
================================================ */
nav {
  line-height: 1;
  text-align: center;
  letter-spacing: .02em;
}

@media (min-width: 751px) {
  nav {
    /*padding: 10px;
    border-top: .01rem solid #73A9AD;
    border-bottom: .01rem solid #73A9AD;*/
    display: block !important;
     font-size: .15rem; 
  }
}

@media (max-width: 750px) {
  nav {
    padding: .1rem;
    display: none;
/*    background: #211D12;*/
    font-weight: bold;
    font-size: .3rem; 
  }
}


nav dl,nav ul{margin: 0 0 0 0;}


nav dt {
	color:#fff;
	cursor: pointer;
	-webkit-transition: .2s;
	transition: .2s;
	cursor:pointer;
	border-bottom:1px solid #000;
	background: #8E2023;
	background-repeat: repeat-x;

}

nav dt a {
  pointer-events: none;
	margin:0;
	color:#fff;
	text-decoration:none;
	display:block;
	 background: url(../images/common/menu_bg.jpg);
	 -moz-background-size:150% auto;
	background-size:150% auto; 
}



nav dt:hover {/*きいてないような*/
	/* opacity:0.65; */
	color: #782ba3;
}




nav dd {
  display: none;
 background: rgb(255,255,255);
}

nav dd a {
  color: #d5482f;
}

nav dd a.current {/*navの現在p*/
   color: #fff;
	background: rgba(213, 72, 47, 1);
}

@media (max-width: 750px) {
  nav dd a.current {
	 background: rgba(213, 72, 47, 1);
  }
}

nav dd a:hover {/*使用中*/
  color: #fff;
  font-weight: bold;
  background:#3f351d;
}

nav a {
  padding: 1em 0;
  display: block;
}

nav dd ul li{
	width: 100%;
	border-bottom: 1px #ccc solid;
	margin:0 1em 0em 0;
}
nav dd ul li:last-child{
border-bottom: none;
}


/* ================================================
header
================================================ */
@media (max-width: 750px) {
  header {
    padding: 0 .8rem 0 .3rem;
    -webkit-box-shadow: 0 0 0.1rem 0 rgba(0, 0, 0, 0.7);
            box-shadow: 0 0 0.1rem 0 rgba(0, 0, 0, 0.7);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
    height: .8rem;
    background: #000;
  }
}

header a {
  line-height: 1.2;
  color: #fff;
  font-weight: bold;
}

header a:hover {
  color: #fff;
}

@media (min-width: 751px) {
  header a {
    padding: 20px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    height: 190px;
    font-size: 16px;
    background: url("../images/common/logo.webp") no-repeat center 14px/212px;
  }
}

header a span {
  display: none;
}

@media (max-width: 750px) {
  header a span {
    display: block;
  }
}

header .toggle {
  position: absolute;
  top: .1rem;
  right: .1rem;
  width: .6rem;
  height: .6rem;
  background: #e66d1d;
  cursor: pointer;
}

@media (min-width: 751px) {
  header .toggle {
    display: none;
  }
}

header .toggle.open span {
  background: none;
}

header .toggle.open span::before {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

header .toggle.open span::after {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
}

header .toggle span {
  margin: auto;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: .4rem;
  height: .02rem;
  background: #fff;
  -webkit-transition: .2s;
  transition: .2s;
}

header .toggle span::before, header .toggle span::after {
  margin: auto;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: .02rem;
  content: '';
  background: #fff;
  -webkit-transition: .2s;
  transition: .2s;
}

header .toggle span::before {
  -webkit-transform: translateY(-0.08rem);
          transform: translateY(-0.08rem);
}

header .toggle span::after {
  -webkit-transform: translateY(0.08rem);
          transform: translateY(0.08rem);
}

/* ================================================
main
================================================ */
main section {
  margin: -.3rem 0 .5rem 0;
  padding: .3rem 0 0 0;
}

@media (max-width: 750px) {
  main section {
    margin-top: -1.1rem;
    padding-top: 1.1rem;
  }
}

main section:last-child {
  margin-bottom: 0;
}

@media (min-width: 751px) {/*最初のh2の前のあきつめ*/
main section:first-child {
  margin-bottom: 0;
}
}
main section:first-child p:last-child {
  margin-bottom: .45rem;
}


main .sec {
  margin: 0 0 2em 0;
}

main .sec:last-child {
  margin-bottom: 0;
}
main .w80 {
  margin: 1em auto;
  width: 80%;
}

@media (max-width: 750px) {
  main .w80 {
    width: 90%;
  }
}

main p {
  margin: 0 0 0 0;
}

main p:last-child {
  margin-bottom: 0;
}

main p img {
  margin: 0 .5em 0 0.5em;
}

main p img.icon {
    width: inherit;
    height: 1.25em;
    width: 1.25em;
    display: inline-block;
	}

@media (max-width: 750px) {
main p img.icon {
    width: inherit;
    height: 1.5em;
    width: 1.5em;
	}
}

main h4 img.icon {/*4100*/
    width: inherit;
    height: 1.25em;
    width: auto;
  margin: 0 .5em 0 0.5em;
}

    
    
main p img, main dl img, main ul img {
  width: auto;
  height: 1.5em;
  width: 1.5em;  
}
main .disc{padding:1% 0 2% 0;}
main .disc li {
  margin: 0 0 0 1.5em;
  list-style: disc outside;
}

main .reference, main .reference_list li {/*注釈*/
  padding: 0 0 0 1em;
  color: #222222;
  font-size: .16rem;
  text-indent: -1em;
}

@media (max-width: 750px) {
  main .reference, main .reference_list li {
    font-size: .2rem;
  }
}

main .reference::before, main .reference_list li::before {
  margin: 0 .2em 0 0;
  content: "\2022";
/*  content: '/203b';*/
/*  font-family: ‘Hiragino Kaku Gothic ProN’,’ヒラギノ角ゴ ProN W3′,’Meiryo UI’,Meiryo,sans-serif;*/
    font-family: 'Roboto', "Segoe UI", "Helvetica Neue", sans-serif;
}



/*================================================
 *  hover効果
 ================================================*/

.image:hover{filter: brightness(130%);}


.center{
	text-align: center;
	margin: 0 auto;
	clear: both;
}

/* ================================================
link
================================================ */
main + .pagination {
  margin: .5rem 0 0 0;
}

.pagination {
  margin: 0 0 .2rem 0;
  line-height: 1;
}

.pagination li {
  display: inline-block;
	margin-left:0em;
	margin-right:1em;

}

.pagination li.prev {
  margin: 0 0 0 .15rem;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}



@media (max-width: 750px) {
  .pagination li + li {
    margin: 0 0 0 .2rem;
  }
}

.pagination a {
  display: block;
  width: .8rem;
  height: .3rem;
}
.pagination a.next {
  background: url("../images/common/next.png") no-repeat center/100%;
  -webkit-transition: none;
  transition: none;
}
.pagination a.prev {
  background: url("../images/common/back.png") no-repeat center/100%;
  -webkit-transition: none;
  transition: none;
}

@media (max-width: 750px) {
  .pagination a {
    width: 1.2rem;
    height: 0.6rem;
  }
}
.pagination a:hover {
  opacity:1;
}



/* ================================================
rim・table
================================================ */

table {
  margin: 1em 0;
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  line-height: 1.2;
  color: #fff;
  background-color: rgba(68,68,68, 0.2);
}

table:last-child {
  margin-bottom: 0;
}

table th, table td {
  padding: .5em;
  border: dotted .01rem #444;
}

table th {
  width: 35%;
  background: rgba(68,68,68, 0.4);
  font-weight: bold;
  text-align: left;
	color: #D0CCDA;
}



table th > span {/*thの改行*/
	display: inline-block;
}

@media (min-width: 751px) {
  table th br {
    display: none;
  }
}


table img {
  margin: 0 .5em;
  width: auto;
  height: 1.2em;
}

table.table_btn {
  table-layout: fixed;
}

table.table_btn th, table.table_btn td {
  width: auto;
	text-align: center;
}

table.table_btn th.th_02 {
  background: rgba(68,68,68, 1.0);
  font-weight: bold;
  text-align: center;
}


th.th_second {/*表の見出しが2段階*/
  width: 20%;
 background: rgba(20,0,71, 0.8);
}
/*
table.w_ttl {冒頭に見出し行あり	
}
*/

table.w_ttl th.midashigyo {
  width: auto;	
  background-color: rgba(0,0,0,0.3)	;
	color: #fff;
}

table.w_ttl th {
 width: 35%;	
}



/* ================================================
表組の代用
================================================ */

.hyo_1dan p {
	margin: 0 0 0 2em;	
}
.hyo_1dan h5 {
	margin: 0.5em 0 0 1.25em;	
	padding: 0.1em 0 0 0.5em;

 background: rgba(20,0,71, 0.3);
}

.hyo_1dan table.hyo_1dan_mini {/*margin分右にはみ出すのをwidthで戻す*/
	margin: 0 0 0 2em;	
	width: calc(100% - 2em);
  border: solid 2px rgba(20,0,71, 1);
	
}
/*
.hyo_1dan_mini th, .hyo_1dan_mini td {
}
*/
.hyo_1dan_mini th {
	  font-weight: inherit;

}



/* ================================================
ph
================================================ */
.ph {
  margin: 1em auto;
  border: solid .01rem #F1F6D5;
}

.ph.controller {
  border: none;
}


.licence_oya {
	margin-top: 2em;
	padding: 1em 1em 1em 0em;
	background-color: rgba(208,204,218, 0.8);
}

.licence li{
	margin-bottom: 0.8em;
	font-size: .16rem;
    color: black;
}

.licence li img{
	font-size: .1rem;
}


/* ================================================
flexbox
================================================ */

/* ================================================
本文用flex
================================================ */

.flexbox_ph {
  margin: 1em 0;
}

@media (max-width: 750px) {
  .flexbox_ph {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: column;
	  position: relative;
  }
}
/*スマホ*/
@media (max-width: 750px) {
  .flexbox_ph img {
		display   : block;
    margin: 0.5em 0 1em 0em;
    width: 100%;
  }
}
@media (max-width: 750px) {
    .flexbox_ph p {
		display   : block;
    width: 100%;
    }
  }

@media (max-width: 750px) {/*横並び画面説明文内のアイコンなどが横100％になるのを避ける*/
  .flexbox_ph img.btn {
    width: auto;
    height: 1.25em;
	display   : inline-block;
	margin: 0 0.2em;  
  }
  }



/*PC 751以上*/
@media (min-width: 751px) {
    .flexbox_ph p {
/*	display   : block;*/
	width:100%;
		margin:0 1em 0 auto;
/*		margin:0 0 0 auto;*/
	}
  }
@media (min-width: 751px) {
    .flexbox_ph div.flex_txt {
	width: 100%;
	margin:0 1em 0 0;
	}
  }

@media (min-width: 751px) {
  .flexbox_ph div {
	display   : block;
	width:70%;
/*	  margin-left: 1em;*/
 		margin:0 0 0 auto;

  }
 }

@media (min-width: 751px) {
  .flexbox_ph div.aki_lr {
    margin: 0 1em 0 1em;
  }
 }



@media (min-width: 751px) {
  .flexbox_ph {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row-reverse;
  }
}




/* ================================================
コラム用flex
================================================ */

.flexbox_column_ph {
  margin: 1em 0;
}

@media (max-width: 750px) {
  .flexbox_column_ph {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: column;
  }
}
/*スマホ*/
@media (max-width: 750px) {
  .flexbox_column_ph img {
		display   : block;
    margin: 0 0 1em 0;
    width: 100%;
  }
 }
@media (max-width: 750px) {
    .flexbox_column_ph p {
		display   : block;
    width: 100%;
    }
  }



/*PC 751以上*/
@media (min-width: 751px) {
    .flexbox_column_ph p {
		display   : block;
		width: 100%;
	}
  }

@media (min-width: 751px) {
  .flexbox_column_ph div {
	display   : block;
	width:70%;
	  margin-top: 0.5em;
  }
 }


@media (min-width: 751px) {
  .flexbox_column_ph {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row;
  }
}




/*------------------------------------
pagejump 
------------------------------------*/
/*ul.pagejump {
	border: 1px dotted black;
}
*/

.pagejump {
  margin: 0 auto .5rem auto;
  /* display: table; */
  text-align: center;
  display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; flex-wrap: wrap;
  justify-content: center;

}

.pagejump li {
  width: calc(24% - 2px);
  margin: 0 0.5% 1% 0.5%;
  display: inline-block;
  border: solid 1px #fbc200;
  display: flex;
  align-items: center;

}

@media (max-width: 750px) {
  .pagejump {
    font-size: .24rem;
  }
  .pagejump li {
    width: calc(32% - 2px);
  }
  
}



/*
.pagejump li:last-child {
  margin-right: 0;
}*/

.pagejump a {
  width: 96%;
  padding: 2%;
  position: relative;
  color: #fbc200;
  display: block;
}
.pagejump a:hover {
  text-decoration: underline;
}


/*------------------------------------
pagelink 参照p
------------------------------------*/

.pagelink {
  margin: 0 auto .5rem auto;
	position: relative;
}

@media (max-width: 750px) {
  .pagelink {
    font-size: .24rem;
  }
}

.pagelink li {
	display: block;
	 padding: 0 0 0 -0.25em;
	margin: 0em;
/*	border: 1px pink solid;*/
}

.pagelink li::before{
 content: "▷";
 display: inline-block;
 vertical-align: middle;
color: #e48d7e;
}

.pagelink a {
  color: #e48d7e;
}

.pagelink a::before{
  content: "▷";
  display: inline-block;
  vertical-align: middle;
 color: #e48d7e;
 margin-right:5px;
 } 


/* ================================================
footer
================================================ */
footer {
  margin: .2rem 0 0 0;
}

footer .copyright {
  font-size: .12rem;
  text-align: center;
  letter-spacing: .05em;
}

@media (max-width: 750px) {
  footer .copyright {
    font-size: .2rem;
  }
}

footer .pagetop {
  display: block;
  position: fixed;
  right: .3rem;
  bottom: .3rem;
  z-index: 10;
  width: .8rem;
  height: 1.44rem;
  content: '';
  background: url("../images/common/totop.png") no-repeat center/100%;
}

@media (max-width: 750px) {
  footer .pagetop {
    width: .4rem;
    height: .6rem;
    background: url("../images/common/totop_sp.png") no-repeat center/100%;
  }
}

footer .pagetop:hover {
  opacity: .8;
}

/* ================================================
TOP
================================================ */
/*
.top {
		 background:#ede4cd;
}
      */

@media (min-width: 751px) {
  .top {
    padding: 0 .3rem .3rem .3rem;
  }
}

@media (max-width: 750px) {
  .top {
    padding-top: .8rem;
  }
}

.top .mv {
  margin: 0 -.3rem;
  height: 5.5rem;
  background: url("../images/0000/mv2.jpg") no-repeat center/cover;
}

@media (max-width: 750px) {
  .top .mv {
    height: 3.5rem;
    background-image: url("../images/0000/mv_sp2.jpg");
  }
}

.top p, .top dl, .top ul {
  text-shadow: none;
}

.top .link {
  margin: 2em 0;
  line-height: 1;
  font-weight: bold;
}

@media (min-width: 751px) {
  .top .link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: .14rem;
  }
  @supports (display: grid) {
    .top .link {
      display: -ms-grid;
      display: grid;
      gap: .1rem;
      -ms-grid-columns: 1fr 1fr 1fr;
          grid-template-columns: 1fr 1fr 1fr;
    }
  }
}

@media (min-width: 751px) {
  .top .link .col {
    width: calc(100% / 3);
  }
  @supports (display: grid) {
    .top .link .col {
      width: auto;
    }
  }
}

@media (max-width: 750px) {
  .top .link .col {
    margin: 0 0 2em 0;
  }
  .top .link .col:last-child {
    margin-bottom: 0;
  }
}

.top .link dl {/*top目次リンク*/
  margin: 0 0 2em 0;
  padding: 0 0 0 1.5em;
}

.top .link dl:last-child {
  margin-bottom: 0;
}

.top .link dt {/*top目次リンク　項目名　見出し*/
  margin: 0 0 1em 0;
  padding:0.5em 0;
  color: #e66d1d;
  border-top: solid 1px #e66d1d;
  border-bottom: solid 1px #e66d1d;
	
}

.top .link li {
  margin: 0 0 1em 0;
}

.top .link li:last-child {
  margin-bottom: 0;
}
.top .link li li{/*下階層*/
  margin: 0.5em 0 0.5em 0.5em;
  color: #f4c09d;
	font-size: 80%;
}
.top .link li li::before {
	content: '\025b6';
	margin-right: 0.2em;
}





.top .link .pagejump {
  margin: .8em 0 0 0;
  padding: 0 0 0 1em;
  display: inherit;
  font-weight: normal;
  text-align: left;
}

.top .link .pagejump li {
  display: inherit;
  margin: 0 0 .5em 0;
}

.top .link .pagejump li:last-child {
  margin-bottom: 0;
}

.top .reference_list {
  margin: 2em 0;
}

.top .reference_list li {/*トップ注釈*/
  color: #fff;
  font-size: .12rem;
}

@media (max-width: 750px) {
  .top .reference_list li  {
    font-size: .2rem;
  }
}

.top .reference_list li img {
  height: 1.05em;
  width: auto;
}




.top_remake {
	display: flex;
	flex-direction: column;
	 justify-content: center;
	background-color: rgba(255,255,255,0.50);
	padding: 1em;
	color: #555;
}
.top_remake p {
	display: block;
	text-align: center;
}
.top_remake img {
  margin: 0 auto;
  width: 82px;
}

/*# sourceMappingURL=style.css.map */




/* ================================================
ユーザーサポート
================================================ */
.column {
 /* display: grid;
  grid-template-columns: 1fr 4fr;
  grid-auto-rows: minmax(30px, auto);*/
	padding: 0.9em;
	 margin: 1em 0em 1em 0em;
	background: rgba(255,255,255, 0.5);
	border: double 1px #211d12;
}

/*
.column > div > p {
	text-shadow: inherit;
	font-weight: normal;
	color: #800000;
}

.column > div > p.bold {
	font-weight: bold;
	color: #000;
}
*/

@media (max-width: 750px) {
/* 	.column {
 display: grid;
  grid-template-columns: 1fr 4fr;
	}
  */
}
.column div.column_ttl {
	background: linear-gradient(to right, transparent 0%, rgba(121,91,29, 0.7) 30%, rgba(121,91,29, 0.7) 70%, transparent 100%);
	padding: 0.5em 0em;
	  display: flex;
  justify-content: center;
  align-items: center;
}




/*----------------------------------
h1 h2 h3 
----------------------------------*/




h1	{
	position: relative;
	text-align:center;
	color: #fff;
    font-size:250%/*55px*/;
	font-weight: bold;
	padding: 20px 5px; 
	margin-bottom:0.5em;
/*	font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;*/
    font-family: 'Roboto', "Segoe UI", "Helvetica Neue", sans-serif;
	line-height: 1.2em;
	filter: drop-shadow(-2px -2px 4px rgb(230, 109, 29)) drop-shadow(2px 2px 4px rgb(138, 23, 203));
/*	snake
	background-position: center bottom;
	background-size: 100% 45% ;
	background-repeat: no-repeat;
	background-image:url("../images/common/light.png");
	*/
}
h1 > span {
	font-weight: bold;
	}

h2	{
	position: relative;
	font-size: 185%/*25px*/;
	font-weight: bold;
	color: #fff;
	line-height: 1.2em;
	text-align: center;
	padding: 10px 10px 10px 10px;  
	margin-bottom:1.5em;
	z-index: 4;
	/* font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif; */
    font-family: 'Merriweather', serif;
	line-height: 1.2em;
	border-bottom: double 3px #fff;
	/*
	background: rgba(54,12,6, 0.9);
	background-image:url("../images/midashi_h2_02.png");
	background-position: center center;
	background-size: 100% 100% ;
	background-repeat: no-repeat;
	*/
}
/*
h2:before {  
	content: '';
  	position: absolute;
  	top: 0;
  	bottom: 0;
  	right: 0;
  	left: 0;
	z-index: -1;
  	background-image:url("../images/midashi_h2_01.png");
	background-position: center top;
	background-size: 100% auto ;
	background-repeat: no-repeat;
}

h2:after {  
	content: '';
  	position: absolute;
  	top: 0;
  	bottom: 0;
  	right: 0;
  	left: 0;
	z-index: -1;
  	background-image:url("../images/midashi_h2_03.png");
	background-position: center bottom;
	background-size: 100% auto ;
	background-repeat: no-repeat;
}


h2 img { 
	height:30px;
	vertical-align:middle;
	padding:0px 5px;
}
*/
.before { /*スマホヘッダー固定用の空白 shiyo*/
	height:40px;
}


h3 {
	position: relative;
	font-size:120%/*22px*/;
	font-weight: bold;
	line-height: 1.2;
	padding: 0.3em 0.5em;
	margin-top:1.35em;
	margin-bottom:0.5em;
	vertical-align: middle;
	clear: both ;
	text-decoration: none;
	color: #ea3c19;
    border: solid 2px #ea3c19;
}
h3 img {
	height:120%/*22px*/;
	padding:0px;
	margin:0px 5px ;
	vertical-align: middle;
}
h3 > span {
	font-weight: bold;
	}
h3 > span > span {
	font-weight: bold;
	}





h4 {	
	/*width: 100%;*/
	font-size:110%/*20px*/;
	clear: both ;
	color:#49241e;
	font-weight: bold;
	line-height: 1.2em;
	padding: 3px 0px 5px 10px; 
	margin-top:1em;
	margin-bottom:0.5em;
	border-bottom: 1px solid rgba(85,71,56,0.5);
  position: relative;
  padding-bottom: 5px;
}

h4 img {
	height:110%/*20px*/;
	vertical-align:middle;
	padding:0px 0px 0px 0px;
}

h4 a {
	text-decoration: none;
	color:#72640c;
}


h4::after {
  position: absolute;
  left:  -10px;
  bottom: -3px;
  display: block;
  content: " ";
  width: 20%;
  border-bottom: 3px solid #be0006;
}

h4.us::after{border-bottom: none;}



h5 {	
	/*width: 100%;*/
	font-size:18px;
	clear: both ;
	color:#6a1917;
	font-weight: bold;
	line-height: 1.2em;
	padding: 3px 0px 5px 0px; 
	margin-top:3%;
	margin-bottom:0.5em;
	border-bottom: 2px solid rgba(85,71,56,0.5);
}

h5 img {
	height:1.5em;/*25px;*/
	width: 2em;
	vertical-align:middle;
	padding:0px 10px 0px 0px;
	
}

section {
	/* overflow: hidden; */
	margin-bottom:0.5em;
	clear: both ;
}
section:first-child {
	margin-bottom:0;
}


a:hover {
	color:#ffffff;
	/* opacity:0.65; */
	filter: drop-shadow(-2px -2px 4px rgb(230, 109, 29)) drop-shadow(2px 2px 4px rgb(138, 23, 203));
	
}
p {
	margin:0 0 1em 0;
}
img {
	vertical-align:middle;
}
img.frame {/*shiyo*/
	border:1px solid #b8860b;
	background-color: rgba(0,0,0,0.5);
}
/*
img.frame_02 {mishiyo
}
*/
ul,ol,dl {
	margin:0 0 1em 0;
}
ul li {
		list-style-type: none;
/*	list-style:disc;*/
}

li {
	margin-left:2em;
}

ul.maru li {
	list-style:disc;
	text-indent: -0em;
	padding-left: 1em;
}
ul.nodisc li {
	list-style:none;
/*	text-indent: -0em;
	padding-left: 1em;*/
}
ul.maru_kei li {
	list-style:disc;
	text-indent: -0em;
	padding-left: 1em;
}
div.list_kei {
	border: 2px #be0006 solid;
	margin: 0.5em 0 1em;
}
div.list_back {
/*	border: 2px #be0006 solid;*/
	margin: 0.5em 0 1em;
	background: rgba(245, 240, 187, 0.4)/*rgba(190,0,6,0.1)*/;
	padding-bottom: 0.1em;
}
p.list_back_ttl {
	border-bottom: 3px solid rgba(245, 240, 187, 1);
	margin: 0 0 0.5em;
	background: rgba(245, 240, 187, 0.6)/*rgba(190,0,6,1)*/;
	padding: 0.2em 0 0 0.5em;
	color: rgba(190,0,6,1);
}

/*================================================
 *  表
 ================================================*/
table {
	border: solid 4px #211D12;
}

th {
	text-align:left;
	font-weight:bold;
}



td {
	text-align:left;
	padding:2px 10px;
	background: rgba(255,255,255,0.3);
}
th img {
	height:30px;
	vertical-align:middle;
	margin:5px;
}

th img.ps4icon {
	height:25px;
	vertical-align:middle;
	margin:5px;
}


td img {
	height:25px;
	vertical-align:middle;
	margin:5px;
}
th,td {
  	border: solid 1px #7b672e;
	vertical-align: middle; 
}

td p.shita_midashi {
	font-weight: bold;
	color: rgba(20,0,71, 1.0);
	border-bottom: 1px rgba(20,0,71, 1.0) solid;
	border-left: 3px rgba(20,0,71, 1.0) solid;
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	padding-left: 0.2em;
	}
td p.shita_midashi:first-child{
	margin-top: 0em;	
}

img.tall {/*flameかいがい*/
	height: 1.25em;
}

table.th10 th{/*leo追加 th10%を一括で*/
	width: 10%;
}
table.th20{margin-top:3%;}
table.th20 th{/*leo追加 th20%を一括で*/
	width: 20%;
}
table.th25 th{/*leo追加 th25%を一括で*/
	width: 25%;
}

table.th30 th{/*leo追加 th30%を一括で*/
	width: 30%;
}
table.th40 th{/*leo追加 th30%を一括で*/
	width: 40%;
}



/*================================================
 *  表（テキストセンター）
 ================================================*/
.center th {
  	text-align: center;
}
.center td {
  	text-align: center;
}



/*================================================
 *  表　2段組変形
 ================================================*/

.flexbox_sousa {
  margin: 1em 0;
	  width: 50%;
	border-top: 1px black solid;
}
@media (max-width: 750px) {
.flexbox_sousa {
  margin: 2em 0 0 0;
	  width: 98%;
}
.flexbox_sousa:nth-last-child(1)  {
  margin: 0em 0 0 0;
	border-top: none;
	border-bottom: 2px black solid;
}
}


@media (max-width: 750px) {
  .flexbox_sousa_oya {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: column;
	  position: relative;
	  margin: inherit;
  }
}
.sousa_line {
	margin: inherit;
	margin: 0;
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row;
	  position: relative;
	border-top: 1px black solid;
	  color: #000;
  background: rgba(255, 255, 255, 0.8);


}
.sousa_th {
/*	border: 1px pink solid ;*/
		width: 45%;
	padding: 0.25em;
	background: rgba(255,255,255, 1.0);
  font-weight: bold;
	color: #D0CCDA;
  text-align: center;
}
.sousa_td {
	width: 54%;
	padding: 0.25em;
}



/*PC 751以上*/
@media (min-width: 751px) {
  .flexbox_sousa_oya {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row;
	  position: relative;
	  gap: 1em;
	}
}






/*================================================
 *  クラス
 ================================================*/

.float_clear{
	clear: both ;
}
.line { 
	display: inline-block;
}
.text_main{/*shiyo*/
	margin-top: 0.5em;
  	margin-bottom:0.5em;
	padding:0;
	text-align: justify;
}
.text_main img {/*shiyo*/
	height:22px;
	margin:5px;
}
.reflect_lr {/*左右反転*/
  display: inline-block;
  transform: scale(-1,1);
}
.reflect_ud {/*上下反転*/
  display: inline-block;
  transform: scale(1,1);
}
.rotated_90 {
transform: rotate(90deg)
}


.thirty_per {/*shiyo*/
	border: 2px black dotted;
	display: block;
	height:30%;
	margin:auto;
}

/*================================================
 *  注釈
 ================================================*/

p.hint0,p.hint1 {/*注釈1*/
	font: 1em;
	color: #e93b18;
}
.hint0::before {
	content: '\2022';
/*	content: '\2022;\203b'*/;
	margin-right: 0.2em;
}

div.flexbox_ph p.hint0 {/*flex内*/
	font: 1em;
	color: rgba(54,12,6, 0.9);
  display: inline-block;
}



.hint1::before {/*\203b*/
	content: 'Caution';
	color: pink;
	background: red;
	padding: 0.2em;
	margin-right: 0.25em;
}




/*================================================
 *  写真につける矢印（スマホは縦）
 ================================================*/

/*スマホ変形あり =flexbox_ph_arrow*/
/*スマホ変形なし =flexbox_ph_arrow_yoko*/

/*親*/
.flexbox_ph_arrow,.flexbox_ph_arrow_yoko {
  margin: 1em 0;
}
/*変形あり　スマホでは縦*/
  .flexbox_ph_arrow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: column;
	  position: relative;
  }
  /*
  .flexbox_ph_arrow div {矢印
  }*/
  .flexbox_ph_arrow img.ph_w_arrow {
	  width: 80%;
	  height: 80%;
  }

/*変形あり　751以上は横*/
@media (min-width: 751px) {
  .flexbox_ph_arrow,.flexbox_ph_arrow_yoko {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row;
	  position: relative;
  }
  .flexbox_ph_arrow img.ph_w_arrow {
	  width: auto;	
  }
  .flexbox_ph_arrow div {
	  width: 20%;
	 top: 0;
	 bottom: 0;
	 margin: auto;
  }
 .flexbox_ph_arrow img.arrow_roteted {
	transform: rotate(-90deg);
  }
  }

/*変形なし　常時横*/
.flexbox_ph_arrow_yoko {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-direction: row;
	  position: relative;
  }
.flexbox_ph_arrow_yoko img.ph_w_arrow {
	  width: 40%;	
	height: auto;
  }
  .flexbox_ph_arrow_yoko div {
	  width: 20%;
	 top: 0;
	 bottom: 0;
	 margin: auto;
	height: auto;
  }
 .flexbox_ph_arrow_yoko img.arrow_roteted {
	transform: rotate(-90deg);
  }	
	
	
/*================================================
 *  photo
 ================================================*/


div.photo {/*画像センタ*/
     width:80%;
     min-width: 320px;
     margin:0 10%;  
/*     border:#F70841 1px solid;　外ケイ1*/
	background-color:rgba(33, 29, 18, 0.5);
	padding:2.5%;/*背景とアキで外ケイ2*/
}

@media (max-width: 750px) {
div.photo {/*画像センタ*/
	width: 100%;
     margin:0;  
	}
}




/*================================================
 *  san8re kobetsu
 ================================================*/


div.kirinuki  {/*画像センタ*/
     width:80%;
     min-width: 320px;
     margin:0 10%;  
}
table.icon-list td{text-align:center;}


/*================================================
 *  画像（横並び)
 ================================================*/

/*
.block_30 {
	display: inline-block;
	width: 30%;
	vertical-align: text-top;
	margin: 0% 1%;
}
*/




/*================================================
 *  番号付き見出し インデントあり
 ================================================*/
.number{
	margin-left: 9%;
	margin-right: 9%;
	text-align: justify;
}

.number h3 {
	font-weight: bold;
	clear: both ;
	background-color: inherit;
	border:none;
	box-shadow: none;
	color:#730031;
	font-size: 1.2em !important;
	line-height: 0.5;
	padding-left:1.75em;
	text-indent:-1.75em;
	margin-bottom: 0 ;
	padding-bottom: 0;
	text-align: left;
}
    
.number_img{ /*数字画像 sample使用*/
	height: 1.5em;
	width: auto;
	margin: 0em 0.25em 0em 0em;
	vertical-align: middle;
}

    
    
/*================================================
 *  番号付き見出し インデントなし
 ================================================*/

.cont_wrap      { margin-left: 1em; }

.number_akinashi {
	margin-left: 0%;
	margin-right: 0%;
}

.number_akinashi h3 {
	font-weight: bold;
	clear: both ;
	background-color: inherit;
	border:none;
	box-shadow: none;
	color:#fff;
	font-size: 1.2em !important;
	line-height: 1.2;
	padding-left:0;
	text-indent:0;
	margin-bottom: 0 ;
	padding-bottom: 0;
	text-align: left;
  filter: drop-shadow(-2px -2px 4px rgb(230, 109, 29)) drop-shadow(2px 2px 4px rgb(138, 23, 203));
}

@media (max-width: 750px) {
.number_img{ 
	height: 1.5em;
	width: auto;
	margin: 0em 0.25em 0em 0em;
	vertical-align: middle;
}
}
@media (min-width: 751px) {
    .number_akinashi.number_img{ 
	height: 1.5em;
	width: auto;
	margin: 0em 0.25em 0em 0em;
	vertical-align: middle;
}
}
    
    
@media (max-width: 750px) {
.capcenter_no img {
	display: inline-block;
	width: auto;
margin-top: 0.1em;
margin-right: 0.1em;
}
}

@media (min-width: 751px) {
.capcenter_no img {
	display: inline-block;
	width: auto;
margin-right: 0.1em;
}
}

/*
@media (min-width: 751px) {
.number_akinashi br{
	display: none;
}
}
@media (max-width: 750px) {
.number_akinashi.capcenter_no br{
	display: inline;
}
}
*/

/*4100*/
.photo p.capcenter_no{
	margin-top: 0.5em;
}
.indent_left{
	margin-left: 2.2em;
}

@media (max-width: 750px) {
.indent_left{
	margin-left: 1em;
}
}

/*================================================
 *  囲み1
 ================================================*/

.kakomi {
	margin: .5em auto;
	border: solid 1px #a00032;
	clear: both;
	color: #a00032;
	background: rgba(255,255,255,.8);
  overflow: hidden;
}
.kakomi p {
	padding: 0.5em;
	margin: 0.25em 0;
	color:#49241e;
}
.kakomi h4 {
	margin: 0;
	padding: 0.5em;
   }


/*================================================
 *  囲み2
 ================================================*/

.table_none {
	width:100%;
	border-collapse:collapse;
	margin-top: 0.5em;
  	margin-bottom:0.5em;
	border: solid 0px #24140e;
	line-height: 1.5;
	background: rgba(255,255,249,0);/*#fffff9*/
}

.table_none th {
	border: solid 0px #24140e;
	text-align:center;
	vertical-align: middle;
	background: rgba(36,20,14,0);
	padding: 0.1em;
}
.table_none td {
	border: solid 0px #24140e;
	text-align:center;
	vertical-align: middle; 
	font-size:18px;
	color:#6c3524;
	padding: 0.5em 0 0 0;
}
.table_none th img {
	width: 100%;
	height: auto;
	vertical-align:middle;
	margin: 0;
}

.table_none td img {
	height: auto;
	vertical-align:middle;
	margin: 0 0 2em 0;
}
.table_none tr:nth-child(odd) {
	background: rgba(255,255,249,0);/*#fffff9*/
}
.kakomi_02 {
  	text-align: center;
	background-color: rgba(255,255,249,0.5);
	font-size: 14px;
	padding: 1em;
	line-height: 1.2;
	border-top:ridge 4px rgba(186,139,64,0.8);
	border-left:ridge 4px rgba(186,139,64,0.8);
	border-bottom:groove 4px rgba(186,139,64,0.8);
	border-right:groove 4px rgba(186,139,64,0.8);
	margin: 12px 4px;
	box-shadow: 0px 0px 0px 4px rgba(36,20,14,0.6);
  }

.kasanari {
    text-align: center;
	margin: 0 auto;
	position: relative;
	width: 50%;
}

.photo_main_2,
.photo_main_3,
.photo_main_4{border: solid 2px #24140e; box-shadow: 0px 0px 5px 0px #24140e ;}

/*100％ 線あり*/
.photo_main_2 { position: relative;}
.photo_main_3 { position: absolute; left: 40%; top: -10%;}
.photo_main_4 { position: relative; left: -40%;}


/*================================================
 *  span (h3内)
 ================================================*/
h3 span {
	margin: 0 0.3em;
	font-size: 70%;	
	padding: 0.1em 0.3em ;
	vertical-align: 0.15em;
	background: rgb(0,0,0);
}
span.kunshu,span.totoku {color: red;}
span.kunshu::before {content: '君主';}
/*span.totoku {color: #fce45f;}*/
span.totoku::before {content: '都督';}


span.taishu {color: orange;}
span.taishu::before {content: '太守';}


span.gunshi {color: yellow;}
span.gunshi::before {content: '軍師';}


span.ippan {color: green;}
span.ippan::before {content: '一般';}


span.toryo,span.doshi {color: blue;}
span.toryo::before {content: '頭領';}
span.doshi::before {content: '同志';}


/*================================================
 *  3500,4100,4300　zuの上の文字 ================================================*/

div.zu {
    position: relative;
}
div.flex {
    display: flex;
}


p.zu {
    color: #fff;
    position: absolute;
/*    font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";*/
    font-family: 'Roboto', "Segoe UI", "Helvetica Neue", sans-serif;
    font-weight:bold;
    font-size: 75%;
}

/*3500上*/
@media (max-width: 750px) {
p.field{
 top: 10%;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
}
}
@media (min-width: 751px) {
p.field{
 top: 10.5%;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
}
}

@media (max-width: 750px) {
div.bottom1 {
    position: absolute;
    width: 96%;
    bottom: 6%;
    height: 8%;
    margin: 0 4%;
}    
}
@media (min-width: 751px) {
div.bottom1 {
    position: absolute;
    width: 96%;
    bottom: 6%;
    height: 8%;
    margin: 0 4%;
}    
}


div.area {
    width: 43%;
    position: relative;
    
}
div.aida {
    width: 5%;
    height: 100%;
}


p.area,p.world{
    width: 100%;
    text-align: center;
}

/*4300*/
p.bl {
    color: black;
    text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
    font-size: 85%;
    line-height: 96%;
}
p.m1{
 top: 11%;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
}
div.bottom3 {
    position: absolute;
    width: 92%;
    top: 25%;
    height: 15%;
    margin: 0 2%;
}
div.sp {
    min-width:35%;
    position: relative;
}
div.aida3 {
    width: 30%;
    height: 100%;
}

p.m2,p.m3{
    width: 100%;
    text-align: center;
}
p.m4{
 text-align: center;
    top: 63%;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
}

div.bottom2 {
    position: absolute;
    width: 92%;
    bottom: 6%;
    height: 8%;
    margin: 0 2%;
}
div.rank {
    width: 46%;
    position: relative;
    
}
div.aida2 {
    width: 7.5%;
    height: 100%;
}

p.m5,p.m6{
    width: 100%;
    text-align: center;
}
/*4300*/
p.b1{
 top: 42%;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
}
div.bottom {
    position: absolute;
    width: 96%;
    bottom: 6%;
    height: 8%;
    
}
div.b2 {
    width: 46%;
    position: relative;    
}
div.b25 {
    width: 5%;
    height: 100%;
}


p.b2,.b3{
    top: 0;
    left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;  
    }
@media (max-width: 750px) {
p.b2,.b3{
    top: 2%;
}
}