<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">/*
Theme Name: shihouen
*/


/* Reset */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, 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 {
word-wrap : break-word;
overflow-wrap : break-word;
line-height: 1;
}

ol, ul, li {
list-style: none;
}

strong {
font-weight: bold;
}

a:focus {
outline: none;
}

blockquote, q {
quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
content: '';
content: none;
}

table {
border-collapse: collapse;
border-spacing: 0;
}

body {
-webkit-text-size-adjust: none;
}



/* 蜈ｨ菴薙�險ｭ螳� PC
---------------------------------------------------------------------------*/
* {-webkit-box-sizing: border-box;
   -moz-box-sizing: border-box;
   box-sizing: border-box
}
  
html, body {
background: #fff;
width: 100%;
height: 100%
}

html {
font-size: 100%;
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
overflow-y: scroll;
}

body, input, select, textarea {
color: #555;
font-family: "貂ｸ譏取悃", YuMincho, "繝偵Λ繧ｮ繝取�譛� ProN W3", "Hiragino Mincho ProN", "HG譏取悃E", "�ｭ�ｳ �ｰ譏取悃", "�ｭ�ｳ 譏取悃", serif;
font-size: 16px;
font-weight: 400;
line-height: 1.6;
}

p {
margin: 0 0 10px 0;
line-height: 1.8;
}

img {
width: auto;
height: auto;
max-width: 100%;
vertical-align: middle;
border: 0;
-ms-interpolation-mode: bicubic
}

a {
color: #333;
text-decoration: none;
}

a:hover {
color: #999;
text-decoration: none;
}

a:hover img {
filter: alpha(opacity=70);
-moz-opacity:0.7;
opacity:0.7;
-webkit-transition: 0.3s ease-in-out;
-moz-transition: 0.3s ease-in-out;
-o-transition: 0.3s ease-in-out;
transition: 0.3s ease-in-out;
}

a:focus {
outline: none;
}

a:hover, a:active {
outline: none;
}

strong, b {
color: #333;
font-weight: bold;
}

em, i {
font-style: italic;
}

h1, h2, h3, h4, h5, h6 {
color: #333;
font-weight: 400;
margin: 0;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
color: inherit;
border: 0;
}

.clear {
clear: both;
}

.cf:after {
content: "."; 
display: block;
height: 0; 
clear: both; 
visibility: hidden;
font-size:0.1em;
line-height:0;
}

.pc {
display: block;
}

.sp {
display: none;
}




/* 蜈ｱ騾壹PC
---------------------------------------------------------------------------*/
#wrapper {
background: url(./img/bg.jpg) no-repeat 50% 0%, url(./img/bg02.jpg) no-repeat 50% 100%;
background-size: 100% auto, 100% auto;
width: 100%;
}

.cont {
max-width: 1200px;
margin-right: auto;
margin-left: auto;
}

.cont_padded {
padding: 40px 100px;
}

.cont_padded02 {
padding: 40px 20px;
}



/* 繝倥ャ繝繝ｼ PC
--------------------------------------------------------------------------- */
#header.header {
display: none;
padding: 0;
}

@media (min-width: 980px) {
#header.header {
display: block;
}
}

#header.header-inverted {
background: rgba(0,0,0,0.8);
background: rgba(98,29,134,0.88);
background: rgba(71,19,99,0.88);
position: absolute;
top: 0;
left: 0;
border-bottom: 0;
z-index: 1000;
width: 280px;
height: 100%;
}

#header.header-inverted .header_container {
width: 280px;
margin: auto;
padding: 0;
box-sizing: border-box;
}

#header.header-inverted .header_container::after {
clear: both;
display: table;
line-height: 0;
content: ""
}

#header.header-inverted img.header_logo {
width: 110px;
height: auto;
margin: 25px 0 0 30px;
}

#header.header-inverted .header_nav {
margin: 15px 0 0 30px;
}

#header.header-inverted .header_nav li {
height: auto;
list-style-type: none;
font-size: 15px;
font-weight: 400;
text-align: left;
border-right: 0px dotted rgba(255,255,255,0.5);
line-height: 1.66;
}

#header.header-inverted .header_nav li a {
background: url(./img/arr01.png) no-repeat;
background-position: 0% 60%;
background-size: 4px 4px;
padding: 0 0 0 10px;
}

#header.header-inverted .header_nav li.sub a {
background: url(./img/arr02.png) no-repeat;
background-position: 10px 60%;
background-size: 7px 10px;
padding: 0 0 0 22px;
}

.header_nav li a {
color: #fff;
}

.header_nav li a:hover {
text-decoration: none;
filter: alpha(opacity=80);
opacity: 0.80;
}

#header.header-inverted .header_nav li span {
padding: 0 0 0 10px;
color: rgba(255,255,255,0.8);
font-size: 80%;
}

#header.header-inverted .header_nav02 {
position: absolute;
bottom: 30px;
right: 0;
}

#header.header-inverted .header_nav02 img.menu01 {
display: block;
width: 100%;
height: auto;
}

#header.header-inverted .header_nav02 img.menu02 {
display: none;
}

#header.header-inverted .header_nav02 li {
background: rgba(98,29,134,0.66);
background: rgba(0,0,0,0.8);
background: rgba(255,255,255,0.22);
line-height: 1;
border-bottom: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted .header_nav02 li:first-child {
border-top: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted .header_nav02 li a:hover {
text-decoration: none;
filter: alpha(opacity=80);
opacity: 0.80;
}

#header.header-inverted.n_scroll {
background: rgba(0,0,0,0.8);
background: rgba(98,29,134,0.88);
background: rgba(71,19,99,0.88);
position:fixed;
top:0;
-moz-box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
-webkit-box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
z-index: 1000;
width: 100%;
height: 110px;
}

#header.header-inverted.n_scroll .header_container {
width: 1200px;
margin: 0 auto;
padding: 0;
box-sizing: border-box;
}

#header.header-inverted.n_scroll .header_container::after {
clear: both;
display: table;
line-height: 0;
content: ""
}

#header.header-inverted.n_scroll h1 {
float: left;
width: 100px;
}

#header.header-inverted.n_scroll img.header_logo {
width: 80px;
height: auto;
margin: 15px 0 0 0;
}

#header.header-inverted.n_scroll .header_nav {
float: left;
margin: 40px 0 0 100px;
}

#header.header-inverted.n_scroll .header_nav li {
display: inline-block;
list-style-type: none;
font-size: 16px;
font-weight: 400;
text-align: center;
border-right: 1px dotted rgba(255,255,255,0.5);
line-height: 1.4;
}

#header.header-inverted.n_scroll .header_nav li a {
display: block;
background: none;
padding: 0;
}

#header.header-inverted.n_scroll .header_nav li.sub a {
display: block;
background: none;
padding: 0;
}

#header.header-inverted.n_scroll .header_nav li:first-child {
border-left: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted.n_scroll .header_nav li span {
display: block;
padding: 0;
color: rgba(255,255,255,0.8);
font-size: 80%;
}

#header.header-inverted.n_scroll .header_nav li ul {
display: none;
}

#header.header-inverted.n_scroll .header_nav li:hover &gt; ul {
display: block;
}

#header.header-inverted.n_scroll .header_nav li {
position: relative;
padding: 0 25px;
}

#header.header-inverted.n_scroll .header_nav li ul {
position: absolute;
top: 100%;
left: 0px;
width: 150px;
}

#header.header-inverted.n_scroll .header_nav li ul li {
float: none;
background: rgba(98,29,134,0.88);
background: rgba(0,0,0,0.88);
padding: 5px 20px;
font-size: 15px;
color: #fff;
text-align: left;
border-left: 0px solid #fff;
border-right: 0px dotted rgba(255,255,255,0.5);
border-bottom: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted.n_scroll .header_nav li ul li:first-child {
border-left: 0px dotted rgba(255,255,255,0.5);
}

#header.header-inverted.n_scroll .header_nav li ul li a {
display: block;
width: 150px;
padding: 5px 20px;
}


#header.header-inverted.n_scroll .header_nav02 {
position: static;
float: right;
width: 182px;
margin: 15px 0 0 0;
padding: 2px 10px;
}

#header.header-inverted.n_scroll .header_nav02 img {
width: auto;
height: 36px;
padding: 0 10px;
}

#header.header-inverted.n_scroll .header_nav02 img.menu01 {
display: none;
}

#header.header-inverted.n_scroll .header_nav02 img.menu02 {
display: block;
}

#header.header-inverted.n_scroll .header_nav02 li {
background: rgba(98,29,134,0.66);
background: rgba(0,0,0,0.8);
background: rgba(255,255,255,0.22);
width: 182px;
line-height: 1;
border-bottom: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted.n_scroll .header_nav02 li:first-child {
border-top: 1px dotted rgba(255,255,255,0.5);
}

#header.header-inverted.n_scroll .header_nav02 li a:hover {
text-decoration: none;
filter: alpha(opacity=80);
opacity: 0.80;
}

.main_visual {
position: relative;
margin:0 auto;
width: 100%;
min-width: 1200px;
height: 100vh;
overflow: hidden;
}

.slide-wrap {
height: 100vh !important;
}

.slide-wrap &gt; div {
background-position:50% 50% !important;
background-size: cover;  
height: 100vh !important;
z-index: 1 !important;
}

.square {
display: block;
background: rgba(98,29,134,0.8);
margin: 70px auto 0;
padding: 15px 0;
width: 270px;
hight: auto;
color: #fff;
font-size: 32px;
text-align: center;
line-height: 1.2;
}

h2 .box {
color: #fff;
font-size: 32px;
line-height: 1.2;
text-align: center;
}

h2 .box .en {
display: block;
color: rgba(255,255,255,0.66);
font-size: 16px;
line-height: 1.2;
}

.sub_visual {
display: table;
position: relative;
width: 100%;
height: 240px;
margin: 110px auto 40px;
text-align: center;
}

.sub_visual01 {
background: url(./img/top_photo01.jpg) no-repeat;
background-position: 50% 50%;
background-size: cover;
}

.sub_visual02 {
background: url(./img/14b.jpg) no-repeat;
background-position: 50% 50%;
background-size: cover;
}




/* 繝輔ャ繧ｿ繝ｼ PC
---------------------------------------------------------------------------*/
.footer {
margin: 80px 0 0;
padding: 20px 0 0;
color: #555;
background: url("./img/footer_line.png") repeat-x;
background-size: 5px 25px;
background-position: 50% 190px;
font-size: 14px
}

.footer_box_l {
float: left;
width: 50%;
}

.footer_box_r {
float: right;
width: 50%;
padding: 80px 0 0 0;
}

.footer h2 {
margin: 0 0 10px 0;
padding: 0;
color: #555;
font-size: 20px
}

.f_nav {
margin: 10px 0 0;
font-size: 0px;
}

.f_nav li {
display: inline-block;
padding: 0 12px;
font-size: 14px;
line-height: 1.4;
border-right: 1px solid rgba(0,0,0,0.33);
text-align: right;
}

.f_nav li:first-child {
border-left: 1px solid rgba(0,0,0,0.33);
}

.f_nav li a {
color: #555;
}

.f_nav li a:hover {
text-decoration: none;
filter: alpha(opacity=80);
opacity: 0.80;
}

.footer p.bod01 {
margin: 0 0 50px 3px;
padding: 0 0 0 7px;
border-left: 7px solid rgba(98,29,134,0.33);
}

.footer p.copyright {
margin-bottom: 0;
padding: 10px 0;
font-size: 13px;
text-align: center;
}

.footer p.copyright br {
display: none
}

#pagetop {
position: fixed;
bottom: 30px;
right: 2.5%;
z-index: 100;
}

#pagetop img {
filter: alpha(opacity=96);
opacity: 0.96;
width:48px;
height: auto;
border: 1px solid #fff;
}

#pagetop:hover {
filter: alpha(opacity=80);
opacity: 0.8;
}



/* 繧ｳ繝ｳ繝�Φ繝� PC
---------------------------------------------------------------------------*/
.top_cont {
width: 1200px;
height: 480px;
margin: 0 auto 60px;
padding: 80px 0 0 0;
background: url(./img/ink.png) no-repeat;
background-position: 100% 100%;
background-size: auto 90%;
}

h2.tit01 {
color: rgba(98,29,134,1);
font-size: 32px;
margin: 0 auto 20px;
padding: 0;
line-height: 1.33;
}

h2.tit02 {
color: rgba(98,29,134,1);
font-size: 24px;
margin: 0 auto 20px;
padding: 0;
line-height: 1.33;
}

h3.tit01 {
width: 100%;
color: #555;
font-size: 30px;
text-align: center;
margin: 0 auto 30px;
padding: 0;
line-height: 1.33;
}

h3.tit01  span {
display: block;
margin: 0;
color: rgba(98,29,134,0.66);
font-size: 16px;
}

h3.tit02 {
width: 100%;
margin: 0 0 20px 0;
padding: 0 0 10px 0;
color: rgba(98,29,134,1);
font-size: 21px;
font-weight: bold;
border-bottom: 2px dotted #ddd;
line-height: 1.2;
}

h3.tit02 span {
padding: 3px 0 3px 5px;
border-left: 8px solid rgba(98,29,134,0.66);
}

h3.tit03 {
margin: 0 0 30px 0;
padding: 10px 10px;
color: #fff;
font-size: 21px;
font-weight: bold;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
border-radius: 4px;
background: linear-gradient(rgba(98,29,134,0.66) 0%, rgba(98,29,134,0.66) 50%, rgba(98,29,134,0.88) 50%, rgba(98,29,134,0.88) 100%);
}

h3.tit03 span {
padding: 6px 0 6px 8px;
border-left: 8px solid rgba(255,255,255,0.8);
}

h4.tit01 {
width: 100%;
color: #fff;
font-size: 17px;
font-weight: bold;
margin: 0 0 10px 0;
padding: 0;
}

h4.tit01 span {
background: rgba(98,29,134,0.66);
padding: 4px 10px;
}

h4.tit02 {
width: 100%;
color: rgba(98,29,134,1);
font-size: 17px;
font-weight: bold;
margin: 0 0 10px 0;
padding: 0;
}

p.lead {
margin-bottom: 0px;
font-size: 18px;
}

.case_box {
margin-bottom: 80px;
}

.block2 {
display: block;
font-size: 0;
}

.block2 li {
display: inline-block;
width: 50%;
padding: 10px 20px 10px 0;
font-size: 16px;
text-align: left;
vertical-align: top;
}

.block2 li:nth-child(2n) {
padding: 10px 0 10px 20px;
}

.block2 li img {
margin: 0 0 5px 0;
}

.block2 li p {
font-size: 16px;
}

#home .block2 li {
font-size: 20px;
text-align: center;
}

#home .block2 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 15px;
}

.block3 {
display: block;
font-size: 0;
}

.block3 li {
display: inline-block;
width: 33.33%;
padding: 10px;
font-size: 18px;
text-align: center;
vertical-align: top;
}

.block3 li img {
margin: 0 0 10px 0;
}

.block3 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 15px;
}

.block4 {
display: block;
font-size: 0;
}

.block4 li {
display: inline-block;
width: 25%;
padding: 10px;
font-size: 20px;
text-align: center;
vertical-align: top;
}

.block4 li img {
margin: 0 0 10px 0;
}

.block4 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 16px;
}

.sample_box {
float: right;
width: 540px;
margin: 0 0 20px 30px;
}

.sample_box li {
width: 100%;
padding: 0;
font-size: 15px;
text-align: center;
vertical-align: top;
}

.sample_box li img {
margin: 0 0 10px 0;
}

.sample_box li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 15px;
}

.sample_box02 {
display: block;
font-size: 0;
}

.sample_box02 li {
display: inline-block;
width: 25%;
padding: 10px;
font-size: 15px;
text-align: center;
vertical-align: top;
}

.sample_box02 li img {
width: 100%;
height: auto;
margin: 0 0 5px 0;
}

img.president_photo {
float: right;
margin: 0 0 30px 30px;
width: 300px;
height: auto;
}

img.staff {
display: block;
margin: 0 auto;
width: 66%;
height: auto;
}

.news_box {
width: 900px;
margin: 0 auto;
}

.news_list {
margin: 0 0 40px 0;
}

.news_list dt{
clear:both;
width:7em;
float:left;
padding: 10px 4px 10px 15px;
color: rgba(98,29,134,1);
}

.news_list dd {
padding: 10px 15px 10px 8em;
text-align: left;
border-bottom: 1px dotted #ddd;
}

.news_list dd a {
color: #555;
}

/*
.news_list dd a:hover {
text-decoration: underline;
}
*/

#info_cont {
float: left;
width: 920px;
}

#info_cont h3.info_tit01 {
width: 100%;
margin: 0 0 10px 0;
padding: 3px 3px 6px;
color: rgba(98,29,134,1);
font-size: 18px;
font-weight: bold;
border-left: 0px solid rgba(56,134,89,0.5);
border-bottom: 3px dotted #ddd;
line-height: 1.33;
}

#info_cont h3.info_tit02 {
width: 100%;
margin: 0 0 10px 0;
padding: 3px 0 3px 10px;
color: rgba(98,29,134,1);
font-size: 18px;
font-weight: bold;
border-left: 8px solid rgba(98,29,134,0.5);
line-height: 1.33;
}

.content_box {
margin: 0 0 120px 0;
padding: 0 5px;
}

.info_date {
padding: 0 5px;
color: #999;
}

.link_nav {
padding: 0 5px;
}

.link_nav_l {
float: left;
width: 45%;
}

.link_nav_r {
float: right;
width: 45%;
}

#side {
float: right;
width: 240px;
}

#side h3 {
background: rgba(98,29,134,1);
color: #fff;
text-align: left;
margin: 0;
padding: 4px 8px;
}

#side h3 span {
border-left: 5px solid rgba(255,255,255,0.5);
margin: 0;
padding: 0 7px;
}

#side ul.side_menu01 {
margin: 7px 0 40px 0;
}

#side ul.side_menu01 li {
padding: 6px 4px;
border-bottom: 1px dotted #ddd;
}




/* 繝��繝悶Ν PC
---------------------------------------------------------------------------*/
.tbl01 {
width: 100%;
border-top: 1px dotted #ddd;
margin: 0 auto 80px;
}

.tbl01 th,
.tbl01 td {
font-size: 15px;
border-bottom: 1px dotted #ddd;
line-height: 1.5;
}

.tbl01 th {
width: 20%;
padding: 18px 28px;
color: #777;
font-weight: bold;
text-align: left;
vertical-align: middle;
}

.tbl01 td {
width: 80%;
padding: 18px 28px;
text-align: left;
vertical-align: middle;
}

.tbl01 tr:nth-child(odd) {
background: rgba(98,29,134,0.05);
}

.tbl02 {
width: 100%;
border-top: 1px dotted #ddd;
margin: 0 auto 80px;
}

.tbl02 th,
.tbl02 td {
font-size: 15px;
border-bottom: 1px dotted #ddd;
line-height: 1.5;
}

.tbl02 th {
width: 25%;
background: rgba(98,29,134,0.05);
padding: 18px 28px;
color: #555;
font-weight: normal;
text-align: left;
vertical-align: middle;
}

.tbl02 td {
width: 75%;
padding: 18px 28px;
text-align: left;
vertical-align: middle;
}




/* 繝輔か繝ｼ繝� PC
---------------------------------------------------------------------------*/
input, button, textarea, select {
outline: none;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

input,
textarea,
select {
background: #fff;
margin: 0;
padding: 10px 0 10px 8px;
width: 94%;
font-size: 14px;
font-family: inherit;
-moz-border-radius: 2px; 
-webkit-border-radius: 2px;
border-radius: 2px;
border: 1px solid #eee;
}

input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
filter: alpha(opacity=70);
-ms-filter: "alpha(opacity=70)";
opacity: 0.7;
}

input::-webkit-input-placeholder {
color: #999;
font-weight: normal;
}

input:-ms-input-placeholder {
color: #999;
font-weight: normal;
}

input::-moz-placeholder {
color: #999;
font-weight: normal;
}

.btn-submit input[type="submit"] {
display: block;
background: #ffe14d;
width: 100%;
max-width: 360px;
height: 60px;
margin: 40px auto 60px;
color: #000;
border: none;
-moz-border-radius: 2px; 
-webkit-border-radius: 2px;
border-radius: 2px;
-webkit-appearance: none;
}

.req {
color: rgb(255, 255, 255);
font-size: 80%;
background: rgb(255, 0, 0);
padding: 0px 2px;
}




/* 縺昴�莉� PC
---------------------------------------------------------------------------*/
.scroll &gt; a {
 display: block; 
 padding-top: 140px; 
 margin-top: -140px;
}

.t_center {
text-align: center;
}

.mt40 {
margin-top: 40px;
}

.mt60 {
margin-top: 60px;
}

.mt80 {
margin-top: 80px;
}




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

* {-webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 box-sizing: border-box
}

.pc {
display: none;
}

.sp {
display: block;
}


body {
padding-right: 0;
padding-left: 0
}


#wrapper {
background: url(./img/sp_bg.jpg) no-repeat 50% 0%, url(./img/sp_bg02.jpg) no-repeat 50% 100%;
background-size: 100% auto, 100% auto;
width: 100%;
}

.cont {
width: 92%;
max-width: initial;
margin-left: 4%;
margin-right: 4%;
}

.cont_padded {
padding: 40px 0px;
}

.cont_padded02 {
padding: 40px 0px;
}

.container {
width: auto;
margin-left: 5%;
margin-right: 5%;
}

.row-fluid {
width: 100%
}

[class*="span"], .uneditable-input[class*="span"], .row-fluid [class*="span"] {
display: block;
float: none;
width: 100%;
margin-left: 0;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box
}
.span12, .row-fluid .span12 {
width: 100%;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box
}
.row-fluid [class*="offset"]:first-child {
margin-left: 0
}




/* 繝倥ャ繝繝ｼ SP
---------------------------------------------------------------------------*/
.h_box {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: auto;
z-index: 1000;
}

.h_box {
position: fixed;
background: #fff;
width: 100%;
height: 60px;
-moz-box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
-webkit-box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
box-shadow: 0px 2px 2px rgba(0,0,0,0.33);
}

.h_box p {
margin-bottom: 0px;
}

.h_box .h_navi {
display: none;
}

.h_box_in {
width: 100%;
height: auto;
margin: 0 auto;
}

.h_box .sp_logo {
float: left;
display: block;
width: calc(100% - 120px);
padding: 0;
text-align: left;
}

.h_box .sp_logo img {
width: auto;
height: 48px;
margin: 6px 0 0 8px;
padding: 0;
}

.h_box .sp_logo imgo:hover {
filter: alpha(opacity=80);
opacity: 0.80;
}

.h_box .tel {
float: left;
width: 40px;
text-align: center;
}

.h_box .tel img {
width: auto;
height: 36px;
margin: 12px 0 0 0;
}

.h_box .mail {
float: left;
width: 40px;
text-align: center;
}

.h_box .mail img {
width: auto;
height: 36px;
margin: 12px 0 0 0;
}

.h_box #menuWrap {
float: right;
width: 40px;
}

nav {
background: #fff;
width: 100%;
height: 60px;
-moz-box-shadow: 0px 0px 0px rgba(0,0,0,0.33);
-webkit-box-shadow: 0px 0px 0px rgba(0,0,0,0.33);
box-shadow: 0px 0px 0px rgba(0,0,0,0.33);
}

a#menu{
display: inline-block;
position: relative;
width: 40px;
height: 40px;
margin: 10px;
}

#menuBtn{
display: block;
position: absolute;
top: 50%;
left: 4px;
width: 20px;
height: 2px;
margin: -1px 0 0 -7px;
background: rgba(98,29,134,1);
transition: .2s;
}

#menuBtn:before, #menuBtn:after{
display: block;
content: "";
position: absolute;
top: 50%;
left: 0;
width: 20px;
height: 2px;
background: rgba(98,29,134,1);
transition: .3s;
}

#menuBtn:before{
margin-top: -7px;
}

#menuBtn:after{
margin-top: 5px;
}

a#menu .close{
background: transparent;
}

a#menu .close:before, a#menu .close:after{
margin-top: 0;
}

a#menu .close:before{
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
}

a#menu .close:after{
transform: rotate(-135deg);
-webkit-transform: rotate(-135deg);
}

.panel{
width: 100%;
display: none;
overflow: hidden;
position: relative;
left: 0;
top: -6px;
z-index: 100;
}

#mainnav{
width: 100%;
text-align: right;
}

#mainnav ul {
border-bottom: 0px solid #ddd;
background: rgba(98,29,134,0.9);
text-align: left;
}

#mainnav li a {
position: relative;
display: block;
padding: 12px 15px;
border-bottom: 1px dotted #ddd;
color: #fff;
font-size: 14px;
}

#mainnav li:last-child a {
border-bottom: 0px dotted #ddd;
}

#mainnav li a span {
padding: 0 0 0 10px;
color: rgba(255,255,255,0.5);
font-size: 12px;
}

#mainnav li a::before {
display: block;
content: "";
position: absolute;
top: 50%;
right: 15px;
width: 6px;
height: 6px;
margin: -4px 0 0 0;
border-top: solid 1px #fff;
border-right: solid 1px #fff;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

.main_visual {
position: relative;
margin:0 auto;
width: 100%;
min-width: initial;
height: 100vh;
overflow: hidden;
}

.square {
display: block;
background: rgba(98,29,134,0.8);
margin: 50px auto 0;
padding: 2px 0 10px;
width: 200px;
hight: auto;
color: #fff;
font-size: 32px;
text-align: center;
line-height: 1.2;
}

h2 .box {
color: #fff;
font-size: 20px;
line-height: 1.2;
text-align: center;
}

h2 .box .en {
display: block;
font-size: 13px;
line-height: 1.2;
}

.sub_visual {
display: table;
position: relative;
width: 100%;
height: 180px;
margin: 60px auto 10px;
text-align: center;
}

.sub_visual01 {
background: url(./img/top_photo01.jpg) no-repeat;
background-position: 50% 50%;
background-size: cover;
}

.sub_visual02 {
background: url(./img/14b.jpg) no-repeat;
background-position: 50% 50%;
background-size: cover;
}




/* 繝輔ャ繧ｿ繝ｼ SP
---------------------------------------------------------------------------*/
.footer {
float: none;
width: 100%;
margin: 20px 0 0;
padding: 20px 0 0;
color: #555;
background: url("./img/footer_line.png") repeat-x;
background-size: 5px 25px;
background-position: 50% 180px;
font-size: 14px
}

.footer_box_l {
float: none;
width: 100%;
margin: 0 0 30px;
}

.footer_box_r {
display: none;
}

.footer h2 {
margin: 0 0 10px 0;
padding: 0;
color: #555;
font-size: 18px
}

.footer p.bod01 {
margin: 0 0 40px 3px;
padding: 0 0 0 7px;
border-left: 7px solid rgba(98,29,134,0.33);
}

.footer p.copyright {
margin-bottom: 0;
padding: 10px 3%;
font-size: 13px;
text-align: left;
line-height: 1.5;
}

.footer p.copyright br {
display: block;
}

#pagetop {
position: fixed;
bottom: 45px;
right: 1.5%;
z-index: 100;
}

#pagetop img {
filter: alpha(opacity=96);
opacity: 0.96;
width:36px;
height: auto;
border: 1px solid #fff;
}

#pagetop:hover {
filter: alpha(opacity=80);
opacity: 0.8;
}



/* 繧ｳ繝ｳ繝�Φ繝� SP
---------------------------------------------------------------------------*/
.top_cont {
width: 94%;
height: 400px;
margin: 0 3%;
padding: 40px 0 0 0;
background: url(./img/ink.png) no-repeat;
background-position: 100% 100%;
background-size: auto 60%;
}

h2.tit01 {
color: rgba(98,29,134,1);
font-size: 25px;
margin: 0 auto 20px;
padding: 0;
line-height: 1.33;
}

h2.tit02 {
color: rgba(98,29,134,1);
font-size: 20px;
margin: 0 auto 20px;
padding: 0;
line-height: 1.33;
}

h3.tit01 {
width: 100%;
color: #555;
font-size: 24px;
text-align: center;
margin: 0 auto 10px;
padding: 0;
line-height: 1.33;
}

h3.tit01  span {
display: block;
margin: 0;
color: rgba(98,29,134,0.66);
font-size: 14px;
}

h3.tit02 {
width: 100%;
margin: 0 0 20px 0;
padding: 0 0 10px 0;
color: rgba(98,29,134,1);
font-size: 17px;
font-weight: bold;
border-bottom: 2px dotted #ddd;
line-height: 1.2;
}

h3.tit02 span {
padding: 3px 0 3px 5px;
border-left: 8px solid rgba(98,29,134,0.66);
}

h3.tit03 {
margin: 0 0 24px 0;
padding: 8px 10px;
color: #fff;
font-size: 17px;
font-weight: bold;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
border-radius: 4px;
background: linear-gradient(rgba(98,29,134,0.66) 0%, rgba(98,29,134,0.66) 50%, rgba(98,29,134,0.88) 50%, rgba(98,29,134,0.88) 100%);
}

h3.tit03 span {
padding: 6px 0 6px 8px;
border-left: 8px solid rgba(255,255,255,0.8);
}

h4.tit01 {
width: 100%;
color: #fff;
font-size: 15px;
font-weight: bold;
margin: 0 0 10px 0;
padding: 0;
}

h4.tit01 span {
background: rgba(98,29,134,0.66);
padding: 4px 10px;
}

h4.tit02 {
width: 100%;
color: rgba(98,29,134,1);
font-size: 15px;
font-weight: bold;
margin: 0 0 10px 0;
padding: 0;
}

p.lead {
margin-bottom: 0px;
font-size: 15px;
}

p.lead br {
display: none;
}

.case_box {
margin-bottom: 40px;
}

.block2 {
display: block;
font-size: 0;
}

.block2 li {
display: inline-block;
width: 100%;
padding: 8px 0;
font-size: 15px;
text-align: left;
vertical-align: top;
}

.block2 li:nth-child(2n) {
padding: 8px 0;
}

.block2 li img {
margin: 0 0 5px 0;
}

.block2 li p {
font-size: 15px;
}

#home .block2 li {
font-size: 16px;
text-align: center;
}

#home .block2 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 14px;
}

.block3 {
display: block;
font-size: 0;
}

.block3 li {
display: inline-block;
width: 50%;
padding: 5px;
font-size: 16px;
text-align: center;
}

.block3 li img {
margin: 0 0 8px 0;
}

.block3 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 14px;
}

.block4 {
display: block;
font-size: 0;
}

.block4 li {
display: inline-block;
width: 50%;
padding: 10px;
font-size: 16px;
text-align: center;
}

.block4 li img {
margin: 0 0 8px 0;
}

.block4 li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 14px;
}

.sample_box {
float: none;
width: 100%;
margin: 0 0 20px 0;
}

.sample_box li {
width: 100%;
padding: 0;
font-size: 15px;
text-align: center;
vertical-align: top;
}

.sample_box li img {
width: 100%;
height: auto;
margin: 0 0 10px 0;
}

.sample_box li span {
display: block;
color: rgba(98,29,134,0.66);
font-size: 14px;
}

.sample_box02 {
display: block;
font-size: 0;
}

.sample_box02 li {
display: inline-block;
width: 100%;
margin: 0 0 20px 0;
padding: 0;
font-size: 15px;
text-align: center;
vertical-align: top;
}

.sample_box02 li img {
width: 100%;
height: auto;
margin: 0 0 5px 0;
}

img.president_photo {
float: none;
margin: 0 0 20px 0;
width: 100%;
height: auto;
}

img.staff {
display: block;
margin: 0 auto;
width: 100%;
height: auto;
}

.news_list {
width: 100%;
font-size: 14px;
overflow:auto;
}

.news_list dt{
clear:both;
width:6em;
float:left;
padding: 4px 3px;
color: rgba(98,29,134,1);
}

.news_list dd {
padding: 4px 3px 4px 7em;
text-align: left;
}

.news_list dd a {
color: #555;
}

.news_box {
width: 100%;
margin: 0 auto;
}

.news_list {
margin: 0 0 32px 0;
}

.news_list dt{
clear:both;
width:7em;
float:left;
padding: 10px 4px 10px 15px;
color: rgba(98,29,134,1);
}

.news_list dd {
padding: 10px 15px 10px 8em;
text-align: left;
border-bottom: 1px dotted #ddd;
}

.news_list dd a {
color: #555;
}

#info_cont {
float: none;
width: 100%;
}

#info_cont h3.info_tit01 {
width: 100%;
margin: 0 0 10px 0;
padding: 3px 3px 6px;
color: rgba(98,29,134,1);
font-size: 16px;
font-weight: bold;
border-left: 0px solid rgba(56,134,89,0.5);
border-bottom: 3px dotted #ddd;
line-height: 1.33;
}

#info_cont h3.info_tit02 {
width: 100%;
margin: 0 0 10px 0;
padding: 3px 0 3px 10px;
color: rgba(98,29,134,1);
font-size: 16px;
font-weight: bold;
border-left: 8px solid rgba(98,29,134,0.5);
line-height: 1.33;
}

.content_box {
margin: 0 0 80px 0;
padding: 0 5px;
}

.info_date {
padding: 0 5px;
color: #999;
}

.link_nav {
padding: 0 5px;
}

.link_nav_l {
float: none;
width: 100%;
}

.link_nav_r {
float: none;
width: 100%;
}

#side {
float: none;
width: 100%;
}

#side h3 {
background: rgba(98,29,134,1);
color: #fff;
text-align: left;
margin: 0;
padding: 4px 8px;
}

#side h3 span {
border-left: 5px solid rgba(255,255,255,0.5);
margin: 0;
padding: 0 7px;
}

#side ul.side_menu01 {
margin: 7px 0 40px 0;
}

#side ul.side_menu01 li {
padding: 6px 4px;
border-bottom: 1px dotted #ddd;
}



/* 繝��繝悶Ν SP
---------------------------------------------------------------------------*/
.tbl01 {
width: 100%;
border-top: 1px dotted #ddd;
border-bottom: 1px dotted #ddd;
margin: 0 auto 40px;
}

.tbl01 th,
.tbl01 td {
display: block;
width: 100%;
font-size: 14px;
border-bottom: 0px dotted #ddd;
}

.tbl01 th {
background: rgba(98,29,134,0.05);
vertical-align: middle;
padding: 7px 14px;
color: rgba(98,29,134,1);
font-weight: bold;
text-align: left;
}

.tbl01 td {
vertical-align: middle;
padding: 10px 14px;
text-align: left;
}

.tbl01 tr:nth-child(odd) {
background: transparent;
}

.tbl02 {
width: 100%;
border-top: 0px dotted #ddd;
margin: 0 auto 40px;
}

.tbl02 th,
.tbl02 td {
display: block;
width: 100%;
font-size: 14px;
border-bottom: 0px dotted #ddd;
}

.tbl02 th {
background: rgba(98,29,134,0.05);
vertical-align: middle;
padding: 6px 8px;
font-weight: normal;
text-align: left;
}

.tbl02 td {
vertical-align: middle;
padding: 10px 0px;
text-align: left;
}




/* 繝輔か繝ｼ繝� SP
---------------------------------------------------------------------------*/
input, button, textarea, select {
outline: none;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

input,
textarea,
select {
background: #fff;
margin: 0;
padding: 7px 0 7px 8px;
width: 100%;
font-size: 14px;
font-family: inherit;
-moz-border-radius: 2px; 
-webkit-border-radius: 2px;
border-radius: 2px;
border: 1px solid #eee;
}

input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
filter: alpha(opacity=70);
-ms-filter: "alpha(opacity=70)";
opacity: 0.7;
}

input::-webkit-input-placeholder {
color: #999;
font-weight: normal;
}

input:-ms-input-placeholder {
color: #999;
font-weight: normal;
}

input::-moz-placeholder {
color: #999;
font-weight: normal;
}

.btn-submit input[type="submit"] {
display: block;
background: #ffe14d;
width: 100%;
height: 50px;
margin: 20px auto 60px;
font-size: 14px;
color: #000;
border: none;
-moz-border-radius: 2px; 
-webkit-border-radius: 2px;
border-radius: 2px;
-webkit-appearance: none;
}

.scroll &gt; a {
 display: block; 
 padding-top: 90px; 
 margin-top: -90px;
}

}


@media screen and (max-width: 480px) {
.top_cont {
width: 94%;
height: 360px;
margin: 0 3% 20px;
padding: 40px 0 0 0;
background: url(./img/ink.png) no-repeat;
background-position: 100% 100%;
background-size: auto 45%;
}
}
</pre></body></html>