@charset "UTF-8";
 html {
font-size: 100%;
scroll-behavior: smooth;
}
body {
width: 100%;  font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 400;
font-style: normal;
color: #4D4D4D;
background: #f7f7f5;
line-height: 2;
padding: 0;
margin: 0;
}
a {
color: #4D4D4D;
text-decoration: none
}
a:hover {
text-decoration: underline;
transition: 2s;
-moz-transition: 2s; -webkit-transition: 2s; -o-transition: 2s; }
*:focus {
outline: none;
}
article a {
text-decoration: underline;
}
article a:hover {
color: #000;
}
dt {
margin-bottom: 5px;
}
dd {
margin-left: 0;
margin-bottom: 20px;
}
img {
max-width: 100%;
height: auto;
vertical-align: bottom;
padding: 0;
margin: 0 auto;
}
figure {
margin: 5px 0;
}
table {
border: none;
border-collapse: collapse;
border-spacing: 0
}
::-moz-selection {
background: #222;
color: #FFF
}
::selection {
background: #222;
color: #FFF
}
::-moz-selection {
background: #222;
color: #FFF
}
strong { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
}
hr {border: none !important;
border-left: none;
border-right: none;
border-top: 0.25px solid #191919 !important;}
.for-sp {
display: block !important
}
.for-tab {
display: none !important
}
.for-pc {
display: none !important
}
@media screen and (min-width: 600px) {
.for-sp {
display: none !important
}
.for-tab {
display: block !important
}
.for-pc {
display: none !important
}
}
@media screen and (min-width: 1025px) {
.for-sp {
display: none !important
}
.for-tab {
display: none !important
}
.for-pc {
display: block !important
}
}
.for-sp-img {
display: block !important
}
.for-pc-img {
display: none !important
}
@media screen and (min-width: 600px) {
.for-sp-img {
display: none !important
}
.for-pc-img {
display: block !important
}
}
h1,h2,h3,h4,h5,h6 { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
}
.bg_wh {
background: #FFF;
}
.pb20 {
padding-bottom: 20px;
}
.pb40 {
padding-bottom: 40px;
}
.pb60 {
padding-bottom: 60px;
}
.pt40 {
padding-top: 40px;
}
.mb30 {
margin-bottom: 30px !important;
}
.mb60 {
margin-bottom: 60px !important;
}
.mb80 {
margin-bottom: 80px !important;
}
.mb100 {
margin-bottom: 100px !important;
}
.wp-caption {
max-width: 100%;
height: auto;
margin: 0 auto;
}
.wp-caption-text {
font-size: 0.8rem !important;
text-align: center;
padding-top: 5px;
}
@import url("http://fonts.googleapis.com/earlyaccess/notosansjapanese.css");
@import url("http://fonts.googleapis.com/earlyaccess/notosansjp.css"); .weight100 { font-weight:100 } 
.weight300 { font-weight:300 }
.weight400 { font-weight:400 }
.weight500 { font-weight:500 }
.weight600 { font-weight:600 }
.weight700 { font-weight:700 }
.weight900 { font-weight:900 }
.text_left, .alignleft { text-align: left; }
.text_center, .aligncenter { text-align: center;}
.text_right,.alignright { text-align: right; } header {
position: relative;
padding: 0;
margin: 0;
}
header a {
text-decoration: none !important;
}
.header-container {
height: 80px;
position: fixed;
z-index: 100;
background: #f7f7f5;
width: 100%;
top: 0 !important;
}
.header-container .logo {
position: absolute;
top: 50%;
left: 25px;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
}
.header-container .logo img {
width: 75%;
max-width: 300px;
}
.nav_open {
position: fixed;
right: 0;
top: 0;
z-index: 300;
}
@media screen and (min-width: 1025px) {
.header-container {
height: 160px;
position: relative;
}
.header-container .logo {
position: absolute;
top: 50%;
left: 70px;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
}
.header-container .logo img {
width: 300px;
}
}
@media screen and (min-width: 1600px) {
.header-container {
max-width: 1400px;
}
}
.header-container .navigation {
position: absolute;
top: 50%;
right: 40px;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
z-index: 200;
}
.header_box { margin: 0 auto;
} .navigation {
position: relative;
margin-top: 10px; }
.navigation ul > li{
display: inline-block;
}
.navigation ul > li > a {
padding: 15px 20px;
display: block;
font-size: 0.9em; letter-spacing: .2em;
}
.navigation ul > li > a:hover {
color: #448538;
}
.navigation ul > li > span{
margin-left: 1.2em;
}
.navigation ul > li:hover > a{
color: #4D4D4D;
}
.navigation ul li .header-navigation-c {
position: absolute;
top: 65px;
left: 100px;
text-align: left;
}
.navigation ul li .header-navigation-d {
position: absolute;
top: 65px;
left: 160px;
}
.navigation ul li .header-navigation-c li,
.navigation ul li .header-navigation-d li{
display: block;
}
.navigation ul li ul li a {
background-color: #FFF;
color: #444;
transition: color .1s ease-out;
}
.navigation ul li ul li a:hover{
background-color: #efefef;
}
.header-navigation ul li ul{
display: none;
}
.header-navigation ul li:hover ul{
display: block;
}
.header-navigation-c,
.header-navigation-d {
box-shadow: 0 5px 15px 0 rgba(0, 0, 0, .2);
border-radius: 5px;
}
.header-navigation-c li:first-child a,
.header-navigation-d li:first-child a {
border-top-left-radius: 5px;
border-top-right-radius: 5px;
}
.header-navigation-c li:last-child a,
.header-navigation-d li:first-child a {
border-bottom-left-radius: 5px;
border-bottom-right-radius: 5px;
}
.item {
text-decoration: none;
}
.item-text {
position: relative;
z-index: 1;
}
.item-text:hover {
color: #448538;
transition: all 0.4s;
}
.item-text:after {
content: '';
position: absolute;
left: 0;
bottom: -10px; width: 0%; height: 2px; background: #448538; z-index: -1;
transition: all 0.4s; }
.item:hover .item-text:after {
width: 100%; } .sp-menu {
position: relative;
}
.pc-menu {
display: none;
}
@media screen and (min-width: 1025px) {
.sp-menu {
display: none;
}
.pc-menu {
display: block;
text-align: right;
margin-left: 395px;
}
}
.sp-menu {
height: 10px;
position: absolute;
right: 30px;
top: 35px;
width: 24px;
z-index: 99;
}
.menu__line {
background: #4D4D4D;
display: block;
height: 2px;
position: absolute;
transition:transform .3s;
width: 100%;
cursor: pointer;
}
.menu__line--bottom {
bottom: 0;
}
.menu__line--top.active {
-webkit-transform: translateY(4px) rotate(-30deg);
transform: translateY(4px) rotate(-30deg);
}
.menu__line--bottom.active {
-webkit-transform: translateY(-4px) rotate(30deg);
transform: translateY(-4px) rotate(30deg);
width: 100%;
}
.gnav {
display: none;
height: 100%;
position: fixed;
width: 100%;
z-index: 98;
}
.gnav__menu {
font-weight: bold;
padding: 80px 30px 30px;
}
.gnav__menu li {
padding: 10px 0;
list-style: none;
}
.gnav__wrap { background: #f7f7f5;
height: 100%;
top: 0 !important;
z-index: 300;
position: fixed;
width: 100%;
}
.gnav__wrap ul {
height: 100%;
overflow: auto; -webkit-overflow-scrolling: touch;
} main {
padding: 80px 0 40px 0;
}
.sbb_g {
color: #448538;
}
.sbb_ga {
color: #448538;
}
.sbb_ga a {
color: #448538;
}
.sbb_marker {
background-color: #FFF;
color: #448538;
padding: 4px 6px;
}
@media screen and (min-width: 899px) {
.sbb_marker {
margin-left: 4px;
}
}
@media screen and (min-width: 1025px) {
main {
padding: 0 0 60px 0;
}
} .index_img {
position: relative;
height: auto;
}
.index_img img {
width: 100%;
height: auto;
}
.index_circle {
position: absolute;
top: 75%;
right: 15px;
}
@media screen and (min-width: 600px) {
.index_img {
position: relative;
height: 210px;
}
}
@media screen and (min-width: 899px) {
.index_img {
position: relative;
height: 350px;
}
}
@media screen and (min-width: 1025px) {
.index_img {
position: relative;
height: 480px;
}
}
.top_catch {
width: 180px;
height: 180px;
box-shadow: 0 5px 15px 0 rgba(0, 0, 0, .2);
border-radius: 50%;
} .index_contents {
margin: 60px auto 100px;
margin: 60px auto 260px;
}
.index_90 {
width: 90%;
max-width: 1040px;
margin: auto;
position: relative;
}
.index_first {
margin-top: 140px;
}
.index_line {
border-top: 5px solid #448538;
width: 20%;
margin: 30px 0;
}
.index_tit_je {
font-size: 1.6rem;
color: #448538;
line-height: 1.6;
}
.index_tit_je small {
font-size: 0.9rem;
}
.index_mission ul {
padding: 0;
}
.index_mission_list {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
flex-flow: row wrap;
justify-content: space-around;
}
.index_mission li {
list-style: none;
text-align: center;
color: #191919;
background: #FFF;
border-radius: 10px;
width: 48%;
padding: 20px 10px 25px;
font-size: 0.74rem;
line-height: 1.5;
margin-bottom: 15px;
}
.index_mission li img {
display: block;
width: 65px;
margin: 20px auto;
}
.index_mission h2 {
font-size: 1rem;
line-height: 1.7;
font-feature-settings: "palt";
letter-spacing: 1.7px;
}
.index_mission h3 {
font-size: 1.2rem;
line-height: 1.7;
color: #448538;
text-align: center;
}
.index_mission h3 small {
font-size: 0.8rem;
}
.index_mission_p {
display: block;
margin-bottom: 60px !important;
}
@media screen and (min-width: 899px) {
.index_mission_p {
font-size: 1rem !important;
}
.index_mission h3 {
font-size: 1.8rem;
line-height: 1.3;
margin-bottom: 40px !important;
margin-top: 100px;
}
.index_mission h3 small {
font-size: 1rem;
}
}
.index_contents {margin: 100px auto 100px;}
.index_contents p {
font-size: 1rem;
margin: 0 0 20px 0;
letter-spacing: 1px;
}
.index_contents .index_textsize {
font-size: 14px;
font-size: .9rem;
margin: 0 0 20px 0;
}
.index_pres {
position: absolute;
right: 10px;
top: 30px;
text-align: center;
vertical-align: top;
line-height: 2.1;
}
.index_pres_message p {
font-feature-settings: "palt";
letter-spacing: 1.7px;
text-align: justify;
}
.index_pres span {
font-size: 0.9rem;
line-height: 1.2;
}
.index_pres small {
font-size: 0.75rem;
}
.index_pres p {
line-height: 1;
margin-top: 10px;
}
.index_pres_img {
border-radius: 50%;
width: 145px;
height: 145px;
object-fit: cover;
}
.index_Message_first {
margin-top: 140px !important;
}
@media screen and (min-width: 899px) {
.index_pres_img {
width: 280px;
height: 280px;
}
.index_Message_first {
margin-top: 40px !important;
}
.index_pres_message {
width: calc(100% - 365px);
}
.index_pres_message p {
font-size: 1.1rem !important;
line-height: 1.9;
}
.index_pres p {
line-height: 1.4;
margin-top: 15px;
}
.index_pres span {
font-size: 1rem !important;
}
.index_pres small {
font-size: 0.8rem !important;
}
}
@media screen and (min-width: 899px) {
.index_mission li {
width: 32%;
max-width: 300px;
font-size: .9rem;
line-height: 1.6;
margin-bottom: 25px;
padding: 50px;
margin-right: 1.3%;
}
}
@media screen and (min-width: 1025px) {
.index_circle {
position: absolute;
bottom: -100px;
right: 100px;
}
.top_catch {
width: 280px;
height: 280px;
box-shadow: 0 5px 15px 0 rgba(0, 0, 0, .2);
border-radius: 50%;
}
.index_tit_je {
font-size: 2.2rem;
line-height: 1.3;
margin-bottom: 30px;
}
.index_tit_je small {
font-size: 1rem;
}
.page_tit_je {
font-size: 2.2rem;
line-height: 1.3;
margin-bottom: 30px;
}
.page_tit_je small {
font-size: 1rem;
}
.index_mission_list {
flex-flow: row wrap;
justify-content: center;
max-width: 960px;
margin: 0 auto;
}
.index_mission li {
width: 32%;
font-size: .9rem;
line-height: 1.6;
margin-bottom: 25px;
padding: 50px 49px;
margin-right: 1.3%;
}
.index_mission li img {
display: block;
width: 95px;
margin: 20px auto;
}
}
@media screen and (min-width: 1600px) {
.index_circle {
top: 500px !important;
right: 200px !important;
}
.index_first {
margin-top: 300px;
}
} .cover_bg {
width: 100%;
position: relative;
}
.cover_img {
width: 100%;
position: relative;
}
.cover_text {
position: absolute;
top: 50%;
left: 25%;
transform: translate(-50%, -50%);
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
color: #FFF;
text-align: left;
}
.cover_text h1 { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-style: normal;
margin: 0;
line-height: 1.7;
font-size: 1.5rem;
}
.cover_text p {
margin: 0;
letter-spacing: 2px;
font-size: 0.785rem;
}
.cover_text_2 {
position: absolute;
top: 50%;
left: 25%;
transform: translate(-50%, -50%);
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
color: #FFF;
text-align: left;
}
.cover_text_2 h1 { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
margin: 0;
line-height: 1.7;
font-size: 1.085rem;
}
.cover_text_2 p {
margin: 0;
letter-spacing: 2px;
font-size: 0.785rem;
}
.cover_text_3 {
position: absolute;
top: 50%;
left: 38%;
transform: translate(-50%, -50%);
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
color: #FFF;
text-align: left;
}
.cover_text_3 h1 { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
margin: 0;
line-height: 1.7;
font-size: 1.085rem;
}
.cover_text_3 p {
margin: 0;
letter-spacing: 2px;
font-size: 0.785rem;
}
.blog_tag {
max-width: 1040px;
margin: 0 auto;
border-bottom: 1px solid rgba(0,16,14,0.08);
}
.blog_tag a {
color: #1b1b1b;
}
.blog_tag ul {
width: 90%;
margin: 15px auto;
display:flex;
list-style: none;
padding-left: 0;
text-align:center;
font-size: 0.75rem;
}
.blog_tag li {
margin-right: 28px;
margin-right: 38px;
}
@media screen and (max-width: 375px) {
.blog_tag ul {
width: 94%;
font-size: 0.68rem;
}
.blog_tag li {
margin-right: 20px;
margin-right: 38px;
}
}
.blog_tag li:active { }
.newslist-items {
padding-left: 0;
}
.newslist-items li {
list-style: none;
background: #FFF;
}
.newslist-items li:nth-of-type(even) {
background: #F5F5F5;
}
.newslist-items li .fp_time {
position: absolute;
top: 20px;
left: 20px;
font-size: .8rem;
width: 200px;
}
.newslist-items li span {
padding: 0;
width: 100%;
position: relative;
}
.newslist-items li span a {
display: block;
overflow: hidden;
zoom: 1;
padding: 54px 20px 24px 20px;
}
@media screen and (min-width: 1025px) {
.cover_text {
left: 20%;
}
.cover_text h1 {
line-height: 1.7;
font-size: 2.5rem;
}
.cover_text p {
font-size: 18px;
font-size: 1.125rem;
}
.cover_text_2 {
left: 25%;
}
.cover_text_2 h1 {
line-height: 1.7;
font-size: 1.9rem;
}
.cover_text_2 p {
font-size: 18px;
font-size: 1.125rem;
}
.cover_text_3 {
left: 34%;
}
.cover_text_3 h1 {
line-height: 1.7;
font-size: 1.9rem;
}
.cover_text_3 p {
font-size: 18px;
font-size: 1.125rem;
}
.blog_tag ul {
width: 100%;
margin: 30px auto;
font-size: 1rem !important;
}
.newslist-items li span {
width: 90%;
max-width: 980px;
margin: 0 auto;
display: block;
padding: 35px 0;
}
.newslist-items li {
font-size: 1.08rem !important;
}
.newslist-items li em {
position: relative;
float: left;
width: 160px;
top: 1px;
left: 0;
}
.newslist-items li .fp_time {
position: relative;
float: left;
width: 160px;
font-size: 1rem;
top: 1px;
left: 0;
}
.newslist-items li span a {
padding: 0;
}
}
.newslist-items li span:after {
content: "";
display: block;
clear: both;
}
.category-tab { }
.category-tab li a {
text-decoration: none;
}
.category-tab li a:hover {
text-decoration: none;
border-bottom: none;
color: #448538 !important;
transition: 1.0s;
} .category-tab li.active a{
background: #fff;
border-bottom: 2px solid #448538;
padding-bottom: 18px;
color: #448538;
}
.category-tab li.noactive a{
border-bottom: none !important;
color: #191919 !important;
}
.category_list {
margin: 0 auto;
padding: 0;
}
@media screen and (min-width: 1025px) { 
.category-tab li.active a {
padding-bottom: 34px;
}
.category_list {
max-width: 1040px;
margin: 0 auto;
padding: 0;
}
}    .entry {
width: 90%;
max-width: 1040px;
margin: 0 auto 40px;
font-feature-settings: "palt";
letter-spacing: 1.7px;
line-height: 1.9;
text-align: justify;
}
.entry img {
max-width: 100%;
height: auto;
}
.entry a {
text-decoration: underline;
}
.entry a:hover {
color: #000;
}
.entry h1, .entry_page h1{ font-size: 22px;
font-size: 1.4rem;
margin: 60px 0 20px;
}
.entry h2, .entry_page h2 {
font-size: 1.3rem;
}
.entry h3, .entry_page h3 {
font-size: 1.2rem;
}
.entry h4, .entry_page h4 {
font-size: 1.1rem;
}
.entry h1 small {
font-size: 60%;
color: #448538 !important;
}
.entry_page ol,
.entry_page ul {
padding-left: 20px;
}
.entry_page li {
margin-bottom: 10px;
}
.entry p {
font-size: 1rem;
margin: 0 0 20px 0;
}
.entry_date {
text-align: right;
margin-bottom: 40px !important;
font-size: .875rem !important;
letter-spacing: 1px;
}
.entry .flex50 div {
margin-bottom: 30px;
}
.page_line_box {
border-top: 5px solid #448538;
width: 20%;
margin: 0;
padding-bottom: 30px;
}
.page_title {
margin-bottom: 60px;
}
.page_title span {
color: #448538;
font-size: 1rem !important;
line-height: 5;
}
@media screen and (min-width: 1025px) {
.entry h1 {
font-size: 34px;
font-size: 2.125rem;
font-weight: 600;
line-height: 1.5;
margin: 80px 0 20px;
}
.entry {
width: 90%;
max-width: 760px;
margin: 0 auto 80px;
}
.entry .flex50 {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.entry .flex50 img {width: 100%; height: auto;}
.entry .flex50 .flex50_l {
width: 57%;
}
.entry .flex50 .flex50_r {
width: 38%;
}
}
.content_100 {
position: relative;
width: 100%;
margin: 0 auto;
}
.content_90 {
position: relative;
width: 100%;
max-width: 1160px;
margin: 0 auto;
}
.content_list {
width: 90%;
max-width: 1040px;
margin: auto;
} .page_line {
position: absolute;
border-top: 5px solid #448538;
width: 20%;
top: 0;
left: 0;
}
.entry_page {
width: 100%;
max-width: 1040px;
margin: 0 auto;
}
.entry_page_bg {
position: relative;
background: #FFF;
padding: 60px 30px 40px;
}
.entry_page_bg p {
text-align: justify;
}
.entry_page_bg2 {
position: relative;
background: #FFF;
padding: 60px 30px 260px;
}
.entry_page_bg2 p {
text-align: justify;
}
.entry_page_profile {
position: relative;
padding: 60px 30px 40px;
}
.entry_page_profile p {
text-align: justify;
font-size: 0.9rem;
}
.entry_page_profile li {
font-size: 0.9rem;
}
@media screen and (max-width: 375px) {
.entry_page_bg {
position: relative;
background: #FFF;
padding: 60px 20px 40px;
}
.entry_page_bg2 {
position: relative;
background: #FFF;
padding: 60px 20px 40px;
}
.entry_page_profile {
position: relative;
padding: 60px 20px 40px;
}
}
@media screen and (min-width: 899px) {
.entry_page_bg {
padding: 80px 120px;
margin: 40px auto;
border-radius: 10px;
}
.entry_page_bg2 {
padding: 80px 120px;
margin: 40px auto;
border-radius: 10px;
}
.entry_page_profile {
padding: 80px 120px;
margin: 40px auto;
border-radius: 10px;
}
}
.company_info {
}
.company_info h3 {
font-size: 1.2rem;
line-height: 1.7;
color: #4D4D4D;
margin-bottom: 50px;
text-align: center;
}
.company_info dl, .page-id-11 dl {
width: 100%;
}
.company_info dt, .page-id-11 dt {
color: #448538 !important;
}
.company_info dd, .page-id-11 dd {
margin-bottom: 30px !important;
}
.company_info ol, .page-id-11 ol {
margin: 0;
padding-left: 0;
}
.company_info ol li, .page-id-11 ol li {
list-style-type: none;
counter-increment: cnt;
margin-bottom: 4px;
}
.company_info ol li::before, .page-id-11 ol li::before {
content: "(" counter(cnt) ") ";
}
@media screen and (min-width: 899px) {
.company_info dl, .page-id-11 dl {
display: flex;
flex-wrap: wrap;
max-width: 700px;
margin: 70px auto 0;
}
.company_info dt, .page-id-11 dt {
width: 25%;
margin: 0;
padding-bottom: 20px;
margin-bottom: 10px;
color: #7f7f7f;
}
.company_info dd, .page-id-11 dd {
width: 75%;
margin: 0;
padding-bottom: 20px;
margin-bottom: 10px;
}
.company_info h3 {
font-size: 1.8rem;
line-height: 1.3;
margin-bottom: 40px !important;
margin-top: 40px;
}
.company_info h3 small {
font-size: 1rem;
}
}
.about_title {
color: #448538;
margin-top: 40px;
}
.about_bold_text { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
font-size: 22px;
font-size: 1.4rem;
margin: 40px 0 20px;
text-align: center;
}
.about_mission_text {
text-align: left;
margin-bottom: 30px;
}
@media screen and (min-width: 899px) {
.about_mission_text {
text-align: center;
}
}
.about_copy {
line-height: 2;
text-align: justify;
font-feature-settings: "palt";
letter-spacing: 1px;
margin: 35px 0 0;
}
.page_message_first {
margin-top: 20px !important;
}
.google_map {
position: relative;
width: 100%;
height: 0;
padding-top: 75%;
margin-bottom: 30px;
}
.google_map iframe{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
} .page_message_list {
display: block;
}
.page_message_title {
padding-top: 58px;
margin-bottom: 100px;
}
.message_pres {
position: absolute;
right: 10px;
top: 80px;
text-align: center;
vertical-align: top;
line-height: 2.1;
}
.message_pres_message p {
font-feature-settings: "palt";
letter-spacing: 1.7px;
}
.message_pres span {
font-size: 0.9rem;
line-height: 1.2;
}
.message_pres small {
font-size: 0.75rem;
}
.message_pres p {
line-height: 1;
margin-top: 10px;
}
.message_pres_img {
border-radius: 0%;
width: 160px;
height: 140px;
object-fit: cover;
}
.message_Message_first {
margin-top: 140px !important;
}
.page_tit_je {
font-size: 1.3rem;
color: #448538;
line-height: 1.6;
}
.page_tit_je small {
font-size: 0.9rem;
}
@media screen and (min-width: 899px) {
.message_pres_img {
width: 280px;
height: 280px;
}
.message_Message_first {
margin-top: 40px !important;
}
.message_pres_message {
width: calc(100% - 365px);
}
.message_pres_message p {
font-size: 1rem !important;
line-height: 1.9;
}
.message_pres p {
line-height: 1.4;
margin-top: 15px;
}
.message_pres span {
font-size: 1rem !important;
}
.message_pres small {
font-size: 0.8rem !important;
}
}
.page_pres {
position: absolute;
right: 0;
top: 50px;
text-align: center;
vertical-align: top;
line-height: 2.1;
}
.page_pres_message {
margin-top: 20px;
}
.page_pres_message h2 {
font-size: 1.35rem;
padding: 20px 0 0;
line-height: 1.8;
}
@media screen and (max-width: 375px) {
.page_pres_message h2 {
font-size: 1.25rem;
padding: 20px 0 0;
}
}
.page_pres_message p {
font-feature-settings: "palt";
letter-spacing: 1.8px;
line-height: 2;
text-align: justify;
}
.page_pres_message ul {
padding: 10px 20px 10px 40px;
}
.page_pres_message ul li { }
.page_pres span {
font-size: 0.9rem;
line-height: 1.2;
}
.page_pres small {
font-size: 0.75rem;
}
.page_pres p {
line-height: 1;
margin-top: 10px;
}
.page_pres_img { width: 150px;
height: 150px;
object-fit: cover;
}
.message_azuma {
text-align: right !important;
}
.message_azuma p {
text-align: right !important;
}
.message_azuma img {
width: 200px;
height: auto;
}
@media screen and (min-width: 899px) {
.page_pres_message h2 {
font-size: 1.6rem;
padding: 40px 0 0;
}
.page_pres {
position: relative;
margin-right: 150px;        
}
.page_pres_img {
width: 280px;
height: 280px;
}
.page_message_first {
margin-top: 0 !important;
}
.aligncenter {
display: block;
text-align: center;        
}
.page_pres_message {
width: calc(100% - 305px);
margin: 20px auto 0;
}
.page_pres_message img {
max-width: 100%;
height: auto;
margin: 0 auto;
text-align: center;
object-fit: cover;
}
.page_pres_message p {
font-size: 1rem !important;
letter-spacing: 2px;
}
.page_pres p {
line-height: 1.4;
margin-top: 15px;
}
.page_pres span {
font-size: 1rem !important;
}
.page_pres small {
font-size: 0.8rem !important;
}
.message_azuma img {
width: 40%;
height: auto;
}
} .accordion-area {
list-style: none;
width: 100%;
margin: 0 auto;
}
.page_message_list ul {
}
.accordion-area li{
margin: 10px 0;
list-style-type: decimal;
font-size: .875rem;
}
.accordion-area section {
}
.accordion-area-title {
position: relative; cursor: pointer;
font-size: .975rem; padding: 12px 0 12px 25px;
transition: all .5s ease; font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
display: block;
}
.accordion-area-title::before,
.accordion-area-title::after{
position: absolute;
content:'';
width: 12px;
height: 1px;
background-color: #4D4D4D; 
display: block;
}
.accordion-area-title::before{
top: 48%;
left: 0;
transform: rotate(0deg);
}
.accordion-area-title::after{    
top: 48%;
left: 0;
transform: rotate(90deg);
} .accordion-area-title.close::before{
transform: rotate(45deg);
}
.accordion-area-title.close::after{
transform: rotate(-45deg);
} .accordion-area-box {
display: none; background: #fff;
margin:0 3% 3% 3%;
padding: 3%;
} footer {
position: relative;
padding: 0;
margin: 0;
}
footer .inner {
background: #191919;
color: #FFF;
padding: 65px 0 20px 0;
font-size: 0.8rem;
}
footer a {
color: #FFF;
}
footer .inner .footer-logo {
margin-bottom: 20px;
}
footer .inner .footer-logo img {
width: 250px;
height: auto;
}
.footer-copy {
text-align: center;
margin-bottom: 30px;
}
.footer-text {
font-size: 0.75rem;
padding-left: 10px;
}
.footer-update {
font-size: 0.75rem;
padding-left: 10px;
}
footer .inner ul {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
flex-wrap: wrap;
}
.footer-link {
padding: 20px;
}
footer .inner ul li {
width: 100%;
list-style: none;
border-bottom: 1px solid #000;
padding: 15px 0;
}
footer .inner ul li span {
padding-left: 10px;
}
footer ul {
padding: 0 !important;
margin: 0 !important;
}
.copyright {
background: #000;
color: #FFF;
font-size: 0.8rem;
padding: 20px 25px;
}
.copyright p {
padding: 0;
margin: 0;
}
.copyright a {
text-decoration: underline;
}
@media screen and (min-width: 899px) {
footer .inner {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
padding: 60px 0 40px 0;
font-size: 0.9rem !important;
}
.footer-copy {
width: 30%;
text-align: left;
margin-left: 70px;
}
.footer-link {
width: 70%;
padding: 0;
}
footer .inner .footer-logo img {
width: 250px;
height: auto;
}
.footer-text {
font-size: 0.75rem;
padding-left: 15px;
}
.footer-update {
font-size: 0.75rem;
padding-left: 15px;
margin-top: 30px;
}
.footer-link ul {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
}
footer .inner ul li {
width: 25%;
list-style: none;
border-bottom: none;
padding: 0 0 30px 0;
}
} .scrolldown1{
position: absolute;
left: 8.6%;
bottom: 10px;
height: 0;
}
.scrolldown1::after{
content: "";
position: absolute;
top: 0;
width: 2px;
height: 100px;
background: #448538;
animation: pathmove 1.4s ease-in-out infinite;
opacity:0;
}
@media screen and (min-width: 1025px) {
.scrolldown1{
left: 15%;
}
}
@media screen and (min-width: 1600px) {
.scrolldown1{
left: 25%;
bottom: -150px;
}
}
@keyframes pathmove {
0% {
height: 0;
top: 0;
opacity: 0;
}
30% {
height: 50px;
opacity: 1;
}
100% {
height: 0;
top: 100px;
opacity: 0;
}
}
.scrolldown-page{
position: absolute;
left: 8.6%;
top: 0;
height: 0;
}
.scrolldown-page::after{
content: "";
position: absolute;
top: 0;
width: 2px;
height: 100px;
background: #448538;
animation: pathmove 1.4s ease-in-out infinite;
opacity:0;
}
@media screen and (min-width: 1025px) {
.scrolldown-page {
left: 15%;
}
}
@keyframes pathmove {
0% {
height: 0;
top: 0;
opacity: 0;
}
30% {
height: 50px;
opacity: 1;
}
100% {
height: 0;
top: 100px;
opacity: 0;
}
}  .bgextend {
animation-name: bgextendAnimeBase;
animation-duration: 1s;
animation-fill-mode: forwards;
position: relative;
overflow: hidden; opacity:0;
}
@keyframes bgextendAnimeBase {
from {
opacity:0;
}
to {
opacity:1;
}
}
.bgappear {
animation-name:bgextendAnimeSecond;
animation-duration:1s;
animation-delay: 0.6s;
animation-fill-mode: forwards;
opacity: 0;
}
@keyframes bgextendAnimeSecond {
0% {
opacity: 0;
}
100% {
opacity: 1;
}
} .bgLRextend::before{
animation-name: bgLRextendAnime;
animation-duration: 1s;
animation-fill-mode: forwards;
content: "";
position: absolute;
width: 100%;
height: 100%;
background-color: #448538;
padding: 10px 0 20px;
}
@keyframes bgLRextendAnime {
0% {
transform-origin:left;
transform:scaleX(0);
}
50% {
transform-origin:left;
transform:scaleX(1);
}
50.001% {
transform-origin:right;
}
100% {
transform-origin:right;
transform:scaleX(0);
}
} .bgappearTrigger,
.bgLRextendTrigger {
opacity: 0;
} #splash {
position: fixed;
width: 100%;
height: 100%;
background: #f7f7f5;
z-index: 9999999;
text-align: center;
color: #fff;
}
#splash-logo {
width: 80px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
}  .splashbg{
display: none;
} body.appear .splashbg {
padding: 0;
margin: 0;
display: block;
content: "";
position:fixed;
z-index: 999;
width: 100%;
height: 100vh;
top: 0;
left: 0;
transform: scaleX(0);
background-color: #448538; animation-name: PageAnime;
animation-duration: 1.2s;
animation-timing-function: ease-in-out;
animation-fill-mode: forwards;
}
@keyframes PageAnime{
0% {
transform-origin:left;
transform:scaleX(0);
}
50% {
transform-origin:left;
transform:scaleX(1);
}
50.001% {
transform-origin:right;
}
100% {
transform-origin:right;
transform:scaleX(0);
}
} #container{
opacity: 0; } body.appear #container {
animation-name: PageAnimeAppear;
animation-duration: 1s;
animation-delay: 0.8s;
animation-fill-mode: forwards;
opacity: 0;
}
@keyframes PageAnimeAppear{
0% {
opacity: 0;
}
100% {
opacity: 1;
}
} #container{
width:100%;
} @keyframes infinity-scroll-left {
from {
transform: translateX(0);
}
to {
transform: translateX(-100%);
}
} _:-ms-lang(x)::-ms-backdrop, .d-demo {
display: -ms-grid;
overflow: hidden;
} .d-demo__wrap {
display: flex;
overflow: hidden;
}
.d-demo__wrap ul {
padding: 0;
margin: 0;
}
.d-demo__list {
display: flex;
list-style: none;
height: 100%;
}
.d-demo__list--left {
animation :infinity-scroll-left 60s infinite linear 0.5s both;
}
.d-demo__item { width: calc(100vw / 1);
}
.d-demo__item > img {
width: 100%;
height: auto;
}
.animation {
animation-timing-function: ease-in-out;
animation-iteration-count: infinite;
animation-direction: alternate;
animation-duration: 1.5s;
}
.keyframe1 {
animation-name: anim_v;
}
@keyframes anim_v {
0% {
transform: translate(0, 0px);
}
100% {
transform: translate(0, 10px);
}
} .btn_link {
width: 200px;
margin: 50px auto 30px;
font-size: 0.9rem;
font-weight: bold;
}
.btn {
position: relative;
overflow: hidden;
text-decoration: none;
display: inline-block;
padding: 10px 30px;
text-align: center;
outline: none;
transition: ease .2s;
background: #191919;
border-radius: 50px;
}
.link_border_no a {
text-decoration: none !important;
width: 210px;
}
.btn span {
position: relative;
z-index: 3;
color: #FFF;
}
.btn:hover span {
color:#fff;
} .bgleft:before {
content: ''; position: absolute;
top: 0;
left: 0;
z-index: 2; background: #448538; width: 100%;
height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
transform: scale(0, 1);
transform-origin: right top;
border-radius: 50px;
} .bgleft:hover:before {
transform-origin: left top;
transform: scale(1, 1);
}
.update_link {
width: 210px;
margin: 50px auto 5px;
font-size: 0.85rem;
font-weight: bold;
}
.update_btn {
position: relative;
overflow: hidden;
text-decoration: none;
display: inline-block;
padding: 10px 30px;
text-align: center;
outline: none;
transition: ease .2s;
background: #FFFFFF;
border-radius: 50px;
border: 1px solid #448538;
color: #448538;
}
.update_link_border_no a {
text-decoration: none !important;
width: 200px;
color: #448538;
}
.update_btn span {
position: relative;
z-index: 3;
color: #448538;
}
.update_btn:hover span {
color:#fff;
} .update_bgleft:before {
content: ''; position: absolute;
top: 0;
left: 0;
z-index: 2; background: #448538; width: 100%;
height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
transform: scale(0, 1);
transform-origin: right top;
border-radius: 50px;
} .update_bgleft:hover:before {
transform-origin: left top;
transform: scale(1, 1);
}
.updatefooter_link {
width: 200px;
margin: 50px auto 20px;
font-size: 0.8rem;
font-weight: bold;
}
.updatefooter_btn {
position: relative;
overflow: hidden;
text-decoration: none;
display: inline-block;
padding: 10px 30px;
text-align: center;
outline: none;
transition: ease .2s;
background: #FFFFFF;
border-radius: 50px;
color: #448538;
}
.updatefooter_link_border_no a {
text-decoration: none !important;
width: 200px;
color: #FFFFFF;
}
.updatefooter_btn span {
position: relative;
z-index: 3;
color: #448538;
}
.updatefooter_btn:hover span {
color:#fff;
} .updatefooter_bgleft:before {
content: ''; position: absolute;
top: 0;
left: 0;
z-index: 2; background: #448538; width: 100%;
height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
transform: scale(0, 1);
transform-origin: right top;
border-radius: 50px;
} .updatefooter_bgleft:hover:before {
transform-origin: left top;
transform: scale(1, 1);
}
@media screen and (min-width: 899px) {
.updatefooter_link {
margin: 20px 0 0 30px;
}
}
#container {
　width: 100%;
　height: 100%;
　position: fixed;
} .pagination {
width: 100%;
}
.pagination ul  {
width: 90%;
margin: 30px auto;
display: flex;
padding-top: 30px;
border-top: 1px solid rgba(0,16,14,0.08);
font-size: 0.8rem;
flex-wrap: wrap;
}
.pagination ul li {
padding: 10px 30px 10px 0;
text-align: center;
}
.pagination ul li:last-child {
padding-right: 0;
}
.pagination .current {
background: #4D4D4D;
color: #FFF;
padding: 10px;
}
.ft_bread {
margin: 55px auto 55px;
}
.ft_bread ul {
display: flex;
padding-left: 0;
font-size: .85rem;
white-space: nowrap;
overflow-x: auto;
}
.ft_bread li {
display: inline-block;
position: relative;
list-style: none;
font-size: .845rem;
color: #adadad;
white-space: nowrap;
padding: 0 15px;
}
.ft_bread li:first-child {
padding-left: 0;
}
.ft_bread li:last-child {
padding-right: 0;
}
.ft_bread ul li::after {
padding-left: 5px;
content: "";
display: block;
width: 11px;
height: 11px;
border-top: 1px solid #cecece;
border-right: 1px solid #cecece;
transform: rotate(45deg);
position: absolute;
top: 0;
bottom: 0;
right: 0;
margin: auto 0;
}
.ft_bread ul li:last-child::after {
content: "";
border: none;
}
@media screen and (min-width: 1025px) {
.ft_bread { padding-left: 10px;
}
}
.youtube {
position: relative;
width: 100%;
padding-top: 56.25%;
}
.youtube iframe {
position: absolute;
top: 0;
right: 0;
width: 100%;
height: 100%;
} .qa-area{
list-style: none;
width: 100%;
margin: 0 auto;
padding-left: 0 !important;
}
.qa-area li{
margin: 10px 0;
}
.qa-area section {
border-bottom: 1px solid #ccc;
} .qa-area-title { position: relative; cursor: pointer; font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
padding: 3% 1% 3% 30px;
transition: all .5s ease;
font-size: 1rem !important;
line-height: 1.6;
}
@media screen and (min-width: 899px) {
.qa-area-title {
padding: 3% 3% 3% 50px;
}
} .qa-area-title::before,
.qa-area-title::after{
position: absolute;
content:'';
width: 15px;
height: 1px;
background-color: #333;
}
.qa-area-title::before{
top: 48%;
left: 0;
transform: rotate(0deg);
}
.qa-area-title::after{    
top: 48%;
left: 0;
transform: rotate(90deg);
} .qa-area-title.close::before{
transform: rotate(45deg);
}
.qa-area-title.close::after{
transform: rotate(-45deg);
} .qa-area-box {
display: none; margin: 0 3% 3% 3%;
padding: 0 3% 3% 3%;
}
.qa-area-box p {
margin: 0 !important;
text-align: justify;
}
.qa-area-box ol,
.qa-area-box ul{
padding-left: 20px !important;
}
@media screen and (min-width: 899px) {
.qa-area-box {
margin: 0 3% 3% 3%;
padding: 0 3% 3% 28px;
}
} #page-top a {
display: flex;
justify-content: center;
align-items: center;
background: #fff;
border-radius: 10px;
width: 50px;
height: 50px;
color: #fff;
text-align: center;
text-decoration: none;
font-size: 0.6rem;
transition: all 0.3s;
}
#page-top img {
width: 80%;
}
#page-top a:hover{
background: #eaeaea;
} #page-top {
position: fixed;
right: 20px;
bottom: 20px;
z-index: 5; opacity: 0;
transform: translateY(100px);
} #page-top.UpMove{
animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
from {
opacity: 0;
transform: translateY(100px);
}
to {
opacity: 1;
transform: translateY(0);
}
} #page-top.DownMove{
animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
from {
opacity: 1;
transform: translateY(0);
}
to {
opacity: 1;
transform: translateY(100px);
}
}
.g-slide{
position: relative;
overflow: hidden;
margin: 15px 0 30px 0;
padding-bottom: 50%;
padding-top: 65px;
}
.g-slide iframe {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
}
.page-link-box ul {
margin-left: 0 !important;
padding-left: 0;
}
#page-link {
margin-left: 0 !important;
display: flex;
flex-wrap: wrap;
}
#page-link li {
list-style: none;
margin: 0 30px 15px 0;
box-sizing: border-box;
font-size: .875rem; background: #eaeaea;
padding: 5px 10px;
border-radius: 5px;
}
#page-link li a {
display: block;
padding: 0;
text-decoration: none;
}
.page-link-head {
padding-top: 25px;
}
.arrow_u {
position: relative;
display: inline-block;
padding-right: 25px !important;
text-decoration: none;
}
.arrow_u:after {
content: '';
width: 8px;
height: 8px;
border: 0;
border-bottom: solid 2px #4c4c4c;
border-right: solid 2px #4c4c4c;
position: absolute;
top: 50%;
right: 10px;
margin-top: -6px;
transform: rotate(45deg);
}
.hissu {
margin-right: 6px;
color: #e54530;
}
.mwform-radio-field {
display: block;
}
@media screen and (min-width: 899px) {
.mwform-radio-field {
display: inline;
margin-right: 20px;
}
}
input { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 400;
font-style: normal;
}
.mw_wp_form .horizontal-item + .horizontal-item {
margin-left: 0 !important;
}
.cform option, .cform textarea, .cform input[type=text], .cform input[type=email], .cform input[type=search], .cform input[type=url] { font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 400;
font-style: normal;
width: 100% !important;
padding: 1em 2%;
border-radius: 3px;
border: 1px solid #eaeaea;
-webkit-appearance: none;
outline: none;
font-size: 1rem;
}
.mwform-tel-field input[type=text] {
width: 30.3% !important;
}
@media screen and (min-width: 899px) {
.mwform-tel-field input[type=text] {
width: 31% !important;
}
}
.submit-btn {
margin: 0 auto;
text-align: center;
}
.cform [type=submit] {
display: inline-block;
font-size: 1rem;
padding: 15px 35px;
margin-top: 30px;
text-decoration: none;
background: #448538;
background: #1e1e1e;
color: #FFF;
border-radius: 3px;
border: none;
}
.submit-backbtn [type=submit] {
display: inline-block;
font-size: .9rem;
padding: 10px 20px;
margin-top: 30px;
text-decoration: none;
background: #eaeaea;
color: #1e1e1e;
border-radius: 3px;
border: none;   
}
.form-box {
margin-bottom: 30px;
}
.gtranslate_pc {
position: absolute;
right: 5%;
top: 5%;
}
.gtranslate select {
border: 2px solid #000000;
}
.two_business {
margin-bottom: 60px !important;
}
.two_business div {
width: 100%;
background: #FFF;
padding: 15px 30px 10px;
border-radius: 10px;
margin: 20px 0;
}
.two_business div h2 {
color: #448538;
}
.two_business p {
text-align: justify;
letter-spacing: -0.5px;
}
.two_business div img {
max-width: 50%;
}
@media screen and (min-width: 899px) {
.two_business_box {
max-width: 850px;
margin: 0 auto;
}
.two_business {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
justify-content: center;
margin-bottom: 60px !important;
}
.two_business div {
width: 48%;
background: #FFF;
padding: 30px 50px 25px;
border-radius: 10px;
margin-right: 3%;
}
.two_business div:last-child {
margin-right: 0;
}
.two_business div h2 {
font-size: 1.275rem;
}
}
.top_h3 {
margin-top: 65px;
}
#page_mission {
margin-top: 65px !important;
}
#page_business {
margin-top: 65px !important;
}
.two_business_box {
width: 300px;
margin: 0 auto;
}
.two_business_c {
margin-bottom: 60px !important;
}
.two_business_c div {
position: relative;
display: inline-block;
width: 300px;
height: 300px;
background: #FFF;
border-radius: 50%;
margin-bottom: 10px;
}
.two_business_c div:last-child {
margin-bottom: 0;
}
.two_business_c span {
position: absolute;
display: inline-block;
left: 0;
top: 50%;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
width : 3    00px;
text-align:center;
}
.two_business_c div h2 {
color: #448538;
}
.two_business_c div img {
max-width: 20%;
}
.two_business_c div h2 {
font-size: 1.15rem;
margin-bottom: 10px;
letter-spacing: 0.5px;
}
.two_business_c div p {
line-height: 1.6;
font-size: 0.875rem;
font-size: 0.8rem;
font-size: 0.78rem;
margin-top: -10px;
width: 200px;
margin: 0 auto;
}
.two_business_ps {line-height: 1.1 !important; letter-spacing: 0 !important;}
@media screen and (min-width: 899px) {
.two_business_box {
width: 850px;
margin: 0 auto;
}
.two_business_c {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
margin-bottom: -30px !important;
}
.two_business_c div {
width: 400px;
height: 400px;
margin-right: 50px;
}
.two_business_c span {
width : 400px;
}
.two_business_c div:last-child {
margin-right: 0;
}
.two_business_c div h2 {
font-size: 1.275rem;
margin-bottom: 30px;
}
.two_business_c div p {
line-height: 1.8;
font-size: 1rem;
width: 300px;
margin: 0 auto;
}
}
.category-interview strong {
font-family: 'Noto Sans Japanese',   sans-serif;
font-family: "dnp-shuei-gothic-kin-std", sans-serif;
font-weight: 600;
font-style: normal;
}
.talk_head {
width: 90%;
margin: 50px auto 50px;
text-align: center;
}
.talk_head h1 {
font-size: 1.6rem;
}
.talk_head p {
font-size: 0.9rem;
}
.talk_list {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
flex-wrap: wrap;
}
.talk_list a {
transition: 1.0s;
}
.talk_list a img:hover {
opacity: 0.9;
transition-duration: 0.8s;
}
.talk_post {
width: 100%;
margin-bottom: 50px;
background: #FFF;
padding-bottom: 20px;
}
.talk_post figure {
margin: 0;
}
.talk_post h2 {
font-size: 0.9rem;
margin: 20px 20px 10px;
line-height: 1.6;
}
.talk_post h3 {
font-size: 0.785rem;
text-align: right;
line-height: 1.5;
color: #666666;
font-weight: normal;
margin: 0 10px;
font-feature-settings: "palt";
}
.talk_post .talk_day {
font-size: 0.675rem;
text-align: right;
margin: 0 10px;
}
@media screen and (min-width: 899px) {
.talk_post {
width: 48%;
margin-right: 4%;
margin-bottom: 50px;
background: #FFF;
padding-bottom: 20px;
}
.talk_post:nth-of-type(2n) {
margin-right: 0;
}
.talk_head h1 {
font-size: 1.6rem;
}
.talk_head p {
font-size: 1rem !important;
letter-spacing: 2px;
}
.talk_post h2 {
font-size: 1.1rem;
margin: 20px 30px;
line-height: 1.6;
}
.talk_post h3 {
font-size: 1rem;
line-height: 1.5;
margin: 0 30px 10px;
}
.talk_post .talk_day {
font-size: 0.875rem;
margin: 0 30px 10px;
}
}
.talk_name_box {
background: #FFF;
padding: 50px; }
.talk_name_2 {
font-weight: 600;
font-size: 0.9rem;
}
.talk_name_big {
font-size: 120%;
}
.talk_name {
color: #448538 !important;
}
.category-talk strong {
font-weight: 600;
}
@media screen and (min-width: 899px) {
.talk_name_2 {
font-size: 1rem;
}
}
.category-talk h1 {
margin-top: 0;
}
.category-talk p {
font-size: 1rem;
margin: 0 0 10px 0;
line-height: 2.1;
}
.category-talk dt {
float: left;
font-weight: 600;
font-size: 95%;
padding-top: 1px;
}
.category-talk dd {
margin-left: 66px;
margin-bottom: 40px;
text-align: justify;
}
.talk_bread {
}
@media screen and (min-width: 1025px) {
.talk_bread {
width: 90%;
max-width: 760px;
margin: 0 auto;
}
.category-talk dd {
margin-left: 80px;
margin-bottom: 40px;
text-align: justify;
}
}
.support_company {
display: flex;
flex-wrap: wrap;
}
.support_company div {
width: 48%;
text-align: center;
}
.support_company div img {
width: auto !important;
max-height: 40px;
margin: 20px 0 0;
}
@media screen and (min-width: 899px) {
.support_company div img {
width: auto !important;
max-height: 50px;
margin: 0;
}
}
.top_circle {
position: relative;
display: inline-block;
width: 180px;
height: 180px;
border-radius: 50%;
background: #FFFFFF;
}
.top_circle:hover {
background: #f7f7f5;
}
.top_circle .top_circle_text {
position: absolute;
display: inline-block; left: 0;
top: 50%;
-webkit-transform: translateY(-50%);
transform: translateY(-50%); width: 180px;
font-size: 0.75rem;
line-height: 1.5;
text-align: center;
}
.top_circle_text_tit {
color: #448538;
display: block;
padding-bottom: 12px;
font-weight: 600;
text-align: center;
margin-left: -7px;
font-size: 0.9rem;
}
.top_circle_text_text {
line-height: 1;
}
@media screen and (min-width: 1025px) {
.top_circle {
width: 280px;
height: 280px;
}
.top_circle .top_circle_text {
left: 45px;
left: 0;
top: 50%;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
width : 235px;
width : 280px;
font-size: 1rem;
}
.top_circle_text_tit {
font-size: 1.1rem;
margin-left: -10px;
}
.recruit_list {
max-width: 670px;
margin: 0 auto;
}
}
.company_en a {
text-decoration: underline;
}  #info {
display: none;
} .modaal-container{
max-width: 500px;
background: #f7f7f5;
} .modaal-close:after, 
.modaal-close:before{
background:#ccc;  
}
.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
background:#666;
}
.modal_contents button {
position: fixed;
left: 50%;
bottom: 1%;
transform: translateX(-50%) translateY(-50%);
background-color: transparent;
border: none;
cursor: pointer;
outline: none;
padding: 10px 30px;
appearance: none;
background: #448538;
color: #FFF;
font-size: 1rem !important;
font-weight: bold;
text-align: justify;
border-radius: 5px;
}
.modaal-content-container {
padding: 120px 150px !important;
text-align: justify;
}
.modaal-inner-wrapper {
padding: 0px 20px !important;
}
.modaal-content-container ul {
padding-left: 20px;
}
@media screen and (max-height: 1000px) {
.modaal-inner-wrapper {
padding-top: 0px !important; 
padding-bottom: 0px !important;
}
}
@media screen and (max-width: 480px) {
.modaal-container{
font-size: 0.9rem;
line-height: 1.5;
}
.modaal-content-container {
padding: 30px !important;
}
}
.as-link a,.as-link-ms a {
text-decoration: underline;
}
.as-link-ms {
font-size: 90%;
} a.anchor { display: block; padding-top: 100px; margin-top: -100px; text-decoration: none;}
.sbb_list_business { width: 100%;}
.sbb_listbox_business { width: 100%; display: flex; margin-bottom: 5px;}
.sbb_list_num_business { background-color: #448538; color: #FFFFFF; text-align: center; display: flex; align-items: center; padding: 0 10px;}
.sbb_list_txt_business { width: 100%; background-color: #FFFFFF; padding: 15px 15px; font-size: 0.9rem; line-height: 1.7;}
.sbb_support h3 {font-size: 1.1rem; line-height: 1.7; color: #448538; margin-bottom: 20px;}
.sbb_support ol {padding-left: 15px; font-size: 0.925rem;}
.sbb_business_nav {display: flex; font-size: 0.95rem; line-height: 1.7; margin: 40px auto; font-weight: bold;}
.sbb_business_nav div {width: 42%; text-align: center;}
.sbb_business_nav a { color: #6d6d6d;}
.sbb_business_nav a:hover {text-decoration: none; color: #333333;}
.sbb_business_nav_active {color: #448538; border-bottom: 2px solid #448538; padding-bottom: 10px; margin: 0 4%;}
.sbb_business_nav_link { color: #6d6d6d; border-bottom: 2px solid #6d6d6d; padding-bottom: 10px; margin: 0 4%;}
.f_num {color: #448538; font-weight: bold; line-height: 1.1;}
.f_num small {padding-left: 2px;}
.f_num span {font-size: 2rem;}
.sbb_business_tit h2 { margin-bottom: 30px !important;}
.sbb_page_bg { position: relative; background: #FFF; padding: 50px 30px 60px; margin: 30px auto;}
.sbb_page_bg_no { position: relative; padding: 40px 10px 60px; margin: 30px auto;}
.sbb_page_bg h2, .sbb_page_bg_no h2 { font-size: 1.2rem; line-height: 1.7; color: #448538; margin-bottom: 60px;}
.sbb_page_bg p, .sbb_page_bg_no p { font-size: 0.95rem; line-height: 1.7; text-align: justify;}
.sbb_page_bg p span, .sbb_page_bg_no p span { color: #448538; }
.sbb_page_bg_about { position: relative; padding: 40px 30px 40px; margin: 30px auto;}
.sbb_page_bg_about h2 { font-size: 1.3rem; line-height: 1.7; color: #448538; margin-bottom: 60px;}
.sbb_page_bg_about p { font-size: 0.95rem; line-height: 1.7; text-align: justify;}
.sbb_page_bg_about p span { color: #448538; }
.img-about-1 { max-width: 300px; margin: 0 auto;}
.img-about-2 { max-width: 200px;}
.sbb_list { width: 100%;}
.sbb_listbox { width: 100%; display: flex; margin-bottom: 5px;}
.sbb_list_num { background-color: #448538; color: #FFFFFF; text-align: center; display: flex; align-items: center; padding: 0 10px;}
.sbb_list_txt { width: 100%; background-color: #FFFFFF; padding: 15px 15px; font-size: 0.9rem; line-height: 1.7;}
.sb7 ol {padding-left: 10px;}
.sb7 li {font-size: 0.95rem; line-height: 1.5; margin-bottom: 10px;}
.business_link {
width: 210px;
margin: 50px auto 5px;
font-size: 0.85rem;
font-weight: bold;
}
.business_btn {
position: relative;
overflow: hidden;
text-decoration: none;
display: inline-block;
padding: 10px 30px;
text-align: center;
outline: none;
transition: ease .2s;
background: #448538;
border-radius: 50px;
color: #FFFFFF;
}
.business_link_border_no a {
text-decoration: none !important;
width: 200px;
color: #FFFFFF;
margin-bottom: 60px;
}
.business_btn span {
position: relative;
z-index: 3;
color: #FFFFFF;
}
.business_btn:hover span {
color:#fff;
} .business_bgleft:before {
content: ''; position: absolute;
top: 0;
left: 0;
z-index: 2; background: #333333; width: 100%;
height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
transform: scale(0, 1);
transform-origin: right top;
border-radius: 50px;
} .business_bgleft:hover:before {
transform-origin: left top;
transform: scale(1, 1);
}
.two_business {margin-bottom: 0 !important;}
@media screen and (max-width: 375px) {
.sbb_page_bg { position: relative; background: #FFF; padding: 60px 20px 40px; }
}
.img-about-4 { max-width: 400px !important; text-align: right !important; margin: 0 0 0 auto !important}
@media screen and (min-width: 899px) {
a.anchor { display: block; padding-top: 60px; margin-top: -60px; text-decoration: none;}
.sbb_business_nav {max-width: 550px; margin: 80px auto 120px !important; font-size: 1.2rem !important;}
.f_num {line-height: 1.2;}
.f_num small {padding-left: 2px; font-size: 120% !important;}
.f_num span {font-size: 3rem;}
.social_issue {display: flex; flex-direction: row-reverse;}
.social_issue_img {width: 50%;}
.social_issue_txt {width: 50%;}
.sbb_support h3 {font-size: 1.2rem !important;}
.sbb_support ol {padding-left: 15px; font-size: 1rem !important;}
.sbb_business_tit h2 { margin-bottom: 60px !important; text-align: left !important;}
.sbb_page_bg { max-width: 1040px; padding: 80px 120px 100px !important; margin: 40px auto !important; border-radius: 10px; }
.sbb_page_bg h2, .sbb_page_bg_no h2 { font-size: 1.8rem !important; line-height: 1.3 !important; color: #448538; text-align: center;}
.sbb_page_bg p, .sbb_page_bg_no p { font-size: 1.125rem !important; line-height: 1.7; text-align: justify;}
.sbb_page_bg_about { max-width: 1040px; padding: 80px 120px 80px !important; margin: 40px auto !important; border-radius: 10px; }
.sbb_page_bg_about h2 { font-size: 1.8rem !important; line-height: 1.3 !important; color: #448538; text-align: center;}
.sbb_page_bg_about p { font-size: 1.125rem !important; line-height: 1.7; text-align: justify;}
.sbb_thought {max-width: 680px !important; margin: 80px auto 0;}
.img-about-1 { max-width: 480px !important; margin: 0 auto;}
.img-about-2 { max-width: 300px !important;}
.img-about-3 { max-width: 680px !important; margin: 0 auto;}
.img-about-4 { max-width: 400px !important; text-align: right !important; margin: 0 0 0 auto !important}
.img-about-5 { max-width: 750px !important; margin: 0 auto;}
.sbb_page_bg_txt_pc p { text-align: center !important;}
.sbb_list { max-width: 880px !important; margin: 0 auto;}
.sbb_list_num { font-size: 1.125rem !important; padding: 0 20px !important;}
.sbb_list_txt { padding: 20px 15px !important; font-size: 1.125rem !important;}
.sbb_list_business { width: 850px !important; margin: 0 auto;}
.sbb_list_num_business { font-size: 1.125rem !important; padding: 0 20px !important;}
.sbb_list_txt_business { padding: 20px 15px !important; font-size: 1.125rem !important;}
.sb7 ol { max-width: 600px !important; margin: 0 auto;}
.sb7 li { font-size: 1.125rem !important; line-height: 1.5; margin-bottom: 10px;}
}
.social-mission {background: #FFF; width: 100%; padding: 15px 30px 10px; border-radius: 10px; margin: 20px 0;}
.social-mission-about-cap {font-size: 0.8rem !important;}
.social-mission_last {margin-bottom: 80px !important;}
.social-mission h2 {font-size: 1rem; line-height: 1.7; font-feature-settings: "palt"; letter-spacing: 0.2px; text-align: justify;}
.social-mission h2 small {line-height: 2.6; letter-spacing: 1.7px;}
.social-mission ol {padding-left: 18px;}
.social-mission li {width: 100%; max-width: none; text-align: justify; list-style-type: decimal; padding: 0 0 0 5px; font-size: 0.9rem; color: #4D4D4D; margin-bottom: 10px;}
.social-mission li:last-child {margin-bottom: 30px;}
@media screen and (min-width: 899px) {
.social-mission_last {margin-bottom: 140px !important;}
.social-mission h2 {font-size: 1.275rem; line-height: 1.7; font-feature-settings: "palt"; letter-spacing: 1.7px; text-align: justify;}
.social-mission h2 small {line-height: 2.6; letter-spacing: 1.7px; font-size: 1.1rem !important;}
.social-mission ol {padding-left: 22px;}
.social-mission li {width: 100%; max-width: none; text-align: justify; list-style-type: decimal; padding: 0 0 0 5px; font-size: 1.1rem; color: #4D4D4D; margin-bottom: 10px;}
.social-mission-about-cap {font-size: 1rem !important;}
}
.social-mission-index {background: none; width: 100%; padding: 0; border-radius: 10px; margin: 30px 0;}
.social-mission-index h2 {font-size: 1rem; line-height: 1.7; font-feature-settings: "palt"; letter-spacing: 0.2px; text-align: justify;}
.social-mission-index h2 small {line-height: 2.6; letter-spacing: 1.7px; font-size: 0.9rem !important;}
.social-mission-index ol {padding-left: 18px;}
.social-mission-index li {width: 100%; max-width: none; text-align: justify; list-style-type: decimal; padding: 0 0 0 5px; font-size: 0.84rem; color: #4D4D4D; margin-bottom: 10px; background: none; letter-spacing: -0.7px;}
.social-mission-index-cap {font-size: 0.8rem !important; line-height: 1.4; text-indent: -1em; padding-left: 1em;}
@media screen and (min-width: 899px) {
.social-mission-index h2 {font-size: 1.275rem; line-height: 1.7; font-feature-settings: "palt"; letter-spacing: 1.7px; text-align: justify;}
.social-mission-index h2 small {line-height: 2.6; letter-spacing: 1.7px; font-size: 1.1rem !important;}
.social-mission-index ol {padding-left: 24px;}
.social-mission-index li {width: 100%; max-width: none; text-align: justify; list-style-type: decimal; padding: 0 0 0 5px; font-size: 1.06rem; color: #4D4D4D; margin-bottom: 10px; letter-spacing: 0.2px;}
.social-mission-index-cap {font-size: 1rem !important;}
}
.about_ps {
line-height: 1.1 !important;
margin-bottom: 100px;
}
.sbb_business_text {
width: 100%;
}
@media screen and (min-width: 899px) {
.sbb_business_text {max-width: 800px; margin: 0 auto; font-size: 1.125rem !important;}
} .report_header {text-align: center; margin: 80px auto; color: #448538; }
.report_header h1 {font-size: 1.4rem;}
.report_header h2 {font-size: 1rem;}
.report_copy {text-align: center; margin: 0 auto 80px; line-height: 1.9;}
.report_copy p {margin-bottom: 25px; font-size: 0.95rem;}
.report-white {padding: 40px 30px 20px;}
.report-pt {margin-bottom: 50px;}
.report_price {text-align: left; margin: 40px auto 0; background: #448538; padding: 10px; line-height: 1.4; font-weight: bold; font-size: 0.9rem; color: #FFF;}
.report_mo {text-align: center; color: #448538; font-weight: bold; background: #F5F5F5; margin: 0;}
.report_mo_num {font-size: 3rem;}
.report_mo_en {font-size: 1.8rem;}
.report_table {margin-bottom: 80px; font-size: 0.85rem;}
.report_table table { border-collapse: collapse; border: solid 0px #448538; width: 100%;}
.report_table table th, table td { border: dashed 0px #448538; line-height: 1.4;}
.report_table table th {background: #448538; color: #FFF; padding: 10px;}
.report_table table tr td {background: #FFF; padding: 10px;}
.report_table table tr:nth-child(2n+1) td { background-color: #F5F5F5;}
.report_table_r {text-align: right; font-weight: bold;}
.report_table_kei {font-size: 1rem;}
.report_table_tit {background: #448538;}
.report_note {line-height: 1.4; margin-bottom: 60px;}
.sbb_thought hr {width: 10%; margin: 30px auto; border: 1px solid #448538;}
.sbb_thought ul li, .sbb_thought ol li {font-size: 1rem; margin-left: 5px;} 
.report_link a {color: #448538; border-bottom: 1px solid #448538; padding-bottom: 2px;}
.report_link a:hover {text-decoration: none; color: #333333; border-bottom: 1px solid #333333;}
@media screen and (max-width: 767px) {
.report_table table { display: block; width: 100%;}
.report_table table tr { display: flex; width: 100%; align-items: stretch;}
.report_table table .report_table_l {width: 63%;}
.report_table table .report_table_r {width: 37%;}
}
@media screen and (min-width: 600px) {
.report_header h1 {font-size: 2rem;}
.report_header h2 {font-size: 1.4rem;}
.report_copy p {margin-bottom: 25px; font-size: 1.05rem;}
.report-white {padding: 20px;}
.sbb_thought ul li, .sbb_thought ol li {font-size: 1.1rem;}
.report_price {text-align: center; margin: 40px auto 0; background: #448538; color: #FFF; padding: 10px; font-size: 1.1rem;}
.report_mo {text-align: center; color: #448538; font-weight: bold; background: #F5F5F5; margin: 0;}
.report_table {font-size: 1rem;}
}
.report_project {margin: 80px auto 0;}
.report_project h2 { margin-bottom: 30px; font-size: 1.4rem; color: #4D4D4D;}
.report_project_box {}
.report_project_box_p {margin: 15px auto;}
.report_project_box_t {margin: 15px auto;}
.report_project_box2 {margin-bottom: 60px;}
.report_project_box2_p {margin: 15px auto;}
.report_project_box2_t {margin: 15px auto;}
@media screen and (min-width: 600px) {
.report_project_box {display: flex; flex-direction:row-reverse;}
.report_project_box_p {margin-right: 15px; width: 45%;}
.report_project_box_t {margin-left: 15px; width: 55%;}
.report_project_box2 {display: flex; flex-direction:row;}
.report_project_box2_p {margin-right: 15px; width: 45%;}
.report_project_box2_t {margin-left: 15px; width: 55%;}
.abc_tv {font-size: 1.4rem;}
.report_project_box2 {margin-bottom: 10px; align-items: center;}
.report_project_box2 h4 {font-size: 1.4rem; margin: 15px 0 0;}
}
.report_thema ol li {font-weight: bold; color: #448538;}
.report_thema ol li span {font-weight: normal; color: #4D4D4D;}
.report_thema dl dt, .report_thema dl dd {font-size: 1rem !important; line-height: 1.6; text-align: justify;}
.report_thema dt { font-weight: bold; color: #448538; margin-bottom: 10px; border-left: 3px solid #448538; padding-left: 10px;}
.report_thema dd { margin-bottom: 40px;}
.report_thema h4 {font-size: 1.3rem; text-align: center;}
.report_text_center {text-align: center!important;}
.report-last {text-align: right !important; margin: 60px 0; font-size: 1rem !important;}
.report_thema_1 dd {padding-left: 25px;}
.report_thema dd {padding-left: 15px;}
@media screen and (min-width: 600px) {
.report_thema dl dt, .report_thema dl dd {font-size: 1.1rem !important; line-height: 1.6;}
.report-last {font-size: 1.1rem !important;}
}
.report_marker {
background:linear-gradient(transparent 60%, #ffff66 60%);
font-weight: 600;
color: #4D4D4D !important;
}
.sbb_thought p {
line-height: 1.8;
}
@media screen and (max-width: 375px) {
.report_copy p {font-size: 0.9rem;}
}
.report_banner {position: fixed; bottom: 0; text-align: left; width: 100%; margin: 0 0 0 0; z-index: 4;}
.report_banner_link { margin: 0 auto; background: #448538; background-image: linear-gradient(90deg, rgba(29, 163, 137, 1), rgba(247, 209, 55, 1) 90%); padding: 10px 0 10px 20px; line-height: 1.6; font-size: 0.9rem;}
.report_banner a {color: #FFF;}
.report_banner a:hover {text-decoration: none;}
@media screen and (min-width: 600px) {
.report_banner_link { padding: 20px 0; text-align: center;font-size: 1.1rem;}
}
.talk_profile {
text-align: justify;
line-height: 1.5;
}
.TrustedBy {margin-bottom: 20px;}
.index_trusted_list {display:-webkit-box; display:-ms-flexbox; display:flex; flex-flow: row wrap;}
.index_trusted_list div {width: 50%; padding: 15px 10px 0;}
.index_trusted_list div h2 {margin: 10px 0 2px 0; font-size: 0.9rem; line-height: 1.5; letter-spacing: 0.6px;}
.index_trusted_list div p {font-size: 0.75rem; line-height: 1.5; margin-bottom: 5px; font-feature-settings: "palt"; text-align: justify;}
.index_trusted_list div a {cursor: pointer;}
.index_trusted_list div a:hover {transition: all 1s; text-decoration: none; opacity: 0.8; transition-duration: 0.5s;}
.index_trusted_list div img {border-radius: 3px;}
.index_trusted_list div img:hover {opacity: 0.8; transition-duration: 0.5s;}
.trusted_link {color: #448538;}
.trusted_link a {text-decoration: none; color: #448538;}
.TrustedBySm {font-size: 0.68rem;}
@media screen and (min-width: 899px) {
.index_trusted_list div h2 { font-size: 1rem; line-height: 1.7; letter-spacing: 1.2px;}
.index_trusted_list div { border-radius: 10px; width: 33.3%; padding: 20px 10px 0;}
.TrustedBySm {font-size: 0.87rem;}
}
.index_trusted_list div p {font-size: 0.87rem; line-height: 1.5;}
.ey {line-height: 1.4; font-size: 0.9rem; margin-bottom: 10px;}
@media screen and (min-width: 899px) {
.post-1549 .entry_page_bg h1 {font-size: 1.8rem !important;}
.post-1549 .entry_page_bg2 h1 {font-size: 1.8rem !important;}
.post-1549 {max-width: 980px !important;}
}
.post-1549 ol {
margin: 0;
padding: 0
}
.post-1549 ol li {
list-style: none;
padding-left: 1.3em;
text-indent: -1.3em;
}
.azuma_column_tx {border-top: 1px dotted #448538; border-bottom: 1px dotted #448538; margin: 20px 0; padding: 20px 30px 0; background: rgba(255, 255, 255, 0.8);}
.azuma_column_tx p {font-size: 0.95rem; color: #448538; letter-spacing: 1.7px; font-weight: bold; text-align: justify;}
@media screen and (min-width: 899px) {
.azuma_column_tx p {letter-spacing: 1.7px; text-align: center;}
}
.column-by {margin: 60px 0; }
.column-by-sbb { border-top: thick double #a2a2a2; border-bottom: thick double #a2a2a2; padding: 40px 0 30px 10px; margin-bottom: 30px;}
.column-by-work {text-align: right; margin-bottom: 100px;}
.column-by-text span {font-size: 90%;}   .index_about_copy {width: 100%; margin-bottom: 30px}
.index_about_copy h2 {font-size: 1rem !important; line-height: 2;}
.index_about_img {width: 100%; filter: drop-shadow(5px 5px 5px #dddddd); }
@media screen and (min-width: 899px) {
.index_about_copy h2 {font-size: 1.275rem !important;}
.index_about {display: flex; flex-wrap: wrap;}
.index_about_copy {width: 38%; margin-right: 2%;}
.index_about_img {width: 60%; margin-top: 22px; margin-top: 60px;}
}
.index_btn {margin-top: 67px;}
.index_btn2 {margin: 60px auto 100px; width: 260px;}
.index_btn4 {margin: 30px auto 60px; width: 100%;}
.btn2 { position: relative; overflow: hidden; text-decoration: none; display: inline-block; text-align: center; outline: none; transition: ease .2s; background: #191919; background-color: #ffce00; border-radius: 10px; width: 100%; padding: 22px 32px 22px; font-weight: 500; -webkit-transition: 0.2s; transition: 0.2s;}
.btn2::after { position: absolute; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); content: "\f054"; font-size: 14px; font-weight: 600; -webkit-transition: 0.1s; transition: 0.1s; font-family: "Font Awesome 6 Free"; color: #FFF; color: #333333; right: 42px; z-index: 4;}
.btn2:hover span { color:#fff; -webkit-transition: 1s; transition: 1s;}
.btn2 span { position: relative; z-index: 3; color: #FFF; color: #333333;}
.bgleft2:before { content: ''; position: absolute; top: 0; left: 0; z-index: 2; background: #448538; width: 100%; height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s; transform: scale(0, 1); transform-origin: right top; border-radius: 10px;}
.btn2:hover:after { color: #fff; -webkit-transition: 1s; transition: 1s;}
.bgleft2:hover:before { transform-origin: left top; transform: scale(1, 1);}
.link_border_no2 a {text-decoration: none !important;}
.btn3 { position: relative; overflow: hidden; text-decoration: none; display: inline-block; text-align: center; outline: none; transition: ease .2s; background: #448538; border-radius: 10px; width: 100%; max-width: 300px; padding: 16px 32px 16px; font-weight: 400; -webkit-transition: 0.2s; transition: 0.2s;}
.btn3::after { position: absolute; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); content: "\f054"; font-size: 14px; font-weight: 600; -webkit-transition: 0.1s; transition: 0.1s; font-family: "Font Awesome 6 Free"; color: #FFF; right: 16px; z-index: 4;}
.btn3:hover span { color:#fff; -webkit-transition: 1s; transition: 1s;}
.btn3 span { position: relative; z-index: 3; color: #FFF;}
.bgleft3:before { content: ''; position: absolute; top: 0; left: 0; z-index: 2; background: #191919; width: 100%; height: 100%; transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s; transform: scale(0, 1); transform-origin: right top; border-radius: 10px;}
.btn3:hover:after { color: #fff; -webkit-transition: 1s; transition: 1s;}
.bgleft3:hover:before { transform-origin: left top; transform: scale(1, 1);}
.cycle {background: #FFF; width: 100%; border-radius: 10px; text-align: center; padding: 20px 0; filter: drop-shadow(5px 5px 5px #dddddd); margin-top: 30px;}
.cycle p {margin: 0;}
.cycle_tit {font-size: 0.9rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #4D4D4D;}
.cycle_tit_top {font-size: 0.84rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #4D4D4D;}
.cycle_txt {font-weight: 600; color: #ec6f1a; font-size: 32px !important; font-family: 'Barlow', sans-serif; letter-spacing: 0.05em !important; line-height: 1.4; vertical-align: text-bottom;}
.cycle_txt_en {color: #4D4D4D; font-size: 0.9rem !important; letter-spacing: 0; padding: 5px; vertical-align: baseline; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600; }
.cycle_txt_small {color: #4D4D4D; font-size: 0.9rem !important; letter-spacing: 0; padding: 5px; vertical-align: middle; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600;}
@media screen and (min-width: 899px) {
.index_btn2 { width: 300px;}
.cycle {width: 300px; margin-top: 20px;}
.index_btn4 {margin: 65px auto 120px; max-width: 600px;}
} .social-mission {margin: 0 auto 30px; filter: drop-shadow(5px 5px 5px #dddddd);}
.social-mission div {margin: 40px auto 50px; max-width: 850px}
.about_box {display: flex; flex-wrap: wrap;}
.about_box .about_mission {width: 49%; margin-right: 1%; background: #FFF; border-radius: 10px; text-align: center; padding: 20px 0; filter: drop-shadow(5px 5px 5px #dddddd);}
.about_box .about_cycle {width: 49%; margin-left: 1%; padding: 60px 0;}
.cycle {background: #FFF; border-radius: 10px; text-align: center; padding: 20px 0; filter: drop-shadow(5px 5px 5px #dddddd); vertical-align: middle;}
.cycle p {margin: 0;}
.cycle_tit {font-size: 1rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #4D4D4D;}
.cycle_tit2 {font-size: 0.9rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #4D4D4D; text-align: right; padding-right: 10%;}
.cycle_txt {font-weight: 900; color: #ec6f1a; font-size: 2.4rem !important; font-family: 'Barlow', sans-serif; letter-spacing: 0.05em !important; line-height: 1.6; vertical-align: text-bottom;}
.cycle_txt_about {font-weight: 900; color: #ec6f1a; font-size: 2.8rem !important; font-family: 'Barlow', sans-serif; letter-spacing: 0.05em !important; line-height: 1.4; vertical-align: text-bottom;}
.cycle_txt_en {color: #4D4D4D; font-size: 1rem !important; letter-spacing: 0; padding: 5px; vertical-align: baseline;}
.cycle_txt_small {color: #4D4D4D; font-size: 1rem !important; letter-spacing: 0; padding: 5px; vertical-align: middle; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600;}
.cycle_txt2 {font-weight: 700; color: #448038; font-size: 1.6rem !important; font-family: 'Barlow', sans-serif; letter-spacing: 0.05em !important; line-height: 1.4; vertical-align: text-bottom;}
.about_cycle_table table {font-weight: 700; background: #f5f5f5; width: 80%; margin: 0 auto; font-family: 'Barlow', sans-serif; font-size: 0.9rem; text-align: center;}
.about_cycle_table tr:nth-child(odd) td { background: #eee;}
.about_cycle_table_num {font-size: 1.4rem !important; color: #448038; padding: 5px; vertical-align: baseline;}
.about_cycle_table th {background: #448038; color: #FFF; letter-spacing: 0.1em;}
.table_th_l {border-radius: 10px 0 0 0;}
.table_th_r {border-radius: 0 10px 0 0;}
.about_cycle_table td {border-right: 1px solid #448038;}
.about_cycle_table td:last-child {border-right: none;}
.about_mission_txt {font-size: 1.6rem !important;}
@media screen and (min-width: 899px) {
.cycle_tit {font-size: 1.2rem !important;}
.cycle_txt {font-size: 2.2rem !important;}
.cycle_txt_en {font-size: 1.2rem !important;}
.cycle_txt_small {font-size: 1.2rem !important;}
.about_cycle_table_num {font-size: 1.6rem !important;}
}
.about_cycle {margin-bottom: 30px;}
.about_cycle_l {width: 100%; margin: 30px 0;}
.about_cycle_r {width: 100%; margin: 30px 0;}
.about_nav_img {display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 30px;}
.about_nav_img div {width: 30.3%; filter: drop-shadow(5px 5px 5px #dddddd);}
.about_nav_img div a:hover {opacity: 0.5;}
.content_100 { border-radius: 10px;}
.sbb_page_bg {border-radius: 10px;}
.project_wrap {background-color: #f8f8f8; padding: 22px 20px 17px 22px; border-radius: 10px; margin-bottom: 30px;}
.project_wrap p {font-size: 0.8rem !important;}
@media screen and (min-width: 899px) {
.about_cycle {display: flex; flex-wrap: wrap; width: 100%;}
.about_cycle_l {width: 50%; margin: 60px 0;}
.about_cycle_r {width: 50%; margin: 30px 0;}
.project_wrap { padding: 22px 20px 17px 40px;}
.project_wrap p {font-size: 0.95rem !important;}
}
.work_box_l {width: 100%; }
.work_box_r {width: 100%; }
.work_more_link {text-align: center !important;}
.work_more_link a { font-size: 0.8rem; color: #448538 !important; border: 1px solid #448538; border-radius: 50px; padding: 10px 30px;}
.work_more_link a:hover {background: #448538; color: #FFF !important; text-decoration: none; border: 1px solid #448538;}
@media screen and (min-width: 899px) {
.work_box {display: flex; flex-wrap: wrap;}
.work_box_l {width: 40%; margin-right: 5%; }
.work_box_r {width: 55%; }
.work_more_link {text-align: left !important; margin: 40px 0 0 5px;}
.work_more_link a { font-size: 1rem;}
} .origination_header {text-align: center; margin-bottom: 30px; color: #448538;}
.origination_header h1 {font-size: 1.5rem; line-height: 1.6 !important; margin-top: 60px}
.origination_img {width: 220px; height: auto; margin: 0 auto;}
.content_100 { border-radius: 10px;}
.sbb_page_bg {border-radius: 10px;}
.origination_text {}
.origination_bx {width: 90%; margin: 0 auto; background: #fff; padding: 40px 20px 40px 40px; filter: drop-shadow(5px 5px 5px #dddddd); border-radius: 10px; margin-bottom: 60px; font-size: 0.9rem;}
.origination_num {display: flex; flex-wrap: wrap; color: #4D4D4D !important;}
.origination_num div:nth-child(odd){ width: 100%; text-align: left;}
.origination_num div:nth-child(even) { width: 100%; text-align: left;}
.origination_num a { color: #448538 !important; text-decoration: none;}
.origination_num a:hover { color: #448538 !important; text-decoration: none;}
.origination_num span {font-size: 12px; padding-left: 10px; vertical-align: middle;}
.content_90 { width: 90%; margin: 0 auto;}
@media screen and (min-width: 899px) {
.origination_bx {max-width: 800px; padding: 30px 40px 30px 80px; font-size: 1rem;}
.origination_header h1 {font-size: 1.8rem; line-height: 1.6 !important;}
.origination_num {display: flex; flex-wrap: wrap;}
.origination_num div:nth-child(odd){ width: 45%; text-align: left; margin-right: 5%;}
.origination_num div:nth-child(even) { width: 45%; text-align: left; margin-left: 5%;}
.content_90 {width: 100%;}
}
.info_list {
text-indent: -1.6em !important;
padding-left: 1.6em !important;
margin-bottom: 16px !important;
} 
.info_list li {
list-style-type: none;
counter-increment: cnt;
margin-bottom: 4px;
}
.info_list li::before {
content: "(" counter(cnt) ") ";
}
.sbb_page_bg_about { position: relative; padding: 40px 30px 10px; margin: 30px auto 10px;}
.sbb_page_bg_about h2 { font-size: 1.3rem; line-height: 1.7; color: #448538; margin-bottom: 60px;}
@media screen and (min-width: 899px) {
.sbb_page_bg_about { max-width: 1040px; padding: 60px 120px 60px !important; margin: 40px auto !important; border-radius: 10px; }
}
.about_text_box p {text-align: justify !important; line-height: 2; color: #4d4d4d;}
.origination_list {display: flex; flex-wrap: wrap; justify-content: space-between;}
.origination_contents {width: 100%; background: #FFF; border-radius: 10px; position: relative; filter: drop-shadow(5px 5px 5px #dddddd); margin-bottom: 60px; padding-bottom: 50px}
.origination_contents a:hover {text-decoration: none; opacity: 0.5;}
.origination_contents_img { border-radius: 10px 10px 0 0;}
.origination_contents dl {padding: 0 30px 0;}
.origination_contents dt {font-weight: 700; font-size: 0.85rem; color: #448538;}
.origination_contents dd {font-size: 0.9rem; line-height: 1.6; margin-bottom: 15px;}
.origination_contents dd span {font-family: 'Barlow', sans-serif; font-weight: 500; font-size: 1.4rem; padding-right: 3px; line-height: 1;}
.origination_contents_en { padding: 20px 30px; display: inline-flex; width: 100%; border-bottom: 0.25px solid #aaaaaa;}
.origination_contents_en_tit {font-weight: 700; font-size: 0.95rem; width: 50%; color: #448538;}
.origination_contents_en_num {font-weight: 700; font-size: 0.95rem; line-height: 1.6; width: 50%; text-align: right; color: #448538;}
.origination_contents_en_num span {font-family: 'Barlow', sans-serif; font-weight: 500; font-size: 1.8rem; padding-right: 3px; line-height: 1;}
.origination_contents_en_tit2 {font-weight: 700; font-size: 0.95rem; width: 65%; color: #448538;}
.origination_contents_en_num2 {font-weight: 700; font-size: 0.95rem; line-height: 1.6; width: 35%; text-align: right; color: #448538;}
.origination_contents_en_num2 span {font-family: 'Barlow', sans-serif; font-weight: 500; font-size: 1.8rem; padding-right: 3px; line-height: 1;}
.origination_more {position: absolute; width: 100%; border-radius: 0 0 10px 10px; padding: 8px 0; bottom: 0; text-align: center; background: #448538; color: #FFF; font-size: 0.8rem;}
.origination_other_list {display: flex; flex-wrap: wrap; justify-content: space-between;}
.origination_other_list div {width: 23%; margin-bottom: 30px;}
.origination_other_list::after {display: block; content:""; width: 23%;}
.origination_other_list div:hover {opacity: 0.5; transition: all 0.5s ease-in-out;}
.origination_other_list div img {border-radius: 5px; filter: drop-shadow(5px 5px 5px #dddddd);}
.origination_other_list_tit {text-align: center; font-weight: 600; color: #448538; margin: 50px 0; font-size: 1.2rem}
@media screen and (min-width: 899px) {
.about_text_box p {text-align: center !important;}
.origination_contents {width: 30.3%;}
.origination_other_list div { width: 15%; margin-bottom: 30px;} }
.origination_contents_ennew {padding: 20px 30px;}
.origination_03 {line-height: 2; margin: 80px auto 0; text-align: justify;}
.origination_03 dt {font-weight: 700; color: #448538; font-size: 1.05rem !important; margin-bottom: 10px}
.origination_03 dd { font-size: 0.95rem !important; margin-bottom: 50px}
@media screen and (min-width: 899px){
.origination_03 {text-align: center;}
.origination_03 dt { font-size: 1.225rem !important;}
.origination_03 dd { font-size: 1.125rem !important;}
}
.project_text p {line-height: 1.8;}
.project_catch {margin-bottom: 30px;}
.origination_h3 {color: #448538;}
.origination_h3 span {border-left: 3px solid #448538; padding-left: 10px; margin-bottom: 30px;}
.origination_numbers {font-weight: 700; font-size: 0.95rem;}
.origination_numbers span {font-family: 'Barlow', sans-serif; font-weight: 500; font-size: 1.8rem; padding-right: 3px; line-height: 1; color: #4D4D4D !important;}
.project_img_re {width: 100%;}
@media screen and (min-width: 899px){
.project_img_re {max-width: 550px; margin: 0 auto;}
.project_img_re2 {max-width: 550px; margin: 0 auto;}
}
.mascot_p1 {width: 140px; height: auto; margin: 0 0 0 auto; position: absolute; right: 8%; bottom: -8px;}
.mascot_f1 {width: 140px; height: auto; margin: 0 0 0 auto; position: absolute; right: 5%; top: -262px;}
.mascot_p2 {width: 160px; height: auto; margin: 30px auto 0;}
.mascot_p3 {width: 80px; height: auto; bottom: -50px; position: absolute; right: 0px;}
.mascot_p4 {width: 120px; height: auto; margin: 30px auto 0;}
.mascot_p5 {width: 100px; height: auto; margin: 30px auto 50px;}
@media screen and (min-width: 899px){
.mascot_p1 {width: 160px;}
.mascot_f1 {width: 160px;}
.mascot_p3 {width: 130px; bottom: -70px;}
} .photo_name{line-height: 1.3;}
@media screen and (min-width: 899px) {
.blog_column_ver2 {display: flex; flex-wrap: wrap; align-items: center;}
.blog_column_ver2_l {width: 55%; margin-right: 5%;}
.blog_column_ver2_r {width: 40%; line-height: 1.3;}
.blog_column_cap {}
}
.origination_contents_en22 {padding: 20px 30px; width: 100%; border-bottom: 0.25px solid #aaaaaa;}
.origination_contents_en_tit22 {font-weight: 700; font-size: 0.95rem; color: #448538; margin-bottom: 10px;}
.origination_contents_en_num22 {font-weight: 700; font-size: 0.95rem; line-height: 1.6; color: #448538;}
.origination_contents_en_num22 span {font-family: 'Barlow', sans-serif; font-weight: 500; font-size: 1.8rem; padding-right: 3px; line-height: 1;}
.origination_listtable { color: #448538; background: #f5f5f5; font-weight: 700; text-align: center;}
.origination_listtable table {width: 100%; font-size: 0.9rem;}
.origination_listtable tr:nth-child(odd) td { background: #eee;}
.origination_listtable_y {width: 35%;}
.origination_listtable_n {width: 65%; color: #448038; padding: 5px; vertical-align: baseline;}
.origination_listtable_n span {font-size: 1.4rem !important;}
.origination_listtable tr:nth-child(odd) td {background: #eee;}
.origination_listtable td { border-right: 1px solid #448038;}
.origination_listtable td:last-child { border-right: none;} .top2025 {width: 100%; margin-bottom: 30px}
.top2025_img {width: 100%; margin: 0 auto; filter: drop-shadow(5px 5px 5px #dddddd); }
.top2025_imgtext {width: 100%; margin: 10px auto 0;}
.top2025_left h2 {font-size: 1rem !important;}
.top2025_left p {font-size: 1rem !important; font-feature-settings: "palt"; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600; }
.top_2025_mo {font-size: 1rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #ec6f1a; line-height: 1;}
.cycle_top {background: #FFF; width: 100%; border-radius: 10px; text-align: center; padding: 25px 0; filter: drop-shadow(5px 5px 5px #dddddd);}
.cycle_tit_top2025 {font-size: 0.95rem !important; font-weight: 700; letter-spacing: 0.1em !important; color: #4D4D4D; padding-bottom: 10px;}
.cycle_top p {margin: 0;}
.cycle_txt2025 {font-weight: 900; color: #ec6f1a; font-size: 2.275rem !important; font-family: 'Barlow', sans-serif; letter-spacing: 0.05em !important; line-height: 1.4; vertical-align: text-bottom; color: #ec6f1a;}
.cycle_txt_en2025 { font-size: 1.275rem !important; letter-spacing: 0; padding: 5px; vertical-align: baseline; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600; }
.cycle_txt_small2025 { font-size: 1rem !important; letter-spacing: 0; padding: 5px; vertical-align: middle; font-family: "dnp-shuei-gothic-kin-std", sans-serif; font-weight: 600;}
.txt_orange{color: #ec6f1a !important;}
@media screen and (min-width: 899px) {
.top2025 {display: flex; flex-wrap: wrap; align-items: center; margin-bottom: 80px;}
.top2025_left {width: 60%; margin-right: 2%;}
.top2025_left h2 {font-size: 1.275rem !important;}
.top2025_right {width: 38%;}
.top2025_left p {font-size: 1.275rem !important; line-height: 2.2; }
.top2025_img {width: 75%; margin: 0 auto;}
.top2025_imgtext {width: 75%; margin: 20px auto 0;}
}
.blend-multiply {
mix-blend-mode: multiply;
} .eyeglass_project {color: #083359;}
.project_hero { padding: 60px 0; background: #f7f7f5; }
.project_hero-inner { max-width: 1240px; margin: 0 auto; padding: 0 20px; display: flex; flex-wrap: wrap; align-items: center; gap: 80px; } .project_hero-left { flex: 1 1 320px; } .project_hero-right { flex: 1 1 400px; } .project_hero-photo { position: relative; border-radius: 6px; overflow: hidden; aspect-ratio: 16 / 9; background: #ddd; } .project_hero-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.8s ease-in-out; }
.project_hero-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.project_hero-slide.is-active { opacity: 1; } .project_hero-footer { margin: 4px 4px 0; font-size: 0.85rem; color: #12406a; text-align: right; }
.about_text_box {padding: 0 30px;}
.about_text_box p {color: #083359;}
.about_text_box .report_marker {color: #083359 !important;} .sbb_page_bg_project { position: relative; padding: 100px 0 100px; margin: 0 auto; color: #083359 !important; }
.sbb_page_bg_project h2 { font-size: 1.3rem; line-height: 1.7; color: #083359; margin-bottom: 60px; }
.sbb_page_bg_project p { font-size: 1rem; line-height: 1.9; text-align: justify; }
.sbb_page_bg_project p span { color: #448538; }
.sbb_page_icon_img {width: 120px; height: auto; margin: 0 auto;}
@media screen and (min-width: 899px) {
.sbb_page_bg_project h2 { font-size: 1.8rem; line-height: 1.7; color: #083359; margin-bottom: 60px; }
.sbb_page_bg_project p { font-size: 1.125rem !important; line-height: 1.9; text-align: justify; }
} .project_role { text-align: center; margin-top: 80px; margin-bottom: 80px; }
.project_role dl { padding: 32px 28px 40px; border-radius: 8px; position: relative; margin: 0 auto 50px; text-align: center; width: 90%; max-width: 800px; }
.project_role dl dt { display: inline-block; color: #fff; font-weight: bold; padding: 6px 18px; border-radius: 6px; position: absolute; top: -16px; left: 50%; transform: translateX(-50%); white-space: nowrap; }
.project_role dl dd { margin: 24px 0 0; line-height: 1.8; }
.project_role-1 { background: #fffbe8; }
.project_role-1 dt { background: #e67341; }
.project_role-2 { background: #e6f3ff; }
.project_role-2 dt { background: #113b67; }
.project_role-3 { background: #ffe5e8; }
.project_role-3 dt { background: #ef8c99; }
.project_role-4 { background: #dff8ea; }
.project_role-4 dt { background: #18915b; }
.project_role .report_marker {color: #083359 !important;}
.gaiyou {max-width: 800px; height: auto; margin: 0 auto;} .project_area { padding: 40px 0; }
.project_area-tabs { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; margin-bottom: 50px; }
.project_area-tab { border: none; padding: 8px 24px; border-radius: 999px; background: #e4e4e4; color: #333; cursor: pointer; transition: background 0.2s, color 0.2s; font-size: 0.95rem; }
.project_area-tab.is-active { background: #12406a; color: #fff; }
.project_area-list { max-width: 1120px; margin: 0 auto; padding: 0 20px; display: grid; gap: 40px; }
@media (min-width: 900px) {
.project_area-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
} .project_card { background: #fff; border-radius: 10px; position: relative; box-shadow: 0 4px 10px rgba(0,0,0,0.04); } .project_card-thumb { margin: 0; border-radius: 10px 10px 0 0; overflow: hidden; aspect-ratio: 16 / 9; }
.project_card-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; } .project_card-badge { position: absolute; top: 12px; left: 12px; width: 14px; height: 14px; background: #e53935; border-radius: 50%; z-index: 5; }
.project_card-body { padding: 40px; }
.project_card-meta { margin: 0 0 16px; padding: 0; } .project_card-row { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 6px; font-size: 0.9rem !important; }
.project_card-row dt { flex: 0 0 auto; min-width: 64px; padding: 4px 14px; border-radius: 999px; background: #ffff66; text-align: center; line-height: 1.8; }
.project_card-row dd { margin: 4px 0 0; line-height: 1.8; } .project_card-body .project_card-link { margin: 0; font-size: 0.8rem !important; text-align: right !important; }
.project_card-link a { color: #12406a; text-decoration: underline; } .project_area-list.show-limit .project_card:nth-of-type(n+5) {
display: none;
} .project_area-more {
text-align: center;
margin: 60px auto 0;
}
.project_area-more-btn {
display: inline-block;
padding: 10px 28px;
border-radius: 999px;
border: 1px solid #ccc;
background: #fff;
font-size: 14px;
cursor: pointer;
transition: background 0.2s;
margin: 0 auto;
}
.project_area-more-btn:hover {
background: #f7f7f7;
} .voice_area { padding: 40px 0; }
.voice_list { max-width: 1120px; margin: 0 auto; padding: 40px 20px 20px; display: grid; gap: 40px; }
@media (min-width: 900px) {
.voice_list { grid-template-columns: repeat(2, 1fr); }
} .voice_card { background: #fffbe8; padding: 24px; border-radius: 14px; position: relative; box-shadow: 0 4px 10px rgba(0,0,0,0.05); } .voice_card-label { display: inline-block; background: #e67341; color: #fff; padding: 6px 16px; border-radius: 6px; font-weight: bold; position: absolute; top: -14px; left: 20px; font-size: 0.95rem; white-space: nowrap; } .voice_card-thumb { margin: 30px 0 20px; border-radius: 5px; overflow: hidden; aspect-ratio: 16 / 9; }
.voice_card-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; } .voice_list .voice_card-body p { font-size: 1rem !important; line-height: 1.9; color: #083359; } .voice_marker { background: linear-gradient(transparent 60%, #fff79a 60%); font-weight: bold; color: #083359 !important; } .media_title { max-width: 800px; margin: 0 auto 32px; padding: 0 20px; text-align: center !important; font-weight: bold; color: #12406a !important; }
.media_list { max-width: 800px; margin: 0 auto; padding: 40px 20px 60px; display: grid; gap: 24px; }
.media_item { border: 2px solid #083359; border-radius: 10px; padding: 50px; background: #fff; }
.media_item-title { margin: 0 0 12px; font-size: 1.05rem; font-weight: bold; }
.sbb_page_bg_project .media_item-text { margin: 0 0 16px; font-size: 0.9rem !important; line-height: 1.9; color: #083359; }
.sbb_page_bg_project .media_item-link { margin: 0; font-size: 0.9rem !important; }
.sbb_page_bg_project .media_item-link a { color: #12406a; text-decoration: underline; font-size: 0.9rem !important; } .media_item-thumb { margin: 12px 0; border-radius: 8px; overflow: hidden; }
.media_item-thumb img { display: block; width: 100%; height: auto; }
.content_90_pdbm {padding-bottom: 50px;} @media (max-width: 768px) { .project_hero { padding: 32px 0; }
.project_area, .voice_area { padding: 32px 0; } .project_hero-inner { flex-direction: column; align-items: center; gap: 24px; }
.project_hero-left { text-align: center; }
.project_hero-left {flex: 1 1 auto; text-align: center; margin-top: 30px;}
.project_hero-left img {width: 90%; height:  auto;}
.project_hero-right { width: 100%; flex: 1 1 auto;}
.project_hero-photo { border-radius: 10px; }
.project_hero-footer { margin-top: 8px; font-size: 0.9rem; text-align: right; }
.gaiyou {padding: 0 10px;} .project_area-tabs { padding: 0 20px; gap: 16px; }
.project_area-tab { padding: 6px 14px; font-size: 0.85rem; } .project_area-list { padding: 0 20px; gap: 24px; }
.project_card { border-radius: 10px; }
.project_card-body { padding: 20px; }
.project_card-row { flex-direction: column; align-items: flex-start; gap: 2px; font-size: 0.95rem !important; }
.project_card-row dt { min-width: auto; padding: 2px 10px; font-size: 0.8rem; }
.project_card-row dd { margin-top: 0; font-size: 0.9rem; line-height: 1.7; padding-left: 10px; }
.project_card-body .project_card-link { font-size: 0.75rem !important; } .voice_list { padding: 0 20px; gap: 24px; grid-template-columns: 1fr; }
.voice_card { padding: 20px; border-radius: 12px; margin-bottom: 30px; }
.voice_card-label { left: 16px; font-size: 0.85rem; }
.voice_card-body { font-size: 0.9rem; line-height: 1.8; } .media_title { margin-bottom: 24px; padding: 0 16px; }
.media_list { padding: 0 20px; gap: 20px; }
.media_item { padding: 20px; }
.media_item-title { font-size: 1rem; }
.media_item-text { font-size: 0.9rem; }
.media_item-link { font-size: 0.8rem; } .project_role dl { margin: 0 16px 48px; }
.sbb_page_bg_project {padding: 50px 0 50px;}
.sbb_page_icon_img {width: 80px;}
.about_text_box_center p {text-align: center !important;}
}
.roles-grid {
display: grid;
gap: 28px;
max-width: 900px;
margin: 40px auto 40px;
} @media (min-width: 768px) {
.roles-grid {
grid-template-columns: repeat(4, 1fr);
}
} @media (max-width: 767px) {
.roles-grid {
grid-template-columns: repeat(2, 1fr);
}
}
.role-img {
width: 100%;
height: auto;
display: block;
}
#eyeglass-top { position: relative;}
#index_top .index_img, #eyeglass-top .index_img { position: relative;}
.index_img {height: auto !important;}
#eyeglass-top .index_img::after { content: ""; position: absolute; inset: 0; background: rgba(0, 0, 0, 0.14); z-index: 2; pointer-events: none;}
.hero-logo-wrapper { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 3; background: rgba(255, 255, 255, 0.7); box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18); text-align: center; padding: 40px 40px 0 60px; border-radius: 12px;}
.eyeglass-logo img { width: min(580px, 80vw); height: auto;}
.project_img-radius img {border-radius: 10px} @media (max-width: 1200px) {
.eyeglass-logo img { width: min(500px, 80vw); height: auto;}
} @media (max-width: 768px) {
.hero-logo-wrapper { width: 80%; padding: 25px 10px 0 25px; border-radius: 6px;}
}
.supporter-list { max-width: 900px; margin: 0 auto 60px;}
.supporter-item { display: flex; align-items: center; gap: 16px; padding: 30px 0; border-bottom: 1px solid #eee;}
.supporter-item:last-child {　border-bottom: none;}
.supporter-photo img { width: 72px;　height: 72px;　border-radius: 50%; object-fit: cover;}
.supporter-text { flex: 1;}
.supporter-name { margin-bottom: 4px; font-weight: bold;}
.supporter-comment { margin: 0; line-height: 1.7;}
@media (max-width: 768px) {
.supporter-item { align-items: flex-start; width: 90%; margin: 0 auto;}
.supporter-photo img { width: 60px; height: 60px;}
.supporter-item { gap: 12px; }
}
.npo-voices-wrap {max-width: 900px; margin: 0 auto;}
.section-npo-voices { padding: 80px 0; background: #fffdf6;}
.npo-voices-lead {text-align: center !important; margin-bottom: 60px;}
.section-npo-voices .section-inner {
max-width: 1040px;
margin: 0 auto;
padding: 0 16px;
}
.section-npo-voices .section-title {
text-align: center;
font-size: 26px;
font-weight: 700;
margin-bottom: 12px;
}
.section-npo-voices .section-lead {
text-align: center !important;
line-height: 1.8;
margin-bottom: 32px;
} .npo-scroll {
display: flex;
gap: 24px;
overflow-x: auto;
padding: 8px 4px 12px;
scroll-snap-type: x mandatory;
-webkit-overflow-scrolling: touch;
} .npo-scroll::-webkit-scrollbar {
height: 6px;
}
.npo-scroll::-webkit-scrollbar-track {
background: transparent;
}
.npo-scroll::-webkit-scrollbar-thumb {
background: #ddd;
border-radius: 999px;
} .npo-card {
flex: 0 0 260px; background: #ffffff;
border-radius: 16px;
padding: 20px 18px 22px;
box-shadow: 0 4px 12px rgba(0,0,0,0.04);
scroll-snap-align: start;
}
.npo-icon {
width: 64px;
height: 64px;
border-radius: 50%;
margin: 0 auto 10px;
display: flex;
align-items: center;
justify-content: center;
font-size: 14px;
font-weight: 600;
} .npo-card--fukuoka  .npo-icon { background: #ffe0e0; }
.npo-card--kyoto    .npo-icon { background: #e0f1ff; }
.npo-card--hyogo    .npo-icon { background: #e4f6e6; }
.npo-card--hiroshima .npo-icon { background: #f3e8ff; }
.npo-card--kagawa   .npo-icon { background: #fff0d9; }
.npo-title {
text-align: center;
font-size: 14px;
font-weight: 700;
margin-bottom: 10px;
}
.npo-card p {
font-size: 0.9rem !important;
}
@media (min-width: 768px) {
.npo-card {
flex: 0 0 300px;
}
} @media (min-width: 1024px) {
.npo-scroll {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
overflow-x: visible; } .npo-card.is-hidden-pc {
display: none;
} .npo-scroll.is-open .npo-card.is-hidden-pc {
display: block;
}
.npo-more-wrap {
text-align: center;
margin-top: 24px;
}
.npo-more-btn {
display: inline-block;
padding: 10px 28px;
border-radius: 999px;
border: 1px solid #ccc;
background: #fff;
font-size: 14px;
cursor: pointer;
transition: background 0.2s;
}
.npo-more-btn:hover {
background: #f7f7f7;
}
} @media (max-width: 1023px) {
.npo-more-wrap {
display: none;
}
}
@media (max-width: 768px) {
.npo-voices-wrap {width: 90%; margin: 0 auto;}
}