@charset "UTF-8";

@media all and (max-width: 736px) {
    .pcOnly {
        display: none;
    }
}

@media all and (min-width: 737px) {
    .spOnly {
        display: none;
    }
}

body {
/*    background-color: #f4f4f4;*/
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, Sans-Serif;
	overflow-x: hidden;
	color: #444;
}

a, a img { 
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease; }
a:hover img {
filter:alpha(opacity=70);
-moz-opacity: 0.7;
opacity: 0.7;
}

a.nrm-link { color: #f8b00; padding-bottom: 0; text-decoration: underline; }
a.nrm-link:hover { color: #b66300; }

.mgB0 { margin-bottom: 0 !important; }
.mgB6 { margin-bottom: 6px !important; }
.mgB10 { margin-bottom: 10px !important; }
.mgB15 { margin-bottom: 15px !important; }
.mgB20 { margin-bottom: 20px !important; }
.mgB30 { margin-bottom: 30px !important; }
.mgB40 { margin-bottom: 40px !important; }
.mgB40r { margin-bottom: 40px !important; }
.mgB50 { margin-bottom: 50px !important; }
.mgB60 { margin-bottom: 60px !important; }
.mgBM20 { margin-bottom: -20px !important; }
.mgT0 { margin-top: 0 !important; }
.mgT10 { margin-top: 10px !important; }
.mgT20 { margin-top: 20px !important; }
.mgT30 { margin-top: 30px !important; }
.mgT40 { margin-top: 40px !important; }
.mgT50 { margin-top: 50px !important; }
.mgT60 { margin-top: 60px !important; }
.mgTM10 { margin-top: -10px !important; }
.mgTM20 { margin-top: -20px !important; }
.mgTM_tks { margin-top: -60px !important; }
.txt_lsm30 { letter-spacing: -3px; }
.txt_lsm10 { letter-spacing: -1px; }
.txt_lsm03 { letter-spacing: -0.3px; }
.txt_md { font-weight: 500; }
.txt-top-doc { text-align: right; font-size: 14px; margin: 15px 0 20px; }
.txt_90 { font-size: 90% !important; }
.txt_80 { font-size: 80% !important; }
.txt_70 { font-size: 70% !important; }
.txt_110 { font-size: 110% !important; }
.txt_120 { font-size: 120% !important; }
.txt_130 { font-size: 130% !important; }
.txt_lh13 { line-height: 1.3 !important; }
.txt_lh16 { line-height: 1.6 !important; }
.txt-cc { text-align: center !important; }
.txt-rc,.txt-rr { text-align: right !important; }
.txt-lc { text-align: left !important; }
.txt-cr { text-align: center !important; }
.txt-cl { text-align: center !important; }
.txt-js { text-align: justify; }
.color-gr { color: #ff8b00 !important; }
.color-or { color: #a85600 !important; }
.color-rd { color: #e7141a !important; }
.color-rd a { color: #e7141a !important; border-bottom: 1px dotted #e7141a; }
.color-rd a:hover { border-bottom: 1px solid #e7141a; }

.spB { display: none; }
.pcB { display: inherit; }
.spB2 { display: none; }
.pcB2 { display: inherit; }
.spB3 { display: none; }
.pcB3 { display: inherit; }
.spB4 { display: none; }
.pcB4 { display: inherit; }
.fs-it { font-style: italic !important; padding-right: 2px; }
@media all and (max-width: 736px) {
.txt-rc { text-align: center !important; }
.txt-lc { text-align: center !important; }
.txt-cr { text-align: right !important; }
.txt-cl { text-align: left !important; }
.spB { display: inherit; }
.pcB { display: none; }
.mgB40r { margin-bottom: 24px !important; }
}
@media all and (max-width: 960px) {
.spB4 { display: inherit; }
.pcB4 { display: none; }}
@media all and (max-width: 560px) {
.spB3 { display: inherit; }
.pcB3 { display: none; }}
@media all and (max-width: 480px) {
.mgTM_tks { margin-top: -26px !important; }
.spB2 { display: inherit; }
.pcB2 { display: none; }
.txt-top-doc { font-size: 12px; margin: 10px 0 15px; }
}

_::-webkit-full-page-media, _:future, :root.mac .fs08 {
    font-size: 0.7em!important;
}

.left-3em::before {
    left: -3em!important;
}

.inner {
    max-width: 1020px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

.inner-kv {
    max-width: 1020px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

ruby > rt {
    font-size: 44%;
    margin-bottom: -0.1em;
    transform: translateY(0.1em);
}

[rb] {
    position: relative;
}

[rb]::before {
  content: attr(rb);
  position: absolute;
  top: -0.9em;
  left: -0.2em;
  right: -0.2em;
  font-size: 0.5em;
  text-align: center;
  white-space: nowrap;
  line-height: 1;
  text-indent: 0;
}

[rb_small] {
    position: relative;
}

[rb_small]::before {
  content: attr(rb_small);
  position: absolute;
  top: -0.8em;
  left: -0.8em;
  right: -0.2em;
  font-size: 0.5em;
  text-align: center;
  white-space: nowrap;
  line-height: 1;
  text-indent: 0;
}

[rb_narrow] {
    position: relative;
}

[rb_narrow]::before {
  content: attr(rb_narrow);
  position: absolute;
  top: -0.5em;
  left: -0.2em;
  right: -0.2em;
  font-size: 0.5em;
  text-align: center;
  white-space: nowrap;
  line-height: 1;
  text-indent: 0;
}

@media all and (-webkit-min-device-pixel-ratio:0){
    .win [rb_small]::before {
        left: -2.0em;
    }
    .mac [rb]::before {
        top: -2.0em;
    }
    .mac [rb_small]::before {
        top: -1.8em;
        left: -2.2em;
    }
    .chrome [rb_narrow]::before {
        font-size: 0.3em;
        top: -1.0em;
    }  
    .mac [rb_narrow]::before {
        font-size: 0.3em;
        top: -2.2em;
    }  
}

_::-webkit-full-page-media, _:future, :root.mac [rb]::before {
        top: -1.0em;
}

_::-webkit-full-page-media, _:future, :root.mac [rb_small]::before {
        top: -1.2em;
        left: -1.2em;
}

_::-webkit-full-page-media, _:future, :root.mac [rb_narrow]::before {
        top: -0.5em;
        font-size: 0.5em;
}

@media all and (max-width: 414px) {
    [rb_narrow]::before {
      top: -1.2em;
      left: -0.2em;
      right: -0.2em;
      font-size: 0.5em;
    }
}

@media all and (max-width: 736px) {
    .inner-kv {
        width: 100%;
        padding: 0;
    }
}

.mb1e {
    margin-bottom: 1em;
}

.right.note {
    margin-top: 10px;
    margin-bottom: 10px;
}

.right.note span {
    display: inline-block;
    font-size: 14px;
    color: #ff1a00;
    border: 1px solid #ff1a00;
    padding: 5px 1em;
}

#footer {
    padding: 35px 0 30px;
    border-left: 17px solid #e1242a;
    background: #fff;
    font-family: Noto Sans CJK JP, Open Sans, sans-serif;
    color: #000;
}

#footer ul {
    font-size: 15px;
    line-height: 20px;
    overflow: hidden;
}


@media all and (max-width: 736px) {
    .right.note span {
        padding: 5px 10px;
    }
}

@media all and (min-width: 737px) {
    .right.note {
        text-align: right;
    }
}

a {
    color: #333;
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;
    text-decoration: none;
}

.link_normal {
    color: #005689;
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;
    text-decoration: underline;
}

img {
    vertical-align: bottom;
    max-width: 100%;
}

.gotop {
    text-align: right;
}

@media all and (max-width: 736px) {
    .gotop {
        display: none;
    }
}

.gotop a {
    color: #3260be;
    font-size: 12px;
}

.gotop a:before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 3.5px 7px 3.5px;
    border-color: transparent transparent #3261be transparent;
    margin-right: 3px;
}

.commentary {
    margin: 10px 0;
}

@media all and (min-width: 737px) {
    .commentary {
        margin: 20px;
    }
}

.commentary dt {
    background-color: #ef7622;
    color: #fff;
    padding: 10px 20px;
    font-weight: bold;
    line-height: 1;
}

.commentary dd {
    font-size: 14px;
    background-color: #ffefe0;
    padding: 15px 20px;
}

.remodal-overlay {
    background-color: rgba(0, 0, 0, 0.3) !important;
}

.remodal {
    max-width: 800px !important;
    padding: 0 !important;
}

.remodal-close {
    top: 20px !important;
    right: 20px !important;
    left: auto !important;
}

.remodal-close:before {
    content: url(/assets/img/common/ico-close.png) !important;
}

.modal-title {
    height: 80px;
    background-color: #ffefe0;
    display: table;
    width: 100%;
    text-align: left;
}

.modal-title .caption {
    display: table-cell;
    padding-left: 50px;
    padding-right: 80px;
    vertical-align: middle;
    font-size: 18px;
}

.modal-title .caption span {
    font-weight: bold;
    color: #ef7622;
}

.modal-content {
    padding: 30px 50px;
}

.modal-content img {
    max-width: 100%;
}

.modal-content p {
    text-align: left;
    margin: .5em 0;
}

.modal-content p.note {
    font-size: 13px;
}

.modal-content p.notice {
    font-size: 11px;
    text-indent: -1em;
    margin-left: 1em;
}

.modal-content .modal-content-cols {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -ms-flex-pack: space-between;
}

.modal-content .modal-content-cols p {
    max-width: 320px;
    margin-left: 30px;
}

.drawer-hamburger {
    display: none;
}

@media all and (min-width: 737px) {
    .drawer-nav {
        display: block;
        position: relative;
        top: 0;
        left: 0;
    }
    
    #footer {
        padding: 16px 0 24px;
        border-left: 17px solid #e1242a;
        background: #fff;
        font-family: Noto Sans CJK JP, Open Sans, sans-serif;
        color: #000;
		position: relative;
    }
.f_border { display: none; }
@media all and (min-width: 737px) {
.f_border { width: 100%; height: 8px; background: #fdf1e4; display: block; }
#footer {
background: rgb(255,255,255);
background: -moz-linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(221,221,221,1) 100%);
background: -webkit-linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(221,221,221,1) 100%);
background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(221,221,221,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff",endColorstr="#dddddd",GradientType=1); }
}

    #footer .footer-inner {
        margin: 0 auto;
        padding: 0 20px;
        width: 1040px;
    }

    #footer ul {
        font-size: 15px;
        line-height: 20px;
        overflow: hidden;
    }

    #footer ul li {
        float: left;
        list-style-type: none;
        font-size: 13px;
    }   

    #footer ul li ~ li::before {
        margin: 0 0.5em;
        content: "|";
    }    
    #footer p {
        margin-top: 16px;
        font-size: 11px;
        line-height: 18px;
    }
}

@media all and (max-width: 736px) {
    .header-contents {
        background-color: #fff;
        position: relative;
        z-index: 100;
    }
    .drawer-hamburger {
        z-index: 3;
        display: block;
        width: 125px;
        height: 48px;
        box-sizing: border-box;
        background-color: #ef7622;
        color: #fff;
        padding: 0;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        border-radius: 4px;
    }
    .drawer-hamburger > span {
        display: inline-block;
        vertical-align: middle;
    }
    .drawer-hamburger:hover {
        background-color: #ef7622;
    }
    .drawer--top.drawer-open .drawer-nav {
        z-index: 999;
        top: 40px;
		margin-top: 30px;
    }
    .drawer--top .drawer-hamburger,
    .drawer--top.drawer-open .drawer-hamburger {
        top: 22px;
        right: 8px;
        text-align: left;
        padding-left: 8px;
    }
    .drawer-hamburger-icon,
    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        width: 20px;
        height: 3px;
        background-color: #fff;
        -webkit-border-radius: 1.5px;
        -moz-border-radius: 1.5px;
        border-radius: 1.5px;
    }
    .drawer-hamburger-icon {
        margin-top: 0;
        margin-right: 2px;
    }
    .drawer-hamburger-icon:before {
        top: -8px;
    }
    .drawer-hamburger-icon:after {
        top: 8px;
    }
    .sr-only {
        position: relative;
        width: 88px;
        height: 42px;
        padding-top: 10px;
        font-size: 14px;
        text-align: center;
    }
    .drawer-open .sr-only:before {
        content: '閉じる';
    }
    .drawer-open .sr-only span {
        display: none;
    }
    
    header .logo_wrapper ul {
        display: none;
    }
    
    #footer {
        padding: 13px 10px 13px 25px;
        border-left: 8px solid #e1242a;
    }

    #footer .footer-inner {
        padding: 0;
        width: auto;
    }

    #footer ul {
        font-size: 12px;
    }
    
    #footer p {
        margin-top: 15px;
        font-size: 12px;
    }

    #footer ul li {
        float: left;
        list-style-type: none;    
    }   

    #footer ul li ~ li::before {
        margin: 0 0.5em;
        content: "|";
    }    

    
    
    
}

@media all and (max-width: 320px) {
    header .inner {
        padding-left: 10px;
        padding-right: 10px;
    }
    .drawer-hamburger {
        width: 100px;
        height: 40px;
    }
    .drawer--top .drawer-hamburger,
    .drawer--top.drawer-open .drawer-hamburger {
        top: 42px;
    }

    .sr-only {
        position: relative;
        width: 63px;
        height: 35px;
        padding-top: 8px;
        font-size: 12px;
        text-align: center;
        background-color: #fff;
        color: #000;
    }

}

header {
background-color: #fff;
}

@media all and (min-width: 737px) {
    header {
        border-top: 14px solid #e1242a;        
    }
}

@media all and (max-width: 736px) {
    header {
        position: fixed;
        z-index: 5;
        width: 100%;
		padding-bottom: 5px;
    }
    header:before {
        content: '';
        width: 100%;
        height: 7px;
        background-color: #e1242a;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1000;
    }
}

header .logo_wrapper {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-flow: column;
}

@media all and (min-width: 737px) {
    header .logo_wrapper {
        margin-bottom: 15px;
        position: relative;
    }
    
    header .logo_wrapper ul li {
        display: inline-block;
        list-style: none;
        background: none;
        margin: 0 0 0 10px;
        font-size: 13px;
    }
    
    header .logo_wrapper ul li::before {
        content: "";
		width: 7px; height: 11px;
		background-image: url(../../assets/img/common/ico-arrow-right.jpg);
		background-size: 7px 11px;
		margin-right: 4px;
		background-repeat: no-repeat;
		background-position: center center;
        display: inline-block;
    }
    
    header .logo_wrapper ul li a:hover {
        color: #e1242a;
    }

}

header .logo_wrapper .logo {
    margin-right: auto;
}

@media all and (max-width: 736px) {
    header .logo_wrapper .logo a {
        padding: 16px 10px 3px;
        margin-left: -10px;
    }
}

@media all and (max-width: 736px) {
    header .logo_wrapper {
        -webkit-flex-direction: column;
        -moz-flex-direction: column;
        -ms-flex-direction: column;
        -o-flex-direction: column;
        flex-direction: column;
    }
}

header .logo_comp a {
    display: block;
    font-size: 0;
    line-height: 0;
    padding: 0;
}

header .logo_comp {
    margin-bottom: 0;
    padding-top: 10px;
	margin-left: -15px;
}


@media all and (min-width: 737px) {
    header .logo_comp {
        max-width: 354px;
		width: 41%;
        margin-bottom: 10px;        
            
    }
    
    header .logo_comp a {
        width: 100%;
    }
}

header .logo a {
    display: block;
    font-size: 0;
    line-height: 0;
}

header .logo a img {
    width: 260px;
    height: auto;
}



@media all and (max-width: 736px) {
    header .globalnav {
        margin: 0 20px;
    }
}

@media all and (min-width: 737px) {
    header .globalnav {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-align-items: stretch;
        -moz-align-items: stretch;
        -ms-align-items: stretch;
        -o-align-items: stretch;
        align-items: stretch;
    }
    header .globalnav li.gn01 { width: 7%; }
    header .globalnav li.gn02, header .globalnav li.gn07 { width: 13%; }
    header .globalnav li.gn03 { width: 14%; }
    header .globalnav li.gn04 { width: 10%; }
    header .globalnav li.gn05,
    header .globalnav li.gn06 { width: 14%; }
	header .globalnav li.gn05 a,header .globalnav li.gn06 a { letter-spacing: -0.5px; }
    header .globalnav li.gn08 { width: 15%; }
    header .globalnav:before{
	content: "";
	width: 1px;
	height: 80%;
	position: absolute;
	top:10%;
	left: 0;
    border-left: 1px solid #ebddcc;
	z-index: -1;
    }
	header .globalnav li:last-child a:after{
	content: "";
	width: 1px;
	height: 80%;
	position: absolute;
	top:10%;
	right: 0;
    border-right: 1px solid #ebddcc;
	z-index: -1;
    }
    header .globalnav li a {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 10px 2px;
        width: 100%;
        height: 100%;
        font-size: 13px;
		font-weight: 700;
        box-sizing: border-box;
		position: relative;
    }
	header .globalnav li a:before {
	content: "";
	width: 1px;
	height: 80%;
	position: absolute;
	top:10%;
	right: -1px;
    border-right: 1px solid #ebddcc;
	z-index: -1;
    }
    header .globalnav li a:hover,
    header .globalnav li a.current {
        background-color: #ffd29d;
        color: #722302;
    }
    header .globalnav li span {
        line-height: 1.385;
        text-align: center;
    }
}

@media all and (max-width: 736px) {
    header .globalnav li:not(:last-child) {
        border-bottom: 1px solid #ccc;
    }
}

@media all and (max-width: 980px) {
    header .globalnav li a {
        font-size: 1.3vw;
    }
}

@media all and (max-width: 920px) {
    header .globalnav li a .pcOnly {
        display: none;
    }
}

@media all and (max-width: 736px) {
    header .globalnav li a {
        display: block;
        position: relative;
        font-size: 16px;
        padding: 15px 0;
    }
    header .globalnav li a:after {
        content: '';
        display: block;
        width: 9px;
        height: 15px;
        background: url(../../assets/img/common/ico-arrow.png) no-repeat 0 0;
        background-size: 9px 15px;
        position: absolute;
        right: 0;
        top: 50%;
        margin-top: -9px;
    }
}

.drawer-open header {
    border-bottom: 1px solid #dddddd;
}

@media all and (max-width: 736px) {
}

main {
    background-color: #fff;
}

main .branch {
    background-color: #f2f2f2;
}

@media all and (max-width: 736px) {
    main .branch {
        background-color: #fff;
        border-top: 1px solid #d2d2d2;
        border-bottom: 1px solid #d2d2d2;
    }
}

main .branch ol {
    list-style-type: none;
    max-width: 1020px;
    margin: 0 auto;
    padding: 5px 30px;
}

main .branch ol li {
    display: inline-block;
    font-size: 12px;
    line-height: 1;
}

main .branch ol li + li:before {
    content: '>';
    margin: 0 5px;
}

main .branch ol li a {
    font-size: 12px;
}

main .main-contents {
    padding-bottom: 20px;
}

@media all and (min-width: 737px) {
    main .main-contents {
        padding: 30px 0;
        background-color: #fff;
    }
}

main .main-contents .ttl-main {
    padding: 6px 10px;
    font-size: 18px;
    border-left: 4px solid #ef7622;
    border-bottom: 1px solid #ef7622;
    line-height: 1em;
}

@media all and (min-width: 737px) {
    main .main-contents .ttl-main {
        padding: 8px 15px;
        font-size: 25px;
        border-left: 6px solid #ef7622;
    }
}

main .main-contents .contentsnav {
    margin-top: 20px;
    background-color: #f2f2f2;
}

@media all and (max-width: 736px) {
    main .main-contents .contentsnav {
        display: none;
    }
}

main .main-contents .contentsnav ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    list-style-type: none;
    padding: 10px 0;
}

main .main-contents .contentsnav ul li {
    box-sizing: border-box;
    padding-left: 2.0408163%;
    margin: 10px 0;
}

@media all and (max-width: 736px) {
    main .main-contents .contentsnav ul li {
        width: 33%;
    }
}

main .main-contents .contentsnav ul li a {
    color: #3260be;
    display: block;
    text-indent: -10px;
    margin-left: 30px;
    font-size: 15px;
    line-height: 1.333;
}

main .main-contents .contentsnav ul li a:before {
    content: url(/assets/img/common/ico-arrow-down.png);
    display: inline-block;
    vertical-align: middle;
    position: relative;
    left: -10px;
}

main .main-contents section {
    margin-top: 40px;
    overflow: hidden;
    position: relative;
}

main .main-contents section .sec-inner {
    margin-top: 20px;
}

@media all and (max-width: 736px) {
    main .main-contents section {
        margin-top: 10px;
        background-color: #fff;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        border-radius: 4px;
    }
    main .main-contents section .sec-inner {
        display: none;
        margin: 0 15px;
        padding-bottom: 15px;
        padding-top: 10px;
        border-top: 1px solid #888;
    }
    main .main-contents section .sec-inner .close {
        display: block;
        background-color: #dedede;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        border-radius: 4px;
        text-align: center;
        padding: 15px 0;
        margin-top: 20px;
    }
}

main .main-contents section .description {
    background-color: #f2f2f2;
    padding: 15px 20px;
}

main .main-contents section .description p {
    margin: 0;
}

@media all and (max-width: 736px) {
    main .main-contents section .description {
        font-size: 14px;
        padding: 10px;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        border-radius: 4px;
    }
}

main .main-contents section .tb-ptn01,
main .main-contents section .tb-ptn02 {
    width: 100%;
    overflow: hidden;
    border-collapse: separate;
    border-spacing: 0;
}

main .main-contents section .tb-ptn01 th,
main .main-contents section .tb-ptn02 th {
    background-color: #fffeee;
    text-align: left;
    padding: 20px;
    font-weight: normal;
    border-left: 1px solid #ef7622;
    border-bottom: 1px solid #ef7622;
    border-right: 1px solid #ef7622;
    vertical-align: top;
    width: 50%;
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 th {
        padding: 10px;
        font-size: 13px;
    }
}

main .main-contents section .tb-ptn01 td {
    padding: 20px;
    border-bottom: 1px solid #ef7622;
    border-right: 1px solid #ef7622;
    vertical-align: top;
    width: 50%;
}
main .main-contents section .tb-ptn02 td {
    padding: 20px;
    border-bottom: 1px solid #ef7622;
    border-right: 1px solid #ef7622;
    vertical-align: top;
}
main .main-contents section .tb-ptn02 th,
main .main-contents section .tb-ptn02 td {
    padding: 10px;
	font-size: 13px;
	}

main .main-contents section .tb-ptn01 td .url {
    display: inline-block;
    margin-right: 20px;
}

main .main-contents section .tb-ptn01 td .qr {
    display: inline-block;
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 td .qr {
        display: none;
    }
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 td {
        font-size: 13px;
    }
    main .main-contents section .tb-ptn01 td.flex_s {
      display: flex;
	  align-items: center;      
	}
}

main .main-contents section .tb-ptn01 tr:first-child th,
main .main-contents section .tb-ptn02 tr:first-child th {
    border-top: 1px solid #ef7622;
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 tr:first-child th,
	main .main-contents section .tb-ptn02 tr:first-child th {
    }
    
    
}

main .main-contents section .tb-ptn01 tr:first-child td,
main .main-contents section .tb-ptn02 tr:first-child td {
    border-top: 1px solid #ef7622;
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 tr:first-child td,
    main .main-contents section .tb-ptn02 tr:first-child td {
    }
}

main .main-contents section .tb-ptn01 tr:last-child th,
main .main-contents section .tb-ptn02 tr:last-child th {
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 tr:last-child th,
    main .main-contents section .tb-ptn02 tr:last-child th {
    }
}

main .main-contents section .tb-ptn01 tr:last-child td,
main .main-contents section .tb-ptn02 tr:last-child td {
}

@media all and (max-width: 736px) {
    main .main-contents section .tb-ptn01 tr:last-child td,
    main .main-contents section .tb-ptn02 tr:last-child td	 {
    }
}

main .main-contents .ttl-sec {
    font-size: 22px;
    padding-bottom: 2px;
    border-bottom: 1px solid #888;
    position: relative;
}

@media all and (max-width: 736px) {
    main .main-contents .ttl-sec {
        font-size: 16px;
        padding: 15px;
        padding-right: 40px;
        border-bottom: none;
        line-height: 1.25;
    }
    main .main-contents .ttl-sec:after {
        content: '';
        display: block;
        width: 15px;
        height: 15px;
        background: url(/assets/img/common/ico-plus.png) no-repeat 50% 50%;
        background-size: 15px 15px;
        position: absolute;
        right: 20px;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        -o-transform: translateY(-50%);
        transform: translateY(-50%);
    }
    main .main-contents .ttl-sec.open:after {
        background-image: url(/assets/img/common/ico-minus.png);
        background-size: 15px 2px;
    }
}

main .main-contents .ttl-sub {
    clear: both;
    margin-top: 30px;
    font-size: 18px;
}

main .main-contents .ttl-sub span {
    font-weight: normal;
}


@media all and (max-width: 736px) {
    main .main-contents .ttl-sub {
        font-size: 16px;
        margin-top: 20px;
    }
}

main .main-contents .ttl-sub:before {
    content: '';
    display: inline-block;
    width: 14px;
    height: 14px;
    background-color: #ef7622;
    margin-right: 6px;
}

@media all and (max-width: 736px) {
    main .main-contents .ttl-sub:before {
        width: 11px;
        height: 11px;
    }
}

main .main-contents .col-wrapper {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

main .main-contents .col-wrapper:first-child > * {
    margin-top: 0;
}


@media all and (max-width: 736px) {
    main .main-contents .col-wrapper {
        -webkit-flex-direction: column;
        -moz-flex-direction: column;
        -ms-flex-direction: column;
        -o-flex-direction: column;
        flex-direction: column;
    }
    
    main .main-contents .col-wrapper p small {
        margin: 10px 0 10px;
        display: block;
        text-indent: -38px;
        padding: 0 0 0 38px;
    }

    
    
    main .main-contents .wrapper_pcOnly {
        display: none;
    }


    main .main-contents .wrapper_spOnly {
        display: block;
    }
    
    
    
}



@media all and (min-width: 737px) {
    main .main-contents .col-wrapper {
        margin-top: 20px;
        margin-bottom: 20px;
    }
    main .main-contents .col-wrapper.col-separate {
        -webkit-justify-content: space-around;
        justify-content: space-around;
        -ms-flex-pack: space-around;
    }
    main .main-contents .col-wrapper .col-text {
        width: 65.306122%;
        position: relative;
    }
    
    main .main-contents .col-wrapper .col-text small {
        margin-top: 52px;
        display: block;
    }
    
    main .main-contents .col-wrapper .col-text span {
        display: block;
        width: 307px;
        background-color: #faac5e;
        padding: 11px;
        margin: 23px 0 13px 0;
        color: #fff;
        font-weight: bold;
    }
    
    main .main-contents .col-wrapper .col-text small {
        margin-top: 11px;
        letter-spacing: 0.1px;
    }
    
    main .main-contents .col-wrapper .col-text small em {
        font-style: normal;
        color: #ef7622;
        font-weight: bold;
        
    }

    
    
    main .main-contents .col-wrapper .col-text span:nth-of-type(2) {
        background-color: #9f84bd;
    }
    
    
    main .main-contents .wrapper_pcOnly {
        display: flex;
    }


    main .main-contents .wrapper_spOnly {
        display: none;
    }
    
    
}

@media all and (max-width: 736px) {
    main .main-contents .col-wrapper .col-text em {
        font-style: normal;
        display: block;
    }
    
    main .main-contents .col-wrapper .col-text em span {
        padding: 11px 11px 11px 0;
        margin: 23px 0 13px 0;
        color: #ef7622;
        font-weight: bold;
        background: transparent;
        display: inline;
    }

    
    
    main .main-contents .col-wrapper .col-text span {
        display: block;
        width: 307px;
        background-color: #faac5e;
        padding: 11px;
        margin: 23px 0 13px 0;
        color: #fff;
        font-weight: bold;
    }
    
    main .main-contents .col-wrapper .col-text small {
        margin-top: 11px;
        letter-spacing: 0.1px;
        text-indent: 0;
        padding: 0;
    }
    
    main .main-contents .col-wrapper .col-text small em {
        font-style: normal;
        color: #ef7622;
        display: inline;
        letter-spacing: -0.2px;
        font-weight: bold;
    }
    
    main .main-contents .col-wrapper .col-text span:nth-of-type(2) {
        background-color: #9f84bd;
    }
}


main .main-contents p {
    clear: both;
    margin-top: 10px;
}

main .main-contents .section_link {
    text-align: center; 
    margin-top: 40px;
}

main .main-contents .section_link a:hover {
    opacity: 0.5;
}



main .main-contents .with-bull {
    list-style-type: none;
    margin: 1em 0;
}

main .main-contents .with-bull li {
    text-indent: -1em;
    margin-left: 1em;
}

@media all and (max-width: 736px) {
    main .main-contents .with-bull li {
        font-size: 14px;
    }
}

main .main-contents .with-bull li:before {
    content: '・';
}

main .main-contents .with-bull02 {
    list-style-type: none;
    margin: 1em 0;
}

main .main-contents .with-bull02 li {
    text-indent: -15px;
    margin-left: 15px;
}

@media all and (max-width: 736px) {
    main .main-contents .with-bull02 li {
        font-size: 14px;
    }
}

main .main-contents .with-bull02 li:before {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    background-color: #006399;
    margin-right: 5px;
    vertical-align: baseline;
}

main .main-contents .img-wide {
    margin: 20px 0;
}

main .main-contents .img-wide img {
    max-width: 100%;
}

main .main-contents .thumbnail-wrapper {
    max-width: 320px;
    margin: 10px 0 20px 20px;
    box-sizing: border-box;
}

@media all and (max-width: 736px) {
    main .main-contents .thumbnail-wrapper {
        margin: 10px 0;
    }
}

main .main-contents .thumbnail-wrapper .caption {
    font-size: 13px;
}

main .main-contents .thumbnail-wrapper .caption span {
    font-weight: bold;
    color: #ef7622;
}

@media all and (min-width: 737px) {
    main .main-contents .thumbnail-wrapper .thumbnail {
        border: 1px solid #dedede;
    }
}

main .main-contents .thumbnail-wrapper .thumbnail + .caption {
    margin-top: 20px;
}

main .main-contents .thumbnail-wrapper .thumbnail img {
    width: 100%;
    display: block;
}

main .main-contents .thumbnail-wrapper .thumbnail .note {
    font-size: 12px;
}

main .main-contents .thumbnail-wrapper .thumbnail .btn-zoom {
    text-align: center;
    background-color: #ffefe0;
    padding: 10px 0;
}

@media all and (max-width: 736px) {
    main .main-contents .thumbnail-wrapper .thumbnail .btn-zoom {
        display: none;
    }
}

main .main-contents .thumbnail-wrapper .thumbnail .btn-zoom a {
    cursor: pointer;
    display: inline-block;
    width: 200px;
    padding-top: 10px;
    padding-bottom: 10px;
    color: #fff;
    font-size: 18px;
    font-weight: bold;
    background-color: #ef7622;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}

main .main-contents .thumbnail-wrapper .thumbnail .btn-zoom a:after {
    content: url(/assets/img/common/ico-zoom.png);
    display: inline-block;
    vertical-align: middle;
    margin-left: 15px;
    height: 27px;
}

main .main-contents .thumbnail-wrapper .thumbnail .btn-zoom a:hover {
    -webkit-opacity: .8;
    -moz-opacity: .8;
    -ms-opacity: .8;
    -o-opacity: .8;
    opacity: .8;
}

@media all and (min-width: 737px) {
    main .main-contents .thumbnail-wrapper .thumbnail-inner {
        padding: 10px;
    }
}

footer {
    background-color: #FFFFFF;
    font-size: 14px;
    padding-bottom: 10px;
}

footer nav {
    display: table;
    margin: 0 auto;
    max-width: 1020px;
    padding: 0 0 25px;
}

footer ul {
    display: table-cell;
    list-style-type: none;
    -webkit-justify-content: center;
    justify-content: center;
    -ms-flex-pack: center;
    margin-bottom: 1em;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    border-right: 1px #FA9B31 solid;
    width: 340px;
    padding: 0 0 0 40px;
}

footer ul:last-child {
    border-right: none;
}

footer ul a {
    line-height: 2;
}

footer .footer-inner {
    font-size: 12px;
}

}

@media all and (max-width: 736px) {
    footer ul li {
        margin: 0 0 2px;
    }
    footer ul li a {
        font-size: 15px;
    }
    footer ul li + li {
        border-left: 1px solid #333;
    }
    footer ul li a {
        display: block;
        margin: 0 1em;
        line-height: 1;
        color: #333;
        font-size: 13px;
    }
}

@media all and (min-width: 737px) {
    footer {
        padding: 0;
    }
    #top footer {
        border-top: none;
    }
    footer ul {
        padding: 0 0 0 16px;
    }
/*
    footer ul:last-child li:last-of-type {
        margin: 21px 0 0 0;
    }
*/
}

@media all and (max-width: 736px) {
    footer nav {
        display: inline;
        margin: 0;
        max-width: 100%;
    }
    footer ul {
        list-style-type: none;
        -webkit-justify-content: center;
        justify-content: center;
        -ms-flex-pack: center;
        margin-bottom: 1em;
        border-right: none;
        width: 100%;
        padding: 0;
        background-color: #fff;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
        -ms-flex-pack: flex-start;
        border-bottom: 1px solid #d4d4d4;
        margin-bottom: 0;
		margin-top: 0px;
    }
    footer ul li {
        width: 50%;
        margin-bottom: -1px;
        border-bottom: 1px solid #d4d4d4;
        box-sizing: border-box;
        display: flex;
        align-items: center;    

    }
    footer ul li:nth-child(2n+1) {
        border-right: 1px solid #d4d4d4;
    }
    footer ul li a {
        font-size: 11px;
        display: block;
        margin: 0;
        padding: 15px 20px;
    }
    
    
    
    footer ul li + li {
        border-left: none;
    }
    
    footer ul {
        background-color: #f4f4f4;
    }
    
    footer ul li {
        text-align: center;
    }

    footer ul li a {
        width: 100%;
    }
    
    
}

footer .copyrights {
    background-color: #d4d4d4;
    font-weight: bold;
    text-align: center;
    line-height: 1;
    padding: 30px 0;
}

@media all and (max-width: 736px) {
    footer .copyrights {
        font-weight: normal;
        font-size: 9px;
    }
}


.kv_area { 
width: 100%;
padding: 30px 0;
background-image: url("../img/top/kv_pc.png");
background-position: center center;
background-size: cover;
}
.kv_video {
max-width: 1020px;
width: 100%;
margin: 0 auto;
padding-left: 20px;
padding-right: 20px; }
video { width: 100%; height: auto; outline: none; }

@media all and (max-width: 736px) {
.kv_area {
padding: 20px 0;
background-image: url("../img/top/kv_sp.png");
} }

.contents-index.contents-nav {
background: rgb(255,251,247);
background: -moz-linear-gradient(180deg, rgba(255,251,247,1) 0%, rgba(255,246,229,1) 71%, rgba(255,254,239,1) 100%);
background: -webkit-linear-gradient(180deg, rgba(255,251,247,1) 0%, rgba(255,246,229,1) 71%, rgba(255,254,239,1) 100%);
background: linear-gradient(180deg, rgba(255,251,247,1) 0%, rgba(255,246,229,1) 71%, rgba(255,254,239,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#fffbf7",endColorstr="#fffeef",GradientType=1);
padding: 25px 0 5px;
}

@media all and (min-width: 737px) {
    .contents-index.contents-nav {
        padding: 40px 0 10px;
    }
}

.contents-index.contents-nav .ttl-contents-index {
    text-align: center;
    position: relative;
    top: -56px;
}

.contents-index.contents-nav .ttl-contents-index img {
    width: 100%;
}

@media all and (min-width: 737px) {
    .contents-index.contents-nav .ttl-contents-index {
        top: -90px;
        height: 226px;
        background: url(/assets/img/home/ttl-main.png) no-repeat center top;
    }
    .contents-index.contents-nav .ttl-contents-index img {
        display: none;
    }
}

.contents-index.contents-nav ul {
    list-style-type: none;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -ms-flex-pack: space-between;
}

.contents-index.contents-nav ul li {
    width: 48%;
    margin-bottom: 18px;
    box-sizing: border-box;
		padding: 0 !important;
	background-color: #fff;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
box-shadow: 0 0 10px rgba(231,213,194,0.9);
	}
.contents-index.contents-nav ul li img { padding: 11px 20px 4px; }
.contents-index.contents-nav ul li p { font-size: 16px; line-height: 1.4; padding: 5px 15px 15px; }
@media all and (max-width: 560px) {
.contents-index.contents-nav ul li { width: 100%; }
}

@media all and (min-width: 737px) {

    .contents-index.contents-nav ul li {
        width: 31.4%;
        margin-bottom: 30px;
        background-repeat: no-repeat;
        overflow: hidden;
    }

}


.contents-index.contents-nav ul li span.ci-btn {
    display: table;
    width: 100.5%;
    height: 70px;
    position: relative;
	background-color: #ffb45b;
	padding: 5px 10px;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
border-radius: 8px 8px 0 0;
-webkit-border-radius: 8px 8px 0 0;
-moz-border-radius: 8px 8px 0 0;
}


.contents-index.contents-nav ul li span.ci-btn span {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    font-size: 110%;
    font-weight: 500;	
	color: #722302;
    line-height: 1.2;
}


@media all and (max-width: 960px) {
.contents-index.contents-nav ul li span.ci-btn {height: 88px;}
.contents-index.contents-nav ul li span.ci-btn span {font-size: 105%;}
}
@media all and (max-width: 560px) {
.contents-index.contents-nav ul li span.ci-btn {height: 60px;}
.contents-index.contents-nav ul li span.ci-btn span {font-size: 3.2vw;}
}
@media all and (max-width: 480px) {
.contents-index.contents-nav ul li span.ci-btn {height: 54px;}
.contents-index.contents-nav ul li span.ci-btn span {font-size: 4.0vw;}
}




.banner {
    margin: 30px auto;
	width: 66%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.banner a { width: 48.5%; }
.banner a:first-child { margin-right: 3%; }

@media all and (max-width: 736px) {
.banner {
    margin: 20px auto;
	width: 100%;
}
.banner a { width: 100%; }
.banner a:first-child { margin-right: 0%; margin-bottom: 16px; }
}


/*  二階層目ここから  */
figure {
    text-align: center;
    margin: 15px;
}
figure img {
    margin-top: 15px;
}

.bold {
    font-weight: bold;
}

.indent-1 {
    padding-left: 1em;
    text-indent: -1em;
}

.indent-1_wrap {
    margin: 0;
    padding: 0 0 0 1em;
}

.summary {
    font-size: 13px;
}

.detail p {
    margin-left: 20px;
    font-size: 13px;
}

.ruby {
    line-height: 1.8em;
}

.line-title {
    font-size: 23px;
    font-weight: bold;
    color: #FA9B31;
    text-align: center;
    border-bottom: solid 1px #FA9B31;
}

.line-title span {
    display: inline-block;
}


@media all and (max-width: 736px) {
    .line-title {
        font-size: 16px;
    }

    h3 {
        font-size: 16px;
    }
}








@media all and (max-width: 736px) {
    .supervision {
        background-color: #fff;
        padding: 15px;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        border-radius: 4px;
        line-height: 1.2;
    }
    .supervision small {
        display: block;
        text-indent: -3em;
        margin-left: 3em;
    }
}



.page-contents {
padding: 50px 0 5px;
background: #fffaf3;
}
.box_01 { margin: 0 0 70px; }
.page-contents p { font-size: 18px; line-height: 1.6; margin-bottom: 10px; }
.page-contents p strong { color: #475e6e; font-weight: 700; }
img.rnd_img { border-radius: 8px; }
img.rnd_img2 { border-radius: 8px; border: 1px solid #9eacb4; }
.img_wrap { display: flex; background: #fff; border-radius: 8px; justify-content: space-between; flex-wrap: wrap; padding: 30px 60px 10px; }
.img_wrap img { width: 44%; }
@media all and (max-width: 960px) { .img_wrap { padding: 30px 40px 10px; } .img_wrap img { width: 46%; } }
@media all and (max-width: 736px) { .img_wrap { padding: 20px 20px 10px; } .img_wrap img { width: 48.5%; } }
@media all and (max-width: 560px) { .img_wrap { padding: 10px 10px 5px; } .img_wrap img { width: 48.5%; } }
.num01 { padding-left: 21px; position: relative; }
.num01:before {
content: "";
width: 18px;
height: 18px;
background-image: url("../img/common/num01.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 16px 16px;
position: absolute;
top: 6.5px;
left: 0;
}
.num01.num02:before { background-image: url("../img/common/num02.png"); }
.num01.rb:before { top: 10px; }

.sq-txt { color: #3876bc; font-weight: 700; font-size: 20px; padding-left: 0 !important; }
.dot-txt { padding-left: 20px; position: relative; }
.dot-txt:before { content: "●"; color: #91d4f5; font-size: 90%;
position: absolute;
top: 2px;
left: 0; }
.dot-txt.rb:before { top: 6px; }
.pdL_dot { padding-left: 20px; }
.pdL01 { padding-left: 2em; }
.pdT20 { padding-top: 23px; }
@media all and (max-width: 736px) {
.page-contents p { font-size: 16px; }
.dot-txt { padding-left: 19px; }
.dot-txt:before { font-size: 85%; }
.pdL_dot { padding-left: 19px; }
.num01:before { top: 4px; }
}
@media all and (max-width: 560px) {
.page-contents p { font-size: 16; }
.dot-txt { padding-left: 17px; }
.pdL_dot { padding-left: 17px; }
.dot-txt:before { top: 1px; }
.dot-txt.rb:before { top: 7px; }
.num01 { padding-left: 19px; }
.num01:before { background-size: 14px 14px; top: 3px; }

.sq-txt { padding-left: 21px; font-size: 18px; }
.sq-txt:before { font-size: 15px; top: 2.3px; }
}

.lNav { margin: 25px 0 10px; list-style: none; display: flex; justify-content: center; flex-wrap: wrap; }
.lNav li { width: 100%; position: relative; margin-right: 0; margin-bottom: 8px; display: flex; text-align: left; }
.lNav li a { display: flex; align-content: center; align-items: center; justify-content: flex-start; width: 100%;
background: #fff;
font-size: 14px;
font-weight: 700;
line-height: 1.35;
color: #3876bc;
text-align: left;
padding: 10px 20px 10px 34px;
position: relative;
border-radius: 24px;
 border: 1px solid #3876bc; }

.lNav li a:after { position: absolute;
font-family: "Font Awesome 5 Free";
font-weight: 700;
content: "\f078";
font-size: 14px;
left: 14px;
top: 50%;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);}

.lNav li a:hover { background: #3876bc; color: #fff; }
.lNav li a:hover:after { color: #fff; }


@media all and (max-width: 736px) {
.lNav { margin: 23px 0 23px; }
.lNav li { width: 100% !important; margin-right: 0 !important; margin-bottom: 8px; text-align: left; }
.lNav li:last-child { border-bottom: none; }
.lNav li a { text-align: left; justify-content: flex-start; padding-left: 32px !important; border-radius: 24px; }
.lNav li a:before { display: none; }
}
@media all and (max-width: 560px) {
.lNav li a { text-align: left; justify-content: flex-start; padding-left: 32px !important; border-radius: 60px; padding-right: 20px !important; }
.lNav li a:before { display: none; }
}
@media all and (max-width: 480px) {
.lNav li a { font-size: 2.8vw; padding: 8px 8px; }
.lNav li a:after { font-size: 2.3vw; left: 14px; }
}



/* メニュー */
.link-top a { color: #ff8b00; font-weight: 700; }
.link-top a i { margin-right: 8px; }

.menu-base { width: 100%; margin: 0; background: #fff; height: 100%; }
.menu-base .cat-top { position: relative; font-size: 110%; }
.menu-base .cat-top span { position: absolute; bottom: 1px; font-size: 10px; color: #fff; font-weight: 500; left: 50%; margin-left: -30px; }
.menu-base .cat-top a { display: block; text-align: center; padding: 10px 0 13px; color: #fff; font-weight: 700; }
.non-link { pointer-events: none !important; }
.menu-base.menu-cat1 { border-color: #ff8b00; }
.menu-base.menu-cat1 .cat-top a { background-color: #ff8b00; }
.menu-base ul { list-style: none; margin-bottom: 0; }
.menu-base ul li { margin: 0 !important; }
.menu-base ul li ul { padding: 8px; margin-bottom: 0; }
.menu-base ul li ul li { margin-bottom: 0; }
.menu-base ul li:last-child,.menu-base ul li ul li:last-child { margin-bottom: 0; }
.menu-base ul li a,
.menu-base ul li span { font-weight: 700; position: relative; display: block; padding: 22px 32px 24px 12px; line-height: 1.2; border-top: 1px dotted #a36349; }
.menu-base ul li:first-child a { border-top: none; }
.menu-base ul li a:after { content: "\f054"; font-family: "Font Awesome 5 Free"; position: absolute; top: 50%; margin-top: -12px; right: 12px; font-size: 120%; color: #722302; }
.menu-base.menu-cat1 ul li a,
.menu-base.menu-cat1 ul li span { color: #722302; background: #fff3e5; }

.menu-base ul li ul li a { font-weight: 400; font-size: 90%; padding: 4px 24px 5px 16px; position: relative; border-bottom: 1px solid #fff; }
.menu-base ul li ul li a:before { content: "・"; position: absolute; left: 0; top: 50%; margin-top: -9px; }
.menu-base ul li ul li a:after { content: "\f054"; font-family: "Font Awesome 5 Free"; position: absolute; top: 50%; margin-top: -10px; right: 0; font-size: 120%; font-weight: 700; color: #722302; }

.menu-base.menu-cat1 ul li ul li a,
.menu-base.menu-cat1 ul li ul li a:hover { background: none; }
.menu-base.menu-cat1 ul li ul li a:hover,
.menu-base.menu-cat1 ul li ul li.current a { border-bottom: 1px dotted #ff8b00; }
.cmt-box { padding: 12px; }


@media all and (min-width: 737px) {
.top-index { display: flex; justify-content: space-between; flex-wrap: wrap; }
.top-index .menu-base { width: 48%; }
.top-index .menu-cat2 ul li { margin-bottom: 24px; }
.menu-cat3 { margin-left: 52%; }
.f-nav {
background-image: url("../img/common/bottom-bg.png");
background-size: 58% auto;
background-position: 0 bottom;
background-repeat: no-repeat;
margin-bottom: -24px;
padding-bottom: 40px; }

.pcMenuWrap.m_fixed {
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
	background: #fff;
	box-shadow: 0 0 6px rgba(0, 0, 0, 0.4);
	z-index: 3;
}
.globalnav { max-width: 980px; width: 100%; margin: 0 auto; }
header .globalnav li:last-child a:before { display: none; }
}

@media all and (max-width: 377px) {
.menu-base .cat-top { font-size: 105%; }
}


@media all and (max-width: 736px) {
    .header-contents {
        background-color: #fff;
        position: relative;
        z-index: 100;
    }
    .drawer-hamburger {
        z-index: 3;
        display: block;
        width: 48px;
        height: 48px;
        box-sizing: border-box;
        background-color: #ff8b00;
        color: #fff;
        padding: 0;
        -webkit-border-radius: 24px;
        -moz-border-radius: 24px;
        border-radius: 24px;
    }
    .drawer-hamburger > span {
        display: inline-block;
        vertical-align: middle;
    }
    .drawer-hamburger:hover {
        background-color: #ff8b00;
    }
	.drawer-nav { overflow-y: hidden; }
    .drawer--top.drawer-open .drawer-nav {
        z-index: 999;
        top: 42px;
		padding: 0;
		width: 100% !important;
		margin-left: 0;
		overflow-y: hidden;
		margin-top: 40px;
    }
    main {padding-top: 180px;}
    .drawer--top .drawer-hamburger,
    .drawer--top.drawer-open .drawer-hamburger {
        top: 23px;
        right: 16px;
        text-align: left;
        padding-left: 8px;
    }
    .drawer-hamburger-icon,
    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        width: 20px;
        height: 3px;
        background-color: #fff;
        -webkit-border-radius: 1.5px;
        -moz-border-radius: 1.5px;
        border-radius: 1.5px;
    }
    .drawer-hamburger-icon {
        top:-2px;
		right: -6px;
    }
    .drawer-hamburger-icon:before {
        top: -8px;
    }
    .drawer-hamburger-icon:after {
        top: 8px;
    }
    .sr-only {
        position: relative;
        width: 88px;
        height: 42px;
        padding-top: 10px;
        font-size: 14px;
        text-align: center;
        color: #fff;
		font-weight: 700;
    }
    .drawer-open .sr-only:before {
        content: '閉じる';
		position: relative;
		top: -2px;
		left: -6px;		
    }
    .drawer-open .sr-only span {
        display: none;
    }
    
    header .logo_wrapper ul {
        display: none;
    }
    
    #footer {
        padding: 13px 10px 13px 25px;
        border-left: 8px solid #e1242a;
    }

    #footer .footer-inner {
        padding: 0;
        width: auto;
    }

    #footer ul {
        font-size: 12px;
    }
    
    #footer p {
        margin-top: 15px;
        font-size: 12px;
    }

    #footer ul li {
        float: left;
        list-style-type: none;    
    }   

    #footer ul li ~ li::before {
        margin: 0 0.5em;
        content: "|";
    }    

    
}
@media all and (max-width: 640px) {main {padding-top: 180px;}}
@media all and (max-width: 540px) {main {padding-top: 170px;}}

@media all and (max-width: 480px) {
header .logo a img {
    width: 230px;
    height: auto;
}
    header .inner {
        padding-left: 10px;
        padding-right: 10px;
    }
    .drawer-hamburger {
        width: 48px;
        height: 48px;
    }
    .drawer--top .drawer-hamburger,
    .drawer--top.drawer-open .drawer-hamburger {
        top: 14px;
		right: 6px;
    }

	.drawer-open .sr-only:before {
	position: relative;
	top:-2px;
	left: -3px; }
    .sr-only {
        position: relative;
        width: 50px;
        height: 27px;
        padding-top: 3px;
        font-size: 12px;
        text-align: center;
        color: #fff;
		font-weight: 700;
    }
    .drawer--top.drawer-open .drawer-nav {
        top: 32px;
    }
    main {padding-top: 160px;}

}
@media all and (max-width: 420px) { .drawer--top.drawer-open .drawer-nav {top: 27px;}main {padding-top: 140px;}}
@media all and (max-width: 380px) {
header .logo a img {
    width: 240px;
    height: auto;
}
    .drawer--top .drawer-hamburger,
    .drawer--top.drawer-open .drawer-hamburger {
        top: 11px;
		right: 4px;
    }
    .drawer--top.drawer-open .drawer-nav {
        top: 22px;
    }
    main {padding-top: 140px;}
}
@media all and (max-width: 338px) { .drawer--top.drawer-open .drawer-nav {top: 19px;}}

/*　ページTOP */
.page-top {
    display: none;
    position: fixed;
    bottom: 23px;
    right: 15px;
	z-index: 8;
}
.page-top a {
    display: block;
    text-align: center;
    color: #3876bc;
	font-weight: 500;
    text-decoration: none;
}
.page-top a i { margin-left: 5px; font-size: 30px; }
.page-top a:hover {
	filter:alpha(opacity=80);
    -moz-opacity: 0.8;
    opacity: 0.8;
}
@media all and (max-width: 736px) {
.page-top-area { padding: 10px 0; position: relative; height: 60px; }
.page-top {
    position: absolute;
    bottom: 20px;
    right: 20px;
}
}


/* TOP */
.tel-box {
background-color: #f3f3f3;
padding: 36px;
color: #545455;
margin-bottom: 40px;
}
#banner-phone { margin: 24px 0; }
#banner-phone img { max-width: 360px; width: 100%; height: auto; }
@media all and (max-width: 736px) {
.tel-box { padding: 20px; font-size: 90%; margin-bottom: 24px; }
}

/* カレント指定 */
#top header .globalnav li.gn01 a,
#pi-01 header .globalnav li.gn02 a,
#pi-02 header .globalnav li.gn03 a,
#pi-03 header .globalnav li.gn04 a,
#pi-04 header .globalnav li.gn05 a,
#pi-05 header .globalnav li.gn06 a,
#pi-06 header .globalnav li.gn07 a,
#pi-07 header .globalnav li.gn08 a { background-color: #ffb45b; color: #722302; }


/* 共通パーツ */
.obi { 
background-image: url("../img/common/ttl_bg_m.png");
background-position: center center;
background-size: cover;
padding: 30px 0; }
.obi_ttl_wrap { padding: 40px 0; width: 100%; position: relative; }
.obi_ttl { background: #fff; border-top: 10px solid #f2b163;
width: 100%;
min-height: 200px;
display: flex;
align-content: center;
align-items: center;
justify-content: center;
box-shadow: 0px 2px 10px 2px #e4ebeb; }
.obi_ttl h1 { font-weight: 700; font-size: 200%; text-align: center; }
.obi_img {
position: absolute;
top: 50%;
left: 36px;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
width: 130px;
height: auto;
z-index: 1;
}
.obi_ttl h1 { position: relative; z-index: 2; }
.obi_img.obi_md { width: 175px; }
.obi_img.obi_img_long { left: 12px; width: 240px; }
@media all and (min-width: 800px) {
.obi_img.obi_md { left: 72px }
.obi_img.obi_img_long { left: 30px; }
}

@media all and (max-width: 768px) {
.obi {
padding: 30px 0;
background-image: url("../img/common/ttl_bg_s.png");
}
.obi_ttl { min-height: 160px; }
.obi_ttl_wrap { padding: 20px 0; }
.obi_ttl h1 { font-size: 180%; }
}

@media all and (max-width: 736px) {
.obi_ttl { min-height: 120px;  border-top: 8px solid #f2b163; }
.obi_ttl h1 { font-size: 150%; padding: 0 100px; }
.obi_img { width: 90px; left: 12px; }
.obi_img.obi_img_long { left: 8px; width: 160px; }
}
@media all and (max-width: 640px) {
.obi_img.obi_md { width: 144px; left: 10px; }
.obi_ttl h1 { font-size: 140%;}}

@media all and (max-width: 560px) {
.obi_img.obi_img_long { left: 0; width: 110px; }
.obi_img.obi_md { width: 118px; left: 10px; }
.obi_ttl h1 { font-size: 130%;}
.obi_ttl.obi_nrm h1 { padding: 0 80px 0 108px; }}
@media all and (max-width: 480px) {
.obi { padding: 5px 0; }
.obi_ttl { min-height: 100px; border-top: 6px solid #f2b163; }
.obi_ttl h1 { font-size: 120%; padding: 0 76px; }
.obi_ttl.obi_long { justify-content: flex-start; }
.obi_ttl.obi_long h1 { padding: 0 20px 0 110px; }
.obi_img { width: 78px; left: 12px; }
.obi_img.obi_md { width: 96px; left: 12px; }
.obi_ttl.obi_nrm h1 { padding: 0 12px 0 94px; }
}
@media all and (max-width: 420px) {.obi_ttl h1{font-size: 4.6vw;}}
@media all and (max-width: 394px) {
.obi_ttl h1{font-size: 4.4vw;}
.obi_img.obi_md { width: 80px; left: 10px; }
.obi_ttl.obi_nrm h1 { padding: 0 10px 0 60px; }
}

.obi_ttl h1{text-shadow:0px 0px 5px #fff;}

.ttl-01 {
background: #3876bc;
color: #fff;
font-size: 135%;
padding: 19px 20px 20px;
line-height: 1.2;
text-align: center;
font-weight: 700 !important;
margin: 0 0 25px;
}
.ttl-01-top { margin: 40px 0 15px; }
@media all and (max-width: 560px) { .ttl-01 { margin: 0 0 20px; } .ttl-01-top { margin: 40px 0 15px; } }
@media all and (max-width: 480px) { .ttl-01-top { margin: 25px 0 10px; } }
.ttl-02 {
color: #3876bc;
font-size: 120%;
padding: 0 0 6px;
line-height: 1.3;
margin-bottom: 16px;
font-weight: 700 !important;
border-bottom: 1px solid #3876bc;
}
.ttl-03 span {
background: #526baa;
width: 130px;
text-align: center;
font-weight: 700;
color: #fff;
line-height: 1.1;
padding: 5px 10px 6px;
display: inline-block;
}
.ttl-04 {
display: inline-block;
background: #146d99;
width: 200px;
font-weight: 700;
font-size: 140%;
line-height: 1.1;
padding: 14px 10px 15px;
position: absolute;
z-index: 2;
color: #fff;
top: -27px;
left: -40px;
text-align: center;
}
.ttl-04:before { content: ""; width: 100%; height: 100%;
position: absolute;
box-shadow: 1px 2px 4px 1px #dfdfdf;
top: 0;
left: 0; }
.box_03 {
background-image: url("../img/under/gbg.gif");
background-position: center center;
background-size: 100% 100%;
margin-left: 40px;
padding: 33px 30px 33px;
box-shadow:0px 0px 5px 4px #eeeadc inset;
position: relative; }
.box_03:before { content: ""; width: 100%; height: 100%;
position: absolute;
box-shadow: 1px 2px 4px 1px #dfdfdf;
top: 0;
left: 0; }
.box_03 p { color: #475e6e; font-weight: 700; font-size: 120%; }
@media all and (max-width: 560px) {
.ttl-04 { font-size: 120%; padding: 10px 10px 11px; width: 168px; top: -24px; }
.box_03 p { font-size: 16px; }
.box_03 { padding: 23px 20px 23px; }
}


.txt-box01 { display: inline-block; background: #ebf6f7; font-weight: bold; font-size: 120%; padding: 9px 12px 11px; margin: 0; line-height: 1.3 !important; }
.img-type01,.img-type02,.img-type03,.img-type04 { text-align: center; }
.img-type01 img { width: 80%; height: auto; }
.img-type02 img { width: 60%; height: auto; }
.img-type03 img { width: 25%; height: auto; }
.img-type04 img { width: 50%; height: auto; }
.w80_2 { width: 80%; margin: 0 auto; }

.icon-box {
padding: 20px 20px 20px 88px;
border-radius: 8px;
background-size: 54px auto;
background-position: 17px center;
background-repeat: no-repeat;
}
.icon-box p { margin-bottom: 0 !important; line-height: 1.6; }

.dot-box {
padding: 20px;
border: 2px dotted #ff8b00;
border-radius: 8px;
}
.dot-box02 { padding-bottom: 12px; }
.dot-box03 { border: none; background: #EBF8F9; }

.w100 { max-width: 100%; height: auto; }
.w80 { max-width: 80%; height: auto; }
.w80_txt { margin-right: 10%; }
.w80_txt2 { margin-left: 10%; }
.phR { float: right; width: 16%; margin-left: 10px; padding: 10px; }
.phR2 { float: right; width: 25%; min-width: 240px; margin-left: 10px; }
.phR3 { float: right; width: 14%; min-width: 120px; margin-left: 18px; }
.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}
@media all and (max-width: 640px) {
.phR { width:26%; margin-left: 10px; padding: 10px 5px; }
.w80 { max-width: 100%; height: auto; }
.w80_txt { margin-right: 0; }
.w80_txt2 { margin-left: 0; }
}
@media all and (max-width: 560px) {
.phR2 { float: none; margin: 0 auto; width: 70%; }
.phR3 { float: right; width: 14%; min-width: 100px; margin-left: 13px; }
}
@media all and (max-width: 480px) {
.phR { width:33%; margin-left: 0; padding: 10px 5px; }
}

.img-tks01 { margin-top: -100px; margin-bottom: -40px; width: 150px !important; margin-right: -30px; }

@media all and (max-width: 680px) {
.img-tks01 { margin-top: 0; margin-right: 0; margin-bottom: 0; }
}

@media all and (max-width: 420px) {
.img-tks01 { width: 120px; height: auto; float: none; margin-top: 20px; }
.flex-tks01 { display: flex; justify-content: space-between;
        -webkit-flex-direction: column-reverse;
        -moz-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
        -o-flex-direction: column-reverse;
        flex-direction: column-reverse;
		flex-wrap: nowrap;}
.flex-tks01 p { width: 100%; }
}

.list-type01 { list-style: none; }
.list-type01 li { font-size: 100%; margin-bottom: 12px; position: relative; padding-left: 21px; }
.list-type01 li span { font-weight: bold; }
.list-type01 li:before { content: "●"; color: #87ced8; font-size: 80%; position: absolute; left: 0; top: 3px; }

.list-check { list-style: none; background: #fff; border: 3px solid #fbcb73; padding: 16px 16px 7px; }
.list-check.list-check2 { background: none; border: none; padding: 0; }
.list-check li { font-size: 18px; margin-bottom: 9px; position: relative; padding-left: 22px; display: block; margin-right: 23px; color: #231916; font-weight: 500; }
.list-check li:before { content: "\f00c"; font-family: "Font Awesome 5 Free"; color: #3fbff0; font-size: 80%; position: absolute; left: 0; top: 6px; font-weight: bold; }
.list-check li.rb:before { top: 12px; }
/*.list-w01 { width: 80%; margin-left: 10%; margin-right: 10%; }*/
.list-w02 { padding-left: 7%; padding-right: 7%; }
@media all and (max-width: 736px) {
.list-check li { font-size: 16px; padding-left: 20px; }
}



.anch { padding-top: 60px; margin-top: -60px; }

@media all and (max-width: 736px) {
.txt-box01 { font-size: 110%; }
.block01 { margin-bottom: 48px; }
.ttl-01 {font-size: 120%;}
.img-type01 img { width: 100%; }
.img-type02 img { width: 80%; }
.img-type03 img { width: 40%; }
.img-type04 img { width: 65%; }
.w80_2 { width: 100%; }
.anch { padding-top: 100px; margin-top: -100px; }
}

@media all and (max-width: 560px) {
.img-type02 img { width: 100%; }
.img-type03 img { width: 50%; }

.icon-ttl-01 { font-size: 130%; padding: 0 10px 18px 32px;
background-position: 0 4px;
background-size: 22px auto;
margin-bottom: 22px; }

.icon-box {
padding: 15px 15px 15px 64px;
background-size: 44px auto;
background-position: 11px center;
}


.dot-box {
padding: 16px;
border: 2px dashed #ff8b00;}
.dot-box02 { padding-bottom: 8px; }
}

@media all and (max-width: 480px) {
.ttl-01 {font-size: 4.6vw;padding: 14px 12px 15px; letter-spacing: -0.5px; }
.anch { padding-top: 70px; margin-top: -70px; }
}

@media all and (max-width: 360px) {
.anch { padding-top: 60px; margin-top: -60px; }
}

.sp-img { width: 32%; }
.sp-txt { width: 65%; }
@media all and (max-width: 560px) {
.sp-img { width: 100%; text-align: center; margin-bottom: 16px; }
.sp-txt { width: 100%; }
}


/* foot nav */
.flex-box { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; }
.foot-nav {
    background-color: #f9fae8;
    padding: 30px 0 8px;
	margin-top: 54px;
}
ul.foot-list { width: 48.5%; list-style: none; }
ul.foot-list li { margin-bottom: 28px; width: 100%; }
ul.foot-list li a,
ul.foot-list li span {
font-size: 115%; font-weight: bold; padding: 0 10px 5px 33px; border-bottom: 1px solid #aedfd6;
background-image: url("../img/common/icon02.png");
background-position: 0 2px;
background-repeat: no-repeat;
background-size: 23px auto;
color: #ff8b00;
display: block;
position: relative;
}
ul.foot-list li ul { list-style: none; padding-top: 8px; }
ul.foot-list li ul li { margin-bottom: 6px; }
ul.foot-list li ul li a { color: #545455; background: none; border-bottom: none; font-size: 100%; font-weight: normal;
 padding: 0 10px 0 33px; }
 ul.foot-list li ul li a:hover,
 #pi-01 .fn-01,
 #pi-02 .fn-02,
 #pi-03 .fn-03,
 #pi-04 .fn-04,
 #pi-05 .fn-05,
 #pi-06-1 .fn-06-1,
 #pi-06-2 .fn-06-2,
 #pi-07 .fn-07,
 #pi-08 .fn-08 { font-weight: bold; }
 
ul.foot-list li a:after { content: "\f0a9"; font-family: "Font Awesome 5 Free"; position: absolute; top: 50%; margin-top: -15px; right: 12px; font-size: 120%; }
ul.foot-list li ul li a:after { font-size: 100%; margin-top: -7px; font-weight: bold; color: #7d7d7d; }
 #pi-01 .fn-01:after,
 #pi-02 .fn-02:after,
 #pi-04 .fn-04:after,
 #pi-05 .fn-05:after,
 #pi-06-1 .fn-06-1,
 #pi-06-2 .fn-06-2 { color: #545455; }
ul.foot-list li a:hover:after {right: 10px; }
ul.foot-list li ul li a:hover:after{ color: #545455; right: 10px; }

@media all and (max-width: 736px) {
ul.foot-list { width: 100%; }
ul.foot-list li a,
ul.foot-list li span { font-size: 100%; background-size: 20px auto; padding: 0 10px 5px 25px; }
ul.foot-list li ul li a { font-size: 90%; padding: 0 10px 0 25px; }
ul.foot-list li { margin-bottom: 20px; }
}



@media print {
.banner-img { box-shadow: none; }
.drawer-nav { display: none; }
header {
    position: relative;
	top: 0;
	left: auto;
	right: auto;
	width: 100%;
	margin-bottom: 0 !important;
}
main { margin-top: 0 !important; }
.drawer--top .drawer-hamburger { display: none; }

}




.ps_rlt { position: relative; }
.dw_btn { position: absolute; right: 10px; bottom: 0; } 
.dw_btn a { width: 90px; line-height: 1.1; padding: 4px 20px 5px; text-align: center; font-size: 80%; color: #fff;
background: #F3823F; border: 3px double #F3823F; border-radius: 5px;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease; }
.dw_btn a i { margin-right: 8px; font-size: 120%; }
.dw_btn a:hover {
    -webkit-opacity: .8;
    -moz-opacity: .8;
    -ms-opacity: .8;
    -o-opacity: .8;
    opacity: .8; }

.img_tks01 { margin-right: 20%; }
@media all and (max-width: 700px) {
.img_tks01 { margin-right: 10%; }
}

@media all and (max-width: 560px) {
.dw_btn { position: relative; text-align: center; margin: 20px auto; }
.img_tks01 { margin-right: auto; }
}



.next-box {
padding: 30px;
background: rgb(201,227,236);
background: -moz-linear-gradient(0deg, rgba(201,227,236,1) 0%, rgba(238,238,232,1) 85%, rgba(232,239,238,1) 100%);
background: -webkit-linear-gradient(0deg, rgba(201,227,236,1) 0%, rgba(238,238,232,1) 85%, rgba(232,239,238,1) 100%);
background: linear-gradient(0deg, rgba(201,227,236,1) 0%, rgba(238,238,232,1) 85%, rgba(232,239,238,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#c9e3ec",endColorstr="#e8efee",GradientType=1);
display: block;
}

.page_btn { 
font-size: 90%;
font-weight: bold;
padding: 12px 20px;
border: 2px solid #ff8b00;
box-sizing: border-box; 
background: #fff;
border-radius: 60px;
margin: 0 20px;
box-sizing: border-box;
display: flex;
justify-content: center;
align-items: center;
align-content: stretch;
z-index: 3;
box-shadow:0px 13px 8px -8px #b5c8d0;
width: 300px;
text-align: center;
height: 72px; }
.page_btn i { font-family: "Font Awesome 5 Free"; font-weight: 700; margin: 4px 8px 0; }

.page_btn:hover { color: #722302; background: #fff3e5; }

.nr_btn { display: flex; justify-content: center; flex-wrap: nowrap; max-width: 980px; margin: 0 auto; width: 100%; align-items:stretch ; align-content: stretch; }

@media all and (max-width: 680px) {
.page_btn { padding: 14px; margin: 0; font-size: 2.3vw; width: 48.5%; }
.page_btn:nth-child(2) { margin-left: 3%; }
.next-box { padding: 18px; }}

@media all and (max-width: 480px) {
.next-box { padding: 14px; }
.page_btn { padding: 8px 10px; }
.page_btn i { margin: 4px 8px 0 0; }
.page_btn:nth-child(2) i { margin: 4px 0 0 8px; }
.page_btn { height: 12vw; }
}
@media all and (max-width: 388px) {.next-box { padding: 12px; }}

.txt-id01 { text-indent: -1em; padding-left: 1em; }
.txt-id02 { text-indent: -2.52em; padding-left: 2.52em; }
.txt-id03 { text-indent: -1.22em; padding-left: 1.22em; }
.txt-id04 { text-indent: -1.18em; padding-left: 1.18em; }

.table01 { border-bottom: 1px solid #9eacb4; border-right: 1px solid #9eacb4;
border-collapse: separate;
border-spacing: 0px;
width: 100%;
background: #fff; }
.table01 th,.table01 td { border-top: 1px solid #9eacb4; border-left: 1px solid #9eacb4; font-size: 18px;  padding: 16px 20px; }
.table01 th { font-weight: 700; white-space: nowrap; background-color: #fef7d8; line-height: 1.3; color: #475e6e; vertical-align: middle; text-align: left; }
.table01 td { font-weight: normal !important; text-align: left; line-height: 1.35 }
@media all and (min-width: 737px) {.table01 th{width:160px;}}
@media all and (max-width: 736px) {
.table01 th, .table01 td { padding: 13px 18px; font-size: 16px; }
.table01 th {width:130px;}
.table-wrap {
  overflow-x: scroll;
}
}
.table {
  width: 100%;
  border-collapse: collapse;
  white-space: nowrap;
}
@media all and (max-width: 560px) { 
.table01 th, .table01 td { padding: 12px; font-size: 16px; }
.table01 th { padding-right: 0px; font-size: 16px; width: 96px; }
.td_sp_nw { white-space: nowrap; } }


/* ディスクレーマー */
.disc-ttl { color: #155268; font-size: 130%; font-weight: 700; padding-bottom: 8px; }
.disc-ttl span { font-size: 90%; }
.txt-confirm span { font-weight: 700; font-size: 110%; }
.remodal {
    max-width: 760px !important;
	padding: 25px !important;
}
.modal-confirm .logo-full {
    width: 360px;
    margin: 30px auto;
}

@media all and (max-width: 736px) {
    .modal-confirm .logo-full {
        width: 180px;
        margin: 20px auto;
    }
}

.modal-confirm .logo-full img {
    width: 100%;
    height: auto;
}

.modal-confirm .txt-confirm {
    text-align: left;
    font-size: 14px;
    line-height: 1.857;
    margin: 0 5px;
    padding: 1.5em 0;
    border-top: 3px solid #ff8b00;
}

@media all and (max-width: 736px) {
    .modal-confirm .txt-confirm {
        padding: 20px 0;
        font-size: 14px;
        margin: 0 5px;
        line-height: 1.5;
    }
}
@media all and (max-width: 480px) {
    .modal-confirm .txt-confirm {
        padding: 14px 0;
        font-size: 12px;
		line-height: 1.35;
    }
}

.modal-confirm .bx-confirm {
    background-color: #eff8fd;
    padding: 30px;
    font-size: 16px;
	font-weight: bold;
	color: #545455;
}

@media all and (max-width: 736px) {
    .modal-confirm .bx-confirm {
        padding: 15px;
		font-size: 14px;
    }
	.remodal { padding: 20px !important; }
.disc-ttl { font-size: 120%; line-height: 1.4; }
.disc-space { width: 16px; display: block; }
}

@media all and (max-width: 480px) {
.modal-confirm .bx-confirm { font-size: 12px; }
.remodal { padding: 11px !important; }
.disc-ttl { font-size: 100%; line-height: 1.4; }
.disc-ttl span { font-size: 80%; } }

.modal-confirm .bx-confirm p {
    margin-bottom: 1em;
    text-align: left;
    line-height: 1.5;
}

.modal-confirm .bx-confirm .btn-wrapper > * {
    display: inline-block;
    width: 200px;
    height: 50px;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    margin: 20px;
    line-height: 50px;
}

@media all and (max-width: 736px) {
    .modal-confirm .bx-confirm .btn-wrapper > * {
        width: 42%;
        height: 44px;
        line-height: 44px;
        font-size: 16px;
        margin: 10px;
    }
}

.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree {
    background-color: #0599e1;
	position: relative;
	z-index: 5;
}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree:before,
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree:after {
width: 100%;
height: 10px;
left: 0;
content: "";
position: absolute;
z-index: -2;
border-radius: 4px;
}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree:before {
background-color: #2382b1;
bottom: -5px;}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree:after {
background-color: #0599e1;
bottom: 0;}

.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree {
    background-color: #db64be;
	position: relative;
	z-index: 5;
}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree:before,
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree:after {
width: 100%;
height: 10px;
left: 0;
content: "";
position: absolute;
z-index: -2;
border-radius: 4px;
}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree:before {
background-color: #ac4192;
bottom: -5px;}
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree:after {
background-color: #db64be;
bottom: 0;}

.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree,
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree {
box-shadow: 0 7px 5px rgba(0, 0, 0, 0.3); }
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-agree:hover,
.modal-confirm .bx-confirm .btn-wrapper .remodal-confirm-disagree:hover {
filter:alpha(opacity=80);
	-moz-opacity: 0.8;
	opacity: 0.8;}


/* video */
.video_wrap{
position: relative;
padding-bottom: 56.25%;
height: 0;
overflow: hidden;
box-shadow: 0 0 10px rgba(231,213,194,0.9);
}
.video_wrap iframe, .video_wrap object, .video_wrap embed{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

.link01 { color: #0071ad; }
.link01 a { color: #0071ad; text-decoration: underline; }
.link01 a:hover { color: #00B9DC; }


/* header 追記 */
@media all and (min-width: 737px) { header { z-index: 8; position: relative; height: 252px; } }
@media all and (max-width: 736px) { header { z-index: 8; position: fixed; } }


@media all and (max-width: 736px) {
header .inner { padding: 0 !important; }
.header-contents { padding: 0 20px; z-index: 100; }
}

/* 追記202309 */
.ci-menu li { border-radius: 8px; }
header .logo { position: relative; z-index: 1; }

@media all and (min-width: 737px) {
header .globalnav li { height: 74px !important; }
.takeda_common { height: 80px !important; flex-wrap: nowrap; }
	}
@media all and (max-width: 820px) and (min-width: 737px) {
    header .logo_comp { width: 34%; }
    header .logo_wrapper ul li { font-size: 12px !important; }
	}
@media all and (min-width: 800px) {
.takeda_common { display: flex; justify-content: space-between; flex-wrap: wrap; } 
header .logo_wrapper ul { padding-top: 26px; }
header .logo a img { width: 480px; height: auto; }
header .logo { margin-top: -20px; }
}

@media all and (max-width: 799px) {
header .logo_wrapper ul { position: absolute; right: 0; top: 55px; }
header .logo { padding-top: 0; }
header .logo a img { width: 420px; height: auto; }}

@media all and (max-width: 736px) {
header .logo { padding-top: 0; height: 99px; }
header .logo a img { width: 50%; height: auto; top: 0; min-width: 240px; }
.logo_comp { width: 60%; }
header .logo_comp { padding-top: 18px; height: 88px; }
}
@media all and (max-width: 560px) {
.logo_comp { width: 65%; }
header .logo_comp { height: 76px; }
header .logo { height: 80px; }
}
@media all and (max-width: 480px) {
header .logo_comp { height: 70px; }
header .logo { height: 76px; }
}
@media all and (max-width: 400px) {
header .logo_comp { padding-top: 16px; }
}
@media all and (max-width: 360px) {
.logo_comp { width: 82%; }
header .logo_comp { padding-top: 12px; }
}

.nt_ruby { position: relative; top: -4px; }
.rb_01 { position: relative; top: -4px; }
@media all and (max-width: 560px) {
.rb_01 { position: relative; top: -2px; }}

.contents-index.contents-nav ul li { position: relative; padding-bottom: 70px !important; }
.top_link { text-align: center; position: absolute; bottom: 0; right: 0; display: block; word-break: keep-all; }
a.top_link_btn { display: block; box-sizing: border-box; padding: 5px 13px 5px 15px; background: #ff8b00; color: #fff; border-radius: 30px; font-size: 24px; position: relative; font-weight: 500; border: 2px solid #ff8b00;
font-family: "Font Awesome 5 Free";
font-weight: 700; }
i { font-style: normal !important; }
a.top_link_btn:hover { background: #fff; color: #ff8b00; }
a.top_link_btn:hover:after { color: #ff8b00; }
.drawer-nav { z-index: 999; }
