@charset "UTF-8";
/* CSS Document */

/* -----------------------------------------------------
Reset
----------------------------------------------------- */
html, body, div, span,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline;
}

article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}

body { line-height: 1; }
ol, ul { list-style: none; }
table { border-collapse: collapse; border-spacing: 0; }

* { margin: 0; padding: 0; }
img { max-width: 100%; width: auto; height: auto; vertical-align: bottom; }

html { font-size: 100%; }
body { color: #000; font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif"; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; /*text-align: justify; text-justify: inter-ideograph;*/ }
a { color: #000; text-decoration: none; }


/* -----------------------------------------------------
Layout
----------------------------------------------------- */
#Container { width: 100%; }

/* -----------------------------------------------------
Header
----------------------------------------------------- */
header { background: #00a072; height: 70px; position: fixed; width: 100%; top: 0; z-index: 10; }
header .inner { max-width: 990px; width: 90%; margin: auto; display: flex; justify-content: space-between; align-items: center; height: 100%; }
header h1 { color: #FFF; font-weight: bold; }
header #HeadRight { display: flex; justify-content: flex-end; align-items: center; }
header #HeadRight .time { background: #FFF; border-radius: 5px; font-size: 0.875em; line-height: 1.3em; padding: 5px 15px; color: #00a072; }
header #HeadRight .time span { display: block; border-top: 1px solid #00a072; margin-top: 3px; padding-top: 3px; }
header #HeadRight .tel { color: #FFF; font-size: 0.875em; line-height: 1.3em; text-align: right; margin-left: 30px; }
header #HeadRight .tel img,#Floating ul li img { width: 233px; height: auto; }
header #HeadRight .tel a,#Floating ul li a { pointer-events: none; }

/* -----------------------------------------------------
Footer
----------------------------------------------------- */
footer ul { display: flex; gap:35px; justify-content: center; font-size: 0.750rem; }
footer ul li a:hover {text-decoration: underline; }
footer p { background: #00a072; font-size: 0.750rem; color: #FFF; text-align: center; padding: 12px 0; margin-top: 15px; }


/* -----------------------------------------------------
Contents
----------------------------------------------------- */
#Contents .inner { max-width: 990px; width: 90%; margin: auto; }
#MainImg { background: url(../images/main_bg.jpg) no-repeat; background-size: 100% 100%; text-align: center; padding: 15px 0; margin-top: 70px; }
#MainImg img { max-width: 100%; width: 95%; }
.bg { background: #ebf2ea; }
br.br { display: none; }
br.sp,img.sp { display: none; }

h2 { font-size: 1.500em; width: 100%; font-weight: bold; text-align: center; }
h2::before { content: ""; display: block; width: 8em; height: 1px; background: #00a072; margin: 0 auto 10px auto; }
h2::after { content: ""; display: block; width: 8em; height: 1px; background: #00a072; margin: 10px auto 0 auto; }


#Benefit { padding: 45px 0 60px 0; }
#Benefit ul { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }
#Benefit ul li { width: 32%; border: 1px solid #00a072; border-radius: 10px; height: 65px; box-sizing: border-box; margin-top: 10px; display: flex; justify-content: center; align-items: center; font-size: 1.188em; color: #00a072; font-weight: bold; text-align: center; }
#Benefit ul li span { display: inline-block; background: #00a072; color: #FFF; border-radius: 10px; height: 35px; display: flex; align-items: center; padding: 0 10px; margin-left: 5px; }
.btn { max-width: 350px; width: 90%; margin: 40px auto 0 auto; }
.btn a { display: block; background: #00a072; font-weight: bold; text-align: center; color: #FFF; padding: 20px 0; border-radius: 10px; }
.btn a:hover { background: rgba(0,160,114,0.80); transition: .3s; }

#About { padding: 35px 0 45px 0; text-align: center; }
#About .ttl,.plan .ttl + ul + p { font-size: 1.250em; font-weight: bold; }
#About .ttl::before,.plan .ttl + ul + p::before { content: ""; display: inline-block; width: 19px; height: 2px; background: #00a072; transform: rotate(45deg); vertical-align: middle; margin-right: 10px; }
#About .ttl::after,.plan .ttl + ul + p::after { content: ""; display: inline-block; width: 19px; height: 2px; background: #00a072; transform: rotate(-45deg); vertical-align: middle; margin-left: 10px; }
#About .ttl + p { font-size: 0.875em; line-height: 1.8em; margin-top: 35px; }
#About .sttl { font-size: 1.063em; font-weight: bold; margin-top: 40px; position: relative; }
#About .sttl::before { content: ""; display: inline-block; width: 0; height: 0; border-style: solid; border-width: 18px 20.5px 0 20.5px; border-color: #00a073 transparent transparent transparent; position: absolute; left: 0; right: 0; bottom: -40px; margin: auto; }
#About .box { background: #FFF; padding: 30px; margin-top: 60px; position: relative; }
#About .box::before { content: ""; display: block; width: 187px; height: 136px; background: url(../images/img_print01.png); background-size: 100% auto; position: absolute;  right: -40px; top: -60px; }
#About h3 { font-size: 1.500em; font-weight: bold; color: #00a072; }
#About h3 + p { font-size: 0.875em; line-height: 1.8em; margin-top: 20px; }
#About h3 + p strong { color: #ed5540; font-size: 0.938rem; font-weight: bold; }
#About .about_flx{ display:flex; margin-top:30px; gap:20px; }
#About .about_flx div{ width:300px; flex-shrink:0; }
#About .about_flx p{ font-size:17px; line-height:26px; text-align:left; }

.movie { display: flex; justify-content: space-between; }
.movie.center { justify-content: center; margin-top: 15px; }
.movie .column { width: 48%; margin-top: 50px; display: flex; flex-direction: column; justify-content: space-between; }
.movie p { font-size: 1.000em; line-height: 1.5em; font-weight: bold; margin-bottom: 20px; }
.movie.center p { text-align: center; }
.movie .moviebox a { display: block; position: relative; }
.movie .moviebox a::before { content: ""; position: absolute; z-index: 2; width: 65px; height: 47px; background: url(../images/ic_play.svg) no-repeat; left: 0; right: 0; margin: auto; top: 0; bottom: 0; }
.movie .moviebox img { position: relative; z-index: 0; }

#Flow { padding: 45px 0; }
#Flow ul { display: flex; justify-content: space-around; align-items: flex-start; margin-top: 50px; }
#Flow ul li { width: 26%; font-size: 0.875em; line-height: 1.5em; }
#Flow ul li > div { width: 132px; height: 132px; background: #00a072; border-radius: 50%; display: flex; justify-content: center; align-items: center; color: #FFF; font-weight: bold; font-size: 1.250rem; margin: 0 auto 20px auto; position: relative; }
#Flow ul li > div::after { content: ""; display: inline-block; background: url(../images/ic_arrow.png) no-repeat center; width: 44px; height: 31px; background-size: auto 100%; position: absolute; top: 0; bottom: 0; right: -95%; margin: auto; }
#Flow ul li:last-child > div::after { display: none; }
#Flow ul li p { display: table; margin: auto; }
#Flow ul li strong { color: #ed5540; font-size: 0.938rem; font-weight: bold; }
#Flow dl { display: flex; justify-content: center; align-items: center; margin-top: 50px; }
#Flow dl dt { background: #ed5540; color: #FFF; width: 155px; padding: 15px 0; text-align: center; transform: rotate(-7deg); font-size: 1.125em; }
#Flow dl dd { font-size: 0.875em; line-height: 1.5em; margin-left: 20px; }

/*240425サイズ表追加↓↓*/
#Size{ padding-top:40px; }
#Size .size_tb{ padding:45px 0; display:flex; gap:20px; }
#Size .tab{ display:flex; gap:15px; flex-wrap:wrap; justify-content:center; }
#Size .tab li{ text-align:center; font-weight:700; width:120px; padding:10px 0; color:#fff; box-sizing:border-box; border-radius:5px; cursor:pointer; transition:all 0.3s; }
#Size .tab li:nth-of-type(1){ background:#ffa300; border:2px solid #ffa300; }
#Size .tab li:nth-of-type(2){ background:#39aaff; border:2px solid #39aaff; }
#Size .tab li:nth-of-type(3){ background:#4351aa; border:2px solid #4351aa; }
#Size .tab li:nth-of-type(4){ background:#96db77; border:2px solid #96db77; }
#Size .tab li:nth-of-type(5){ background:#f27272; border:2px solid #f27272; }
#Size .tab li:nth-of-type(6){ background:#138ee2; border:2px solid #138ee2; }
#Size .tab li.active{ background:transparent; }
#Size .tab li.active:nth-of-type(1){ color:#ffa300; }
#Size .tab li.active:nth-of-type(2){ color:#39aaff; }
#Size .tab li.active:nth-of-type(3){ color:#4351aa; }
#Size .tab li.active:nth-of-type(4){ color:#96db77; }
#Size .tab li.active:nth-of-type(5){ color:#f27272; }
#Size .tab li.active:nth-of-type(6){ color:#138ee2; }
#Size .panel{ margin:40px auto; position:relative; }
#Size .panel li{ opacity:0; visibility:hidden; display:none; transition:all 0.3s; }
#Size .panel li.active{ opacity:1; visibility:visible; display:block; }
#Size .panel li .pn_inner{ display:flex; justify-content:space-between; align-items:flex-start; }
#Size .panel li .pn_inner div:nth-of-type(1){ width:40%; }
#Size .panel li .pn_inner div:nth-of-type(2){ width:55%; }
#Size .panel li .pn_inner .pnl_ttl{ font-size:22px; font-weight:700; color:#00a072; border-bottom:1px dashed #333; padding-bottom:8px; margin-bottom:10px; }
#Size .panel li .pn_inner .pnl_txt{ font-size:16px; line-height:20px; }

/*240425サイズ表追加↑↑*/

#Price .inner { padding: 45px 0; }
#Price h2 + p { font-size:1.625em; font-weight:bold; text-align:center; margin-top:20px; line-height: 1.3em; }
#Price h2 + p strong { color:#ed5540; font-size: 2.188rem; }
.price { background:#FFF; margin-top: 30px; padding: 25px; display: flex; justify-content: center; flex-wrap: wrap; position: relative; }
.price .obi { background:#ed5540; color: #FFF; position: absolute; left: -60px; top: -15px; transform: rotate(-10deg); font-size: 1.125em; width:130px; padding: 5px; box-sizing: border-box; line-height: 1.3em; display: flex; justify-content: center; }
.price > p { text-align: center; font-size: 1.250em; width: 100%; line-height: 1.3em; padding: 0 90px; }
.price > div { margin: 20px 5% 0 5%; }
.price .size { font-size: 1.938em; font-weight: bold; }
.price .size strong {font-size: 2.625rem; }
.fc { color: #ed5540; }
small { font-size: 1.000rem; display: block; margin-top: 10px; }
.price .size + p { background: #ebf2ea; font-size: 0.875em; padding: 5px 10px; margin-top: 10px; }
.price + p { font-size: 1.250em; text-align: center; margin-top: 25px; line-height: 1.3em; }
.plan { border: 1px solid #00a072; background: #FFF; margin-top: 50px; padding: 25px; }
.plan .ttl { font-size: 1.500em; color: #00a072; text-align: center; font-weight: bold; }
.plan .ttl + ul { display: flex; justify-content: center; margin-top: 30px; }
.plan .ttl + ul li { background: #00a072; color: #FFF; font-size: 1.375em; width: 248px; height: 55px; display: flex; justify-content: center; align-items: center; margin: 0 10px; font-weight: bold; }
.plan .ttl + ul + p { margin-top: 20px; text-align: center; }
.plan .list { font-size: 1.125em; display: table; margin: 15px auto 0 auto; line-height: 1.8em; }
.plan .list li { text-indent: -1em; margin-left: 1em; }
.plan .list li::before { content: "■"; color: #00a072; }
.plan .list + p { text-align: center; margin-top: 20px; }

#Price ul.dl { display: flex; justify-content: space-around; margin-top: 40px; }
#Price ul.dl li { width: 45%; }
#Price ul.dl li a { display: block; background: #00a072; font-weight: bold; text-align: center; color: #FFF; padding: 20px 0; border-radius: 10px; }
#Price ul.dl li a:hover { background: rgba(0,160,114,0.80); transition: .3s; }
#Price ul.dl li a::before { content: ""; display: inline-block; width: 18px; height: 24px; background: url(../images/ic_pdf.svg) no-repeat; vertical-align: -0.3em; margin-right: 10px; }


#Qa { padding: 100px 0; }
#Qa dl dt { font-size: 1.063em; font-weight: bold; margin-top: 30px; display: flex; line-height: 1.5em; }
#Qa dl dt::before { content: "Q"; display: inline-block; color: #339f74; font-size: 1.750rem; vertical-align: -0.1em; margin-right: 15px; }
#Qa dl dd { font-size: 0.875em; border-bottom: 1px dashed #b3b3b3; padding-bottom: 30px; margin-top: 10px; display: flex; flex-wrap: wrap; line-height: 1.3em; }
#Qa dl dd.dd_flex{ flex-wrap:nowrap;align-items:flex-start; }
#Qa dl dd .dd_mov{ border:1px solid #e4e4e4; box-sizing:border-box; padding:15px; position:relative; }
/*#Qa dl dd .dd_mov::before{content:""; position:absolute; z-index:2; width:65px; height:47px; background:url(../images/ic_play.svg) no-repeat; left:0; right:0; margin:auto; top:0; bottom:0; }*/
#Qa dl dd::before { content: "A"; display: inline-block; color: #ed5540; font-size: 1.750rem; font-weight: bold; vertical-align: -0.1em; margin-right:15px;  }
#Qa dl dd div,#Qa dl dt div { width: calc(100% - 3em); }
#Qa dl dd div a { color: #339f74; text-decoration: underline; }
#Qa dl dd div a:hover { text-decoration: none; }
#Qa dl dd div a.arrow { display: inline-block; margin-left: 20px; }
#Qa dl dd div a.arrow::before { content: ""; display: inline-block; width: 0; height: 0; border-style: solid; border-width: 5px 0 5px 5px;
border-color: transparent transparent transparent #339f74; }

#Results { padding: 50px 0; }
#Results .flex { display: flex; justify-content: space-between; flex-wrap: wrap; border: 1px solid #339f74; background: #FFF; margin-top: 50px; padding: 45px 50px; box-sizing: border-box; }
#Results .flex + .flex { margin-top: 35px; }
#Results h3 { text-align: center; width: 100%; font-size: 1.500em; font-weight: bold; color: #339f74; }
#Results h4 { background: #339f74; font-weight: bold; color: #FFF; height: 55px; display: flex; justify-content: center; align-items: center; font-size: 1.375em; }
#Results .column { width: 47%; margin-top: 30px; }
#Results .column p { font-size: 1.00em; line-height: 1.5em; margin-top: 15px; }
#Results .inner > p { font-size: 1.25em; line-height: 1.5em; text-align: center; margin-top: 25px; }
#Results .inner > p strong { color: #ed5540; }

#Voice { padding: 50px 0; }
#Voice dl.voice { display: flex; justify-content: space-between; align-items: flex-start; margin-top: 60px; }
#Voice dl.voice dt {width: 80px; }
#Voice dl.voice dd { width: calc(30% - 80px); background: #FFF; border-radius: 10px; padding: 15px; box-sizing: border-box; font-size: 0.875em; line-height: 1.5em; position: relative; }
#Voice dl.voice dd::before { content: ""; display: inline-block; width: 0; height: 0; border-style: solid; border-width: 0 0 16px 16px; border-color: transparent transparent #FFF transparent; position: absolute; left: -13px; top: 50px; }

#Forte { padding: 50px 0 80px 0; }
#Forte .box { border: 1px solid #339f74;; background: #FFF; padding: 70px 65px; margin-top: 50px; }
#Forte h3 { color: #339f74; font-weight: bold; text-align: center; font-size: 1.5em; line-height: 1.3em; }
#Forte h3 strong { color: #ed5540; }
#Forte p { margin-top: 25px; font-size: 1.125em; line-height: 1.5em; }
#Forte p.large { font-size: 1.5rem; font-weight: bold; color: #339f74; text-align: center; }
#Forte p.large strong { color: #ed5540; }
#Forte .flex { display: flex; justify-content: space-around; background: url(../images/bg_line.png) no-repeat center; margin-top: 40px; }
#Forte .column { max-width: 360px; width: 40%; padding: 75px 0; }
#Forte .column h4 { background: #339f74; color: #FFF; font-size: 1.125em; font-weight: bold; width: 250px; height: 43px; display: flex; justify-content: center; align-items: center; margin: 0 auto; letter-spacing: -0.1em; position: relative; margin-bottom: 50px; }
#Forte .column h4::after { content: ""; display: block; width: 0; height: 0; border-style: solid; border-width: 11px 6px 0 6px; border-color: #339f74 transparent transparent transparent; position: absolute; bottom: -11px; }
#Forte .column h5 {  width: 250px; border-top: 1px dashed #339f74; border-bottom: 1px dashed #339f74; height: 95px; display: flex; align-items: center; justify-content: center; line-height: 1.6em; margin: 0 auto; }
#Forte .column h5 span { text-align: center; font-size: 1.125em; }
#Forte .column h5 strong { font-size: 1.625rem; font-weight: bold; color: #339f74; }
#Forte .column .img { margin-top: 45px; }

#Contact { padding: 50px 0; }
#Contact h3 { background: #00a072; color: #FFF; text-align: center; font-size: 1.500em; font-weight: bold; padding: 15px 10px; margin-top: 95px; }
#Contact h4 { color: #00a072; text-align: center; font-size: 1.500em; font-weight: bold; margin-top: 70px; }
#Contact h4 + p { margin-top: 25px; line-height: 1.5em; }
#Contact .box { background: #FFF; padding: 40px 10px; border: 1px solid #339f74; }
#Contact .box p { font-size: 0.875em; line-height: 1.5em; text-align: center; }
#Contact dl { max-width: 620px; width: 100%; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: wrap; font-size: 0.875em; }
#Contact dl dt { width: 10em; margin-top: 15px; padding-top: 5px; box-sizing: border-box; font-weight: bold; }
#Contact dl dd { width: calc(100% - 10em); margin-top: 15px; }
#Contact .box input[type="text"],textarea { width: 100%;　-webkit-appearance: none; appearance: none; border: 1px solid #808080; font-size: 0.875rem; padding: 5px; box-sizing: border-box; }
#Contact .box dl + p { max-width: 620px; width: 100%; text-align: right; margin: 5px auto 0 auto; font-size: 0.875em; }
#Contact .box .overflow { max-width: 620px; width: 100%; margin: 0 auto; box-sizing: border-box; border: 1px solid #808080; margin-top: 25px; padding: 20px; height: 84px; overflow-y: scroll; }
#Contact .box .overflow p { text-align: left; }
#Contact .box .overflow p + p { margin-top: 25px; }
#Contact .box input[type="checkbox"] { margin-right: 5px; }
#Contact .box .overflow + p { font-weight: bold; margin-top: 25px; }
#Contact .box .overflow + p + p { margin-top: 35px; }
.btn input[type="submit"],.btn input[type="button"] { -webkit-appearance: none; appearance: none; display: block; background: #00a072; font-weight: bold; text-align: center; color: #FFF; padding: 20px 0; border-radius: 10px; max-width: 350px; width: 100%; border: none; box-shadow: none; outline: none; font-size: 1.000rem; cursor: pointer; }
.btn input[type="submit"]:hover,.btn input[type="button"]:hover { background: rgba(0,160,114,0.80); transition: .3s; }
#Contact .box dl dd.flex { display: flex; justify-content: space-between; align-items: center; }
#Contact .box dl dd.flex input[type="text"] { margin-left: 10px; }

#Contact dl.error,#Contact dl.conf { margin-top: 30px; }
#Contact dl.error dt,#Contact dl.conf dt { width: 11em; }
#Contact dl.error dd,#Contact dl.conf dd { width: calc(100% - 11em); color: #ed5540; padding-top: 5px; }
#Contact dl.conf dd { color: #000; }
#Contact dl.conf dt:nth-last-of-type(1),#Contact dl.conf dd:nth-last-of-type(1) { display: none; }
#Contact dl + .btn { display: flex; justify-content: space-around; max-width: 620px; }
#Contact dl + .btn input[type="submit"],.btn input[type="button"] { width: 47%; }
#Contact .thanks { min-height: 500px; }
#Contact .thanks .center { display: table; margin-left: auto; margin-right: auto; }
#Contact .thanks p { margin-top: 30px; line-height: 1.5em; font-size: 0.875em; }

#Rinen { padding-top: 50px; }
#Rinen dl dt { text-align: center; font-size: 1.125em; margin-top: 50px; }
#Rinen dl dd { color: #339f74; font-size: 1.5rem; text-align: center; font-weight: bold; margin-top: 15px; line-height: 1.3em; }
#Rinen ul { display: flex; justify-content: space-between; margin: 60px auto 0 auto; max-width: 920px; }
#Rinen ul li { max-width: 285px; width: 32%; border: 1px solid #339f74; box-sizing: border-box; display: flex; flex-direction: column; justify-content: center; text-align: center; }
#Rinen ul li strong { display: block; background: #339f74; color: #FFF; font-size: 1.5em; font-weight: bold; text-align: center; padding: 10px; margin-top: 0; margin-bottom: auto; }
#Rinen ul li span { display: block; margin-top: 10px; }
#Rinen ul li div { display: flex; width: 100%; flex-direction: column; justify-content: center; align-items: center; height: 100%; font-size: 1.250em; line-height: 1.3em; padding: 30px 0; box-sizing: border-box; font-weight: bold; }

#Outline { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; padding: 100px 0; }
#Outline dl { width: 56%; margin-top: 50px; display: flex; justify-content: flex-start; flex-wrap: wrap; font-size: 0.875em; line-height: 1.8em; }
#Outline dl dt { width: 9em; border-bottom: 1px solid #000; padding: 10px; box-sizing: border-box; color: #00a072; font-weight: bold; }
#Outline dl dd { width: calc(100% - 9em); border-bottom: 1px solid #000; padding: 10px; box-sizing: border-box; }
#Outline dl dd ul li { text-indent: -1em; margin-left: 1em; }
#Outline .img { width: 35%; margin-top: 50px; }
#Outline .img img { margin-top: 12px; }

#Floating { visibility: hidden; opacity: 0; position: fixed; bottom: 0; width: 100%; }

@media screen and (max-width:960px) {
	/*#Container { padding-bottom: 55px; }*/
/* -----------------------------------------------------
Header
----------------------------------------------------- */
	#Home header,header #HeadRight .time { display: none; }
	
/* -----------------------------------------------------
Contents
----------------------------------------------------- */
	#MainImg { margin-top: 0px; }
	#Benefit ul li { width: 49%; font-size: 1.125rem; white-space: nowrap; }
	
	
	#About .ttl + p { text-align: left; }
	br.tb { display: none; }
	br.br { display: inline; }
	#About .box::before {  width: 25%; background: url(../images/img_print01.png) no-repeat top; background-size: 100% auto; right: -3%; top: -25%; }
	#About h3 { width: 14em; margin: auto; line-height: 1.3em; }
	#About h3 + p { text-align: left; }
	
	#Flow ul li { position: relative; }
	#Flow ul li::after { content: ""; display: inline-block; background: url(../images/ic_arrow.png) no-repeat center center; width: 44px; height: 31px; background-size: 41px 31px; position: absolute; top: 50px; bottom: 0; right: -30%; }
	#Flow ul li > div::after,#Flow ul li:last-child::after  { display: none; }
	#Flow dl { flex-wrap: wrap; }
	#Flow dl dt { transform: rotate(0deg); }
	#Flow dl dd { margin-left: 0; margin-top: 15px; width: 100%; text-align: center; }

	/*240425サイズ表追加↓↓*/
	#Size .panel li .pn_inner{ flex-direction:column; align-items:center; gap:25px; }
	#Size .panel li .pn_inner div:nth-of-type(1),#Size .panel li .pn_inner div:nth-of-type(2){ width:100%; }
	#Size .panel li .pn_inner .pnl_ttl{ font-size:18px; padding-bottom:7px; margin-bottom:7px; }
	#Size .panel li .pn_inner .pnl_txt{ font-size:14px; line-height:20px; }
	/*240425サイズ表追加↑↑*/
    
  #Price ul.dl { justify-content: space-between; }
  #Price ul.dl li { width: 48%; }
	
	.price > p { margin-top: 10px; padding: 0; }
  .price .obi { left: -40px; top: -15px; width: 180px; }
    
  #Results .flex { padding: 25px; box-sizing: border-box; }
  #Results .column { width: 48%; }
  #Results h4 { font-size: 1.125rem; }
	
	#Voice dl.voice { flex-wrap: wrap; max-width: 400px; width: 100%; margin-left: auto; margin-right: auto; }
	#Voice dl.voice dd { width: calc(100% - 100px); }
	#Voice dl.voice dd + dt { margin-top: 20px; }
	#Voice dl.voice dd + dt + dd { margin-top: 20px; }
	
	#Contact .box p { text-align: left; }
    
    #Forte .box { padding: 25px; }
    #Forte .column { width: 45%; }
    #Forte .column h4 { width: 100%; }
    #Forte .column h5 { width: 100%; }
	
	#Outline dl { width: 60%; }
	#Outline dl dt { width: 7.5em; padding: 10px 5px; }
	#Outline dl dd { width: calc(100% - 7.5em); padding: 10px 5px; }
	
	#Floating { position: fixed; bottom: 0; width: 100%; visibility: visible; opacity: 1; }
	#Floating ul { display: flex; justify-content: space-between; width: 100%; }
	#Floating ul li:first-child { border-right: 1px solid #FFF; }
	#Floating ul li { width: 50%; background: #00a072; color: #FFF; line-height: 1.3em; font-size: 0.875em;  box-sizing: border-box; }
	#Floating ul li a { border-top: 1px solid #FFF; display: flex; justify-content: center; align-items: center; width: 100%; height: 100%; padding: 10px 0; box-sizing: border-box; }
	#Floating ul li:first-child a::before { content: ""; display: inline-block; width: 25px; height: 19px; background: url(../images/ic_mail.svg) no-repeat; margin-right: 8px; }
	#Floating ul li:last-child a::before { content: ""; display: inline-block; width: 27px; height: 27px; background: url(../images/ic_tel.svg) no-repeat; margin-right: 8px; }
	#Floating ul li a { color: #FFF; height: 100%; font-weight: bold; }
	#Floating ul li strong { font-size: 1.125rem; display: block; }
	#Floating ul li span { font-size: 0.750rem; display: block; margin-top: 3px; }
}

@media screen and (max-width:600px) {
	/*#Container { padding-bottom: 52px; }*/
/* -----------------------------------------------------
Header
----------------------------------------------------- */
	header { background: #00a072; height: 100px; padding: 10px 0; box-sizing: border-box; }
	header .inner { flex-wrap: wrap; }
	header h1 { width: 100%; text-align: center; }
	header #HeadRight { display: flex; justify-content: center; align-items: center; width: 100%; }
	header #HeadRight .tel { text-align: center; margin: 10px auto 0 auto; }
	header #HeadRight .tel a,#Floating ul li a { pointer-events: auto; }
	
	footer p { font-size: 0.688rem; }
	
/* -----------------------------------------------------
Contents
----------------------------------------------------- */
	#MainImg { padding: 0; }
	#MainImg img { max-width: 100%; width: 100%; display: none; }
	#Benefit ul li { width: 100%; }
	.btn { max-width: 350px; width: 100%; }
	
	#About h3 { font-size: 1.250rem; }
	#About .box::before {  width: 35%; background: url(../images/img_print01.png) no-repeat top; background-size: 100% auto; right: -3%; top: -20%; }
	#About .about_flx{ flex-direction:column; align-items:center; }
	#About .about_flx p{ font-size:15px; line-height:25px; }
    
  .movie { flex-wrap: wrap; }
  .movie .column { width: 100%; margin-top: 50px; display: flex; flex-direction: column; justify-content: space-between; }
	
	#Flow ul { flex-wrap: wrap; }
	#Flow ul li { width: 100%; font-size: 0.875em; line-height: 1.5em; margin-top: 20px; }
	#Flow ul li:first-child { margin-top: 0; }
	#Flow ul li::after { content: ""; display: block; width: 0; height: 0; border-style: solid; border-width: 18px 20.5px 0 20.5px; border-color: #00a073 transparent transparent transparent; position: static; left: 0; right: 0; margin: 15px auto 0 auto; background-image: none; }
	#Flow dl dd { text-align: left; }

	#Size .panel li .pn_inner .pnl_ttl{ font-size:15px; }
	#Size .panel li .pn_inner .pnl_txt{ font-size:13px; line-height:18px; }
	
	#Price h2 + p { font-size: 1.500rem; }
	#Price h2 + p strong { font-size: 2.00rem; }
	.price,.plan  { padding: 15px 10px; }
	.price > div { margin: 20px 0 0 0; }
	.price > div + div { margin-top: 30px; }
	.price + p { font-size: 0.875rem; }
	.price .size { font-size: 1.500em; }
	.price .size strong { font-size: 2.000rem; }
  .price > p { margin-top: 40px; padding: 0; }
  .price .obi { left: -10px; top: -25px; width: 150px; }
	
	.plan .ttl { font-size: 1.250rem; }
	.plan .ttl + ul li { width: auto; height: auto; margin: 0 10px; padding: 5px 20px; text-align: center; line-height: 1.3em; }
	.plan .ttl + ul + p { font-size: 0.875rem; }
	.plan .ttl + ul + p::before { margin-right: 5px; }
	.plan .ttl + ul + p::after { margin-left: 5px; }
	.plan .list { font-size: 0.938em; }
	.plan .list li + li { margin-top: 5px; }
	.plan .list + p { text-align: left; line-height: 1.3em; }
	br.sp { display: inline; }
	#MainImg img.sp { display: block; }
    
    #Price ul.dl { flex-wrap: wrap; margin-top: 40px; justify-content: center; }
    #Price ul.dl li { max-width: 350px; width: 90%; }
    #Price ul.dl li + li { margin-top: 20px; }
    #Price ul.dl li a { display: block; background: #00a072; font-weight: bold; text-align: center; color: #FFF; padding: 20px 0; border-radius: 10px; }
    #Price ul.dl li a:hover { background: rgba(0,160,114,0.80); transition: .3s; }
    #Price ul.dl li a::before { content: ""; display: inline-block; width: 18px; height: 24px; background: url(../images/ic_pdf.svg) no-repeat; vertical-align: -0.3em; margin-right: 10px; }
    
    #Results { padding: 30px 0; }
    #Results .flex { margin-top: 25px; padding: 15px; flex-wrap: wrap; }
    #Results .flex + .flex { margin-top: 25px; }
    #Results h4 { height: 40px; font-size: 1.375rem; }
    #Results .column { width: 100%; margin-top: 25px; }
    #Results .column p { font-size: 0.875rem; }
    #Results .inner > p { font-size: 1.125rem; text-align: left; }
    #Results .inner > p br { display: none; }
	
	#Contact h3 { font-size: 1.125em; margin-top: 0px; }
	#Contact .box { padding: 0; border: none; }
	#Contact .box p { font-size: 0.875em; line-height: 1.5em; text-align: left; margin-top: 25px; }
	#Contact .box dl dt { width: 100%; margin-top: 15px; padding-top: 5px; box-sizing: border-box; font-weight: bold; }
	#Contact .box dl dd { width: 100%; margin-top: 15px; }
    
    #Forte { padding: 30px 0; }
    #Forte .box { padding: 15px; margin-top: 25px; }
    #Forte h3 { font-size: 1.250rem; }
    #Forte p { margin-top: 20px; font-size: 0.875rem; }
    #Forte p.large { font-size: 1.125rem; font-weight: bold; color: #339f74; text-align: center; }
    #Forte .flex { flex-wrap: wrap; margin-top: 0; background: none; }
    #Forte .column { max-width: 345px; width: 100%; padding: 0; margin-top: 20px; }
    #Forte .column h4 { width: 100%; margin-bottom: 25px; }
    
	#Outline { padding: 50px 0; }
	#Outline dl { width: 100%; }

	#Outline .img { width: 100%; margin-top: 50px; display: flex; justify-content: space-between; align-items: flex-start; }
	#Outline .img img { width: 48%; }
	

	#Floating ul li { font-size: 0.750rem; }
	#Floating ul li strong { font-size: 0.938rem; }
	#Floating ul li span { font-size: 0.625rem; }
    
    #Rinen { padding-top: 30px; }
    #Rinen dl dd { font-size: 1.250rem; }
    #Rinen dl dd br.none { display: none; }
    #Rinen ul { flex-wrap: wrap; margin: 20px auto 0 auto; justify-content: center; }
    #Rinen ul li { width: 100%; }
    #Rinen ul li + li { margin-top: 15px; }
    #Rinen ul li div { height: 150px; }
	
	#Qa dl dd div a.arrow { display: block; margin-left: 0; }
	#Qa dl dd div a.arrow + a { margin-top: 5px; }
	#Qa dl dd.dd_flex{ flex-wrap:wrap; gap:15px; }
	#Qa dl dd .dd_mov{ width:90%; margin:0 auto; }
}

