@charset "utf-8";

/*---------------------------------------------------------
    Theme Name: simple-hoiku
    Description: シンプル保育
    Theme URI: https://hoikushi-tenshoku.info/
---------------------------------------------------------*/

/****************************************

    /* CSS Reset

*****************************************/

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

body {
    line-height: 1;
}

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

blockquote, q {
    quotes: none;
}

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

a {
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    margin: 0;
    padding: 0;
}

ins {
    color: #000;
    text-decoration: none;
    background-color: #ff9;
}

mark {
    color: #000;
    font-style: italic;
    font-weight: bold;
    background-color: #ff9;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom: 1px dotted;
    cursor: help;
}

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

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

input, select, textarea, img, th, td {
    vertical-align: middle;
}

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

/****************************************

    /* 共通設定

*****************************************/

* {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-appearance: none;
            appearance: none;
}

body {
    font-family: 'Noto Sans Japanese', Meiryo, sans-serif;
    font-size: 3.8vw;
    font-weight: 500;
    color: #444;
    line-height: 1.8;
    background: #fff;
    -webkit-text-size-adjust: 100%;
}

@media screen and (min-width: 1090px) {

    html {
        background: #fbeded;
        background-image: radial-gradient(#fff 20%, transparent 0), radial-gradient(#fff 20%, transparent 0);
        background-position: 0 0, 5px 5px;
        background-size: 10px 10px;
    }

    body {
        font-size: 24px;
        max-width: 1090px;
        margin: 0 auto;
        padding: 0 40px;
        box-shadow: 0 0 40px rgba(210,40,80,.2);
    }

}

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

    body {
        max-width: auto;
        margin: 0 auto;
        padding: 0 10px;
    }

}

h1, h2, h3, h4, h5, h6, th {
    font-weight: normal;
}

a {
    color: #333;
    text-decoration: underline;
    transition-duration: .3s;
}

a:hover {
    text-decoration: none;
    transition-duration: .3s;
}

a:hover img {
    -moz-opacity: .5;
    opacity: .5;
    transition-duration: .3s;
}

img, video, object {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
    border: none;
    transition-duration: .3s;
}

table {
    table-layout:fixed;
}

table th,
table td {
    vertical-align: middle;
}

/****************************************

    /*

*****************************************/

.sp {
    display: none;
}

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

.pc {
    display: none;
}

.sp {
    display: block;
}

}

/****************************************

    /*

*****************************************/


h2 {
    font-size: 46px;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0;
    font-family: 'Zen Maru Gothic', sans-serif;
    margin: 0 0 .5em;
}

h2 span {
    color: #f06072;
}

.tx-ul {
    font-weight: 600;
    background:linear-gradient(transparent 70%, #ff5 0%);
}

.tx-pink {
    color: #f06072;
}

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

h2 {
    font-size: 6vw;
}

}

/****************************************

    /*

*****************************************/

.manga {
    padding: 20px 0;
}

.manga > img {
    display: block;
    border: 5px solid;
    margin: 20px 0;
}

.manga p {
    color: #888;
    font-size: 10px;
    text-align: right;
    margin: -10px 0;
}

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

.manga {
    padding: 10px 0;
}

.manga > img {
    display: block;
    border: 4px solid;
    margin: 10px 0;
}

.manga p {
    color: #888;
    font-size: 10px;
    text-align: right;
    margin: -5px 0;
}

}

/****************************************

    /*

*****************************************/

.cta {
    text-align: center;
    margin: 40px 0;
    padding: 10px 0;
}

.cta a img {
    animation-name: anime;
    animation-delay: 0s;
    animation-duration: 2s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
}

@keyframes anime {
    0% {transform: scale(1);}
    40% {transform: scale(1);}
    50% {transform: scale(1.06);}
    60% {transform: scale(1);}
    100% {transform: scale(1);}
}

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

.cta {
    margin: 20px 0;
}

}

/****************************************

    /*

*****************************************/

.talk {
    margin: 40px 0;
}

.talk dl {
    width: 80%;
    margin: 0 auto;
}

.talk dl dt,
.talk dl dd {
    padding: 1em;
    min-height: 100px;
}

.talk dl dt {
    color: #9b4a3e;
    text-align: right;
    background: url(/wp-content/uploads/2022/06/talk-icon_02_nurse.png) no-repeat right center;
    background-size: 100px;
    padding: 1em 130px 1em 1em;
}

.talk dl dt span {
    display: inline-block;
    background: #fff2f3;
    padding: .5em 2em;
    border-radius: 10px;
    position: relative;
}

.talk dl dt.point span {
    color: #fff;
    background: #9b4a3e;
}

.talk dl dt.point span strong {
    color: #ff0;
}

.talk dl dt span::after {
    position: absolute;
    top: 50%;
    right: -30px;
    content: '';
    width: 0;
    height: 0;
    border: 15px solid transparent;
    border-left: 20px solid #fff2f3;
    margin: -15px 0 0;
}

.talk dl dt.point span::after {
    border: 15px solid transparent;
    border-left: 20px solid #9b4a3e;
}

.talk dl dd {
    color: #876;
    background: url(/wp-content/uploads/2022/06/talk-icon_01_nurse.png) no-repeat left center;
    background-size: 100px;
    padding: 1em 1em 1em 130px;
}

.talk dl dd span {
    display: inline-block;
    background: #fbf8ef;
    padding: .5em 2em;
    border-radius: 10px;
    position: relative;
}

.talk dl dd span::after {
    position: absolute;
    top: 50%;
    left: -30px;
    content: '';
    width: 0;
    height: 0;
    border: 15px solid transparent;
    border-right: 20px solid #fbf8ef;
    margin: -15px 0 0;
}


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

.talk {
    margin: 20px 0;
}

.talk dl {
    width: 100%;
}

.talk dl dt,
.talk dl dd {
    min-height: 80px;
}

.talk dl dt br,
.talk dl dd br {
    display: none;
}

.talk dl dt {
    text-align: left;
    background: url(/wp-content/uploads/2022/06/talk-icon_02_nurse.png) no-repeat right center;
    background-size: 80px;
    padding: 1em 100px 1em 1em;
}

.talk dl dt span {
    padding: .5em 1em;
}

.talk dl dd {
    background: url(/wp-content/uploads/2022/06/talk-icon_01_nurse.png) no-repeat left center;
    background-size: 80px;
    padding: 1em 1em 1em 100px;
}

.talk dl dd span {
    padding: .5em 1em;
}

}

/****************************************

    /*

*****************************************/

.no1 {
    margin: 40px 0;
}

.no1 img {
    display: block;
    margin: 20px auto 0;
}

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

.no1 {
    margin: 20px 0;
}

.no1 img {
    margin: 10px auto 0;
}

}

/****************************************

    /*

*****************************************/

.howto {
    text-align: center;
    background: url(images/howto-bg.png) no-repeat center bottom;
    padding: 0 0 20px;
    position: relative;
}

.howto .flame {
    display: inline-block;
    border: 2px solid #666;
    background: #222;
    margin: 10px 0;
    padding: 50px 20px 80px;
    border-radius: 20px;
    position: relative;
}

.howto .flame::before {
    content: "";
    display: block;
    width: 100px;
    height: 8px;
    border: 2px solid #333;
    background: #666;
    position: absolute;
    top: 20px;
    left: 50%;
    margin: 0 0 0 -51px;
    border-radius: 10px;
}

.howto .flame::after {
    content: "";
    display: block;
    width: 50px;
    height: 50px;
    border: 2px solid #333;
    background: #666;
    position: absolute;
    bottom: 15px;
    left: 50%;
    margin: 0 0 0 -26px;
    border-radius: 50%;
}

.howto .flame .display {
    border: 2px solid #111;
    border-radius: 5px;
    overflow: hidden;
}

.howto .icon {
    width: 240px;
    position: absolute;
    bottom: 20px;
    left: 60px;
}

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

.howto {
    background: url(images/howto-bg.png) no-repeat center bottom;
    background-size: 100% auto;
}

.howto .flame {
    display: inline-block;
    border: 2px solid #666;
    background: #222;
    margin: 10px 16%;
    padding: 30px 10px 50px;
    border-radius: 20px;
    position: relative;
}

.howto .flame::before {
    width: 60px;
    height: 5px;
    top: 10px;
    margin: 0 0 0 -31px;
}

.howto .flame::after {
    width: 30px;
    height: 30px;
    bottom: 10px;
    margin: 0 0 0 -16px;
}

.howto .flame .display {
    border: 2px solid #111;
    border-radius: 5px;
    overflow: hidden;
}

.howto .icon {
    width: 120px;
    left: 0;
}

}

/****************************************

    /*

*****************************************/

.area {
    margin: 40px 0;
}

.area table {
    width: 80%;
    border: 2px solid #333;
    margin: 0 auto;
}

.area table th,
.area table td {
    padding: 1em;
}

.area table th {
    width: 40%;
    color: #fff;
    border-right: 2px solid #333;
    background: #f06072;
}

.area table td {
    width: 60%;
}

.area ul {
    display: flex;
    flex-flow: wrap;
}

.area ul li {
    width: 50%;
    padding: .1em;
}

.area ul li a {
    color: #48b;
}

.area ul li a::before {
    content: "■";
}

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

.area {
    margin: 20px 0 40px;
}

.area table {
    width: 96%;
}

}

/****************************************

    /*

*****************************************/

.support {

}

.support .icon {
    display: block;
    width: 160px;
    margin: 0 auto 20px;
}

.support p {
    text-align: center;
    margin: .5em 0;
}

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

.support {
    margin: 0 0 -20px;
    padding: 0 10px;
}

.support .icon {
    display: block;
    width: 80px;
    margin: 0 auto 10px;
}

.support p {
    text-align: left;
}

}

/****************************************

    /*

*****************************************/

footer {
    text-align: center;
    padding: 40px 0;
}

footer a {
    color: #888;
    font-size: 12px;
}

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

footer {
    text-align: center;
    padding: 20px 0;
}

}
