@charset "utf-8";

/** ▼▼▼ main ▼▼▼ **/
.main {
    position: relative;
    width: 245px;
    height: 515px;
    margin: 0 auto;
    padding: 85px 0 0 755px;
    background: url(../images/img_main.png) no-repeat;
    border-radius: 15px;
}

h2.vision {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
}

h2.vision span {
    font-size: 1.87em;
    font-family: marugo_r;
    font-weight: 100;
    line-height: 150%;
    letter-spacing: 0.05em;
    text-align: left;
    color: #333333;
    text-shadow: 0 3px 6px rgba(0,0,0,0.16);
}

.main div {
    position: absolute;
    left: 0;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
    width: 430px;
    height: 125px;
    padding: 0 0 0 10px;
    color: #DC3E5B;
    border-radius: 0 10px 10px 0;
    background: rgba(255, 255, 255, 0.7);
}

.main div h4 {
    margin: 5px 0 0 0;
    font-family: marugo_r;
    font-size: 1.87em;
    font-weight: 700;
}

.main div p {
    margin: 10px 0 0 0;
    font-weight: 600;
}

.main div p span {
    font-size: 1.25em;
    font-weight: 700;
}

.main div a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 150px;
    height: 28px;
    margin: 5px 0 0 0;
    font-size: 1.12em;
    font-weight: 700;
    text-decoration: none;
    color: #DC3E5B;
    border: 1px solid #DC3E5B;
    border-radius: 15px;
    background: #FFFFFF;
}
/** ▲▲▲ main ▲▲▲ **/

/** ▼▼▼ about ▼▼▼ **/
.about {
    margin: 100px auto 0 auto;
}

.about ul {
    width: 1000px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    list-style: none;
}

.about .text {
    width: 310px;
}

.about .text p {
    margin: 30px 0 0 0;
}

.about .content {
    width: 650px;
}

.about .content ul {
    width: 650px;
    display: flex;
    justify-content: space-between;
    list-style: none;
}

.about .content ul li {
    width: 205px;
}

.about .content ul li h4 {
    margin: 20px 0 0 0;
    font-size: 1.56em;
    font-family: marugo_r;
    text-align: center;
}

.about .content ul li p {
    margin: 20px 0 0 0;
}
/** ▲▲▲ about ▲▲▲ **/

/** ▼▼▼ works ▼▼▼ **/
.works {
    margin: 100px 0 0 0;
    padding: 100px 0;
    background: #E8D7D1;
}

.works h2 {
    width: 1000px;
    margin: 0 auto;
}

.works h3 {
    width: 1000px;
    margin: 60px auto 0 auto;
    font-size: 1.88em;
    line-height: 130%;
}

.works p {
    width: 1000px;
    margin: 30px auto 0 auto;
}

.area {
  width: 1000px;
  margin: 50px auto 0 auto;
  overflow: hidden;
}

/**.wrap {
  display: flex;
}**/

.item {
    display: block;
    /**justify-content: flex-end;
    align-items: center;**/
    height: 400px;
    padding: 161px 0;
}

.item01 {
    background: url(../images/img_item01.png) no-repeat 0 0 / cover;
    border-radius: 15px;
}
  
.item02 {
    background: url(../images/img_item02.png) no-repeat 0 0 / cover;
    border-radius: 15px;
}

.item03 {
    background: url(../images/img_item03.png) no-repeat 0 0 / cover;
    border-radius: 15px;
}

.item04 {
    background: url(../images/img_item04.png) no-repeat 0 0 / cover;
    border-radius: 15px;
}

.works .item h4 {
    display: inline-block;
    position: relative;
    left: 780px;
    width: 200px;
    padding: 15px 0 15px 20px;
    background: rgba(255,255,255,0.7);
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
    font-size: 12px;
    font-family: marugo_b;
    color: #DC3E5B;
}

.works .item h4 span {
    display: block;
    font-size: 25px;
    font-family: marugo_r;
    color: #333333;
    margin: 0;
}

@media(min-width:641px){
    .sp{
        display: none !important;
    }
}
@media(max-width:640px){
    .pc{
        display: none !important;
    }
}
/** ▲▲▲ works ▲▲▲ **/

/** ▼▼▼ company ▼▼▼ **/
.company {
    margin: 100px 0 0 0;
}

.company h2 {
    text-align: center;
}

.company h3 {
    width: 770px;
    height: 320px;
    margin: 50px auto 0 auto;
    padding: 30px 30px 0 0;
    display: flex;
    justify-content: flex-end;
    background: url(../images/img_company.png) no-repeat 0 0 / cover;
    border-radius: 15px;
    line-height: 130%;
    text-shadow: 0 3px 6px rgba(0,0,0,0.16);
}

.company p {
    width: 800px;
    margin: 50px auto 0 auto;
}

.company ul {
    width: 800px;
    margin: 50px auto 0 auto;
    display: flex;
    flex-wrap: wrap;
    border-top: #CCCCCC 1px solid;
    list-style: none;
}

.company ul li {
    padding: 25px 0;
    border-bottom: 1px solid #CCCCCC;
}

.company ul li.heading {
    width: 200px;
    font-weight: 600;
    color: #666666;
}

.company ul li.content {
    width: 600px;
}

.company div {
    width: 800px;
    height: 500px;
    margin: 50px auto 0 auto;
}
/** ▲▲▲ company ▲▲▲ **/

/** ▼▼▼ contact ▼▼▼ **/
.contact {
    margin: 100px 0 0 0;
    padding: 100px 0;
    background: #E8D7D1;
}

.contact h2 {
    text-align: center;
}

.contact h3 {
    text-align: center;
}

.contact p {
    text-align: center;
    margin: 50px 0 0 0;
    padding: 0 0 25px 0;
}

.contact ul {
    width: 800px;
    margin: 25px auto 0 auto;
    display: flex;
    list-style: none;
}

.contact ul li.headline {
    width: 200px;
    padding: 12px 0 0 0;
}

.contact ul li.headline::after {
    content: "[必須]";
    margin: 0 0 0 10px;
    color: #EF2858;
}

.contact ul li.input {
    width: 600px;
}

.contact ul li input {
    width: 580px;
    height: 50px;
    padding: 0 10px;
    border: 1px solid #CCCCCC;
    border-radius: 10px;
    font-size: 1em;
    font-weight: 300;
    font-family: marugo_r;
    color: #333333;
}

.contact ul li textarea {
    width: 580px;
    height: 180px;
    padding: 10px;
    border: 1px solid #CCCCCC;
    border-radius: 10px;
    resize: none;
    font-size: 1em;
    font-weight: 300;
    font-family: marugo_r;
    color: #333333;
}

.contact .send {
    margin: 50px 0 0 0;
    text-align: center;
}

.button {
    width: 250px;
    height: 50px;
    background: #DC3E5B;
    border: 0;
    border-radius: 10px;
    font-weight: 700;
    color: #FFFFFF;
}

.error {
    color: #FF0000;
}

/** 確認 **/
.confirm {
    width: 800px;
    margin: 100px auto;
    padding: 0;
}

.confirm p {
    width: 560px;
    margin: 50px 0 0 0;
}

.confirm ul {
    width: 800px;
    margin: 50px auto 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
    list-style: none;
}

.confirm .headline {
    width: 200px;
}

.confirm .input {
    width: 600px;
    border-bottom: 1px solid #CCCCCC;
    font-size: 1.2em;
    font-family: marugo_r;
}

.confirm .submit {
    width: 550px;
    margin: 100px auto 0 auto;
    display: flex;
    justify-content: space-between;
}

.button_02 {
    width: 250px;
    height: 50px;
    border: 1px solid #DC3E5B;
    border-radius: 10px;
    background: #FFFFFF;
    font-size: 0.93em;
    font-weight: 700;
    color: #DC3E5B;
}
/** //確認 **/

.contact .form-mailer {
    width: 90%;
    margin: 0 auto;
}
/** ▲▲▲ contact ▲▲▲ **/

@media (max-width: 640px) {
    /** ▼▼▼ main ▼▼▼ **/
    .main {
        position: relative;
        width: 100%;
        background: url(../images/img_main.png) no-repeat center center / cover;
        border-radius: 0;
        padding: 100px 0 0 0;
        display: flex;
        justify-content: flex-end;
        height: 420px;
        /**margin: 0 auto;**/
    }

    h2.vision {
        margin: 0 30px 0 0;
        /**-ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;**/
    }
    
    h2.vision span {
        display: inline;
        margin-right: 25px;
        font-size: 1.6em;
        text-shadow: 2px 2px 6px rgba(255,255,255,0.6);
        /**background: rgba(255,255,255,0.4);**/
        /**font-family: marugo_r;
        font-weight: 100;
        line-height: 150%;
        letter-spacing: 0.05em;
        text-align: left;
        color: #333333;**/
    }

    .main div {
        /**position: absolute;
        left: 0;**/
        bottom: -50px;
        /**display: flex;
        align-items: flex-start;
        justify-content: center;
        flex-direction: column;**/
        width: 75%;
        height: initial;
        padding: 10px 0 10px 10px;
        box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
        /**color: #DC3E5B;
        border-radius: 0 10px 10px 0;
        background: rgba(255, 255, 255, 0.7);**/
    }
    
    .main div h4 {
        font-size: 1.7em;
        /**margin: 5px 0 0 0;
        font-family: marugo_r;
        font-weight: 700;**/
    }
    
    /**.main div p {
        margin: 10px 0 0 0;
        font-weight: 600;
    }**/
    
    /**.main div p span {
        font-size: 1.25em;
        font-weight: 700;
    }**/
    
    /**.main div a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 150px;
        height: 28px;
        margin: 5px 0 0 0;
        font-size: 1.12em;
        font-weight: 700;
        text-decoration: none;
        color: #DC3E5B;
        border: 1px solid #DC3E5B;
        border-radius: 15px;
        background: #FFFFFF;
    }**/
    /** ▲▲▲ main ▲▲▲ **/

    /** ▼▼▼ about ▼▼▼ **/
    /**.about {
        margin: 100px auto 0 auto;
    }**/
    
    .about ul {
        width: 90%;
        flex-wrap: wrap;
        /**margin: 0 auto;
        display: flex;
        justify-content: space-between;
        list-style: none;**/
    }
    
    .about .text {
        width: 100%;
    }
    
    /**.about .text p {
        margin: 30px 0 0 0;
    }**/
    
    .about .content {
        width: 100%;
    }
    
    .about .content ul {
        width: 100%;
        flex-wrap: wrap;
        /**display: flex;
        justify-content: space-between;
        list-style: none;**/
    }
    
    .about .content ul li {
        width: 100%;
        margin: 50px 0 0 0;
        text-align: center;
    }
    
    /**.about .content ul li h4 {
        margin: 20px 0 0 0;
        font-size: 1.56em;
        font-family: marugo_r;
        text-align: center;
    }**/
    
    .about .content ul li p {
        text-align: left;
        /**margin: 20px 0 0 0;**/
    }
    /** ▲▲▲ about ▲▲▲ **/

    /** ▼▼▼ works ▼▼▼ **/
    /**.works {
        margin: 100px 0 0 0;
        padding: 100px 0;
        background: #E8D7D1;
    }**/
    
    .works h2 {
        width: 90%;
        /**margin: 0 auto;**/
    }
    
    .works h3 {
        width: 90%;
        font-size: 1.5em;
        line-height: 150%
        /**margin: 60px auto 0 auto;;**/
    }
    
    .works p {
        width: 90%;
        /**margin: 30px auto 0 auto;**/
    }
    
    .area {
      width: 90%;
      /**margin: 50px auto 0 auto;
      overflow: hidden;**/
    }
    
    /**.wrap {
      display: flex;
    }
    
    .item {
      height: 400px;
      display: flex;
      justify-content: flex-end;
      align-items: center;
    }**/
    
    .item01 {
        background: url(../images/img_item01.png) no-repeat -215px 0 / cover;
        /**border-radius: 15px;**/
    }
      
    .item02 {
        background: url(../images/img_item02.png) no-repeat -240px 0 / cover;
        /**border-radius: 15px;**/
    }
    
    .item03 {
        background: url(../images/img_item03.png) no-repeat -440px 0 / cover;
        /**border-radius: 15px;**/
    }
    
    .item04 {
        background: url(../images/img_item04.png) no-repeat -440px 0 / cover;
        /**border-radius: 15px;**/
    }
    
    .works .item h4 {
        left: 37.3%;
        /**width: 200px;
        padding: 15px 0 15px 20px;
        background: rgba(255,255,255,0.7);
        border-top-left-radius: 15px;
        border-bottom-left-radius: 15px;
        font-size: 12px;
        font-family: marugo_b;
        color: #DC3E5B;**/
    }


/**.works .item h4 {
    display: inline-block;
    position: relative;
    left: 780px;
    width: 200px;
    padding: 15px 0 15px 20px;
    background: rgba(255,255,255,0.7);
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
    font-size: 12px;
    font-family: marugo_b;
    color: #DC3E5B;
}**/


    
    /**.works .item h4 span {
        display: block;
        font-size: 25px;
        font-family: marugo_r;
        color: #333333;
        margin: 0;
    }**/
    /** ▲▲▲ works ▲▲▲ **/

    /** ▼▼▼ company ▼▼▼ **/
    /**.company {
        margin: 100px 0 0 0;
    }**/
    
    /**.company h2 {
        text-align: center;
    }**/
    
    .company h3 {
        width: 90%;
        background: url(../images/img_company.png) no-repeat right center / cover;
        padding: 30px 15px 0 0;
        font-size: 1.5em;
        /**height: 320px;
        margin: 50px auto 0 auto;
        display: flex;
        justify-content: flex-end;
        border-radius: 15px;
        line-height: 130%;
        text-shadow: 0 3px 6px rgba(0,0,0,0.16);**/
    }
    
    .company p {
        width: 90%;
        /**margin: 50px auto 0 auto;**/
    }
    
    .company ul {
        width: 90%;
        /**margin: 50px auto 0 auto;
        display: flex;
        flex-wrap: wrap;
        border-top: #CCCCCC 1px solid;
        list-style: none;**/
    }
    
    /**.company ul li {
        padding: 25px 0;
        border-bottom: 1px solid #CCCCCC;
    }**/
    
    .company ul li.heading {
        width: 40%;
        /**font-weight: 600;
        color: #666666;**/
    }
    
    .company ul li.content {
        width: 60%;
    }
    
    .company div {
        width: 90%;
        /**height: 500px;
        margin: 50px auto 0 auto;**/
    }
    /** ▲▲▲ company ▲▲▲ **/

    /** ▼▼▼ contact ▼▼▼ **/
    /**.contact {
        margin: 100px 0 0 0;
        padding: 100px 0;
        background: #E8D7D1;
    }**/
    
    /**.contact h2 {
        text-align: center;
    }**/
    
    .contact h3 {
        width: 85%;
        margin: 40px auto 0 auto;
        /**text-align: center;**/
    }
    
    .contact p {
        width: 90%;
        margin: 50px auto 0 auto;
        /**text-align: center;
        padding: 0 0 25px 0;**/
    }
    
    .contact ul {
        width: 90%;
        flex-wrap: wrap;
        /**margin: 25px auto 0 auto;
        display: flex;
        list-style: none;**/
    }
    
    .contact ul li.headline {
        width: 100%;
        padding: 0;
    }
    
    /**.contact ul li.headline::after {
        content: "[必須]";
        margin: 0 0 0 10px;
        color: #EF2858;
    }**/
    
    .contact ul li.input {
        width: 100%;
    }
    
    .contact ul li input {
        width: 94%;
        /**height: 50px;
        padding: 0 10px;
        border: 1px solid #CCCCCC;
        border-radius: 10px;
        font-size: 1em;
        font-weight: 300;
        font-family: marugo_r;
        color: #333333;**/
    }
    
    .contact ul li textarea {
        width: 94%;
        /**height: 180px;
        padding: 10px;
        border: 1px solid #CCCCCC;
        border-radius: 10px;
        resize: none;
        font-size: 1em;
        font-weight: 300;
        font-family: marugo_r;
        color: #333333;**/
    }
    
    /**.contact .send {
        margin: 50px 0 0 0;
        text-align: center;
    }**/
    
    /**.button {
        width: 250px;
        height: 50px;
        background: #DC3E5B;
        border: 0;
        border-radius: 10px;
        font-weight: 700;
        color: #FFFFFF;
    }**/
    
    /**.error {
        color: #FF0000;
    }**/
    
    /** 確認 **/
    .confirm {
        width: 90%;
        /**margin: 100px auto;
        padding: 0;**/
    }
    
    .confirm p {
        width: 100%;
        /**margin: 50px 0 0 0;**/
    }
    
    .confirm ul {
        width: 100%;
        flex-wrap: wrap;
        /**margin: 50px auto 0 auto;
        padding: 0;
        display: flex;
        justify-content: space-between;
        list-style: none;**/
    }
    
    .confirm .headline {
        width: 100%;
    }
    
    .confirm .input {
        width: 100%;
        margin: 10px 0 0 0;
        /**border-bottom: 1px solid #CCCCCC;
        font-size: 1.2em;
        font-family: marugo_r;**/
    }
    
    .confirm .submit {
        width: 90%;
        /**margin: 100px auto 0 auto;
        display: flex;
        justify-content: space-between;**/
    }

    .button {
        width: 150px;
        font-size: 0.93em;
        /**height: 50px;
        background: #DC3E5B;
        border: 0;
        border-radius: 10px;
        font-weight: 700;
        color: #FFFFFF;**/
    }
    
    .button_02 {
        width: 150px;
        /**height: 50px;
        border: 1px solid #DC3E5B;
        border-radius: 10px;
        background: #FFFFFF;
        font-size: 0.93em;
        font-weight: 700;
        color: #DC3E5B;**/
    }
    /** //確認 **/
    /** ▲▲▲ contact ▲▲▲ **/
}