@charset "utf-8";

/*=================================================================================================================================*/
/** 個別指定 for スマートフォン
/*=================================================================================================================================*/

/*---------------------------------------------
 ** 320px
---------------------------------------------*/
@media screen and (max-width: 320px) {
}

/*---------------------------------------------
 ** 740px
---------------------------------------------*/
@media screen and (max-width: 740px) {
  /*---------------------------------------------
	body
---------------------------------------------*/
  html {
    scroll-behavior: smooth;
  }
  body {
    font-size: 15px;
    font-family: "M PLUS 1p";
  }
  p {
    font-size: 15px;
  }

  /* fook */
  .only_sp_none {
    display: none !important;
  }
  .sp_br {
    display: inline#FFF2F2;
  }
  .pc_br {
    display: none;
  }

  /*画像*/
  img {
    max-width: 100%;
    height: auto;
  }

  /*---------------------------------------------
 **  ナビ
---------------------------------------------*/
  .sp_nav ul {
    padding: 0 12% 0 7%;
    background: #fff2f2;
  }
  .sp_nav ul li {
    border-bottom: 1px dashed #ccc;
  }
  .sp_nav ul li:last-of-type {
    border: none;
  }
  .sp_nav ul li a {
    padding: 0.8em 1em 0.7em 2em;
    font-size: 12px;
  }
  .sp_nav ul li a:after {
    position: absolute;
    top: 7px;
    left: 5px;
    content: "≫";
    color: #dd0b59;
  }
  .sp_nav ul li:last-of-type a:after {
    content: "≫";
  }
  .sp_nav {
    border-bottom: none;
  }

  .sp_nav ul li a:before {
    display: none;
  }

  .sp_nav ul {
    border-top: 1px solid #dcdddd;
    border-bottom: 1px solid #dcdddd;
  }

  header nav ul li a:hover {
    background: rgba(255, 255, 255, 0) !important;
  }

  /*---------------------------------------------
 **  メイン画像
---------------------------------------------*/
  .main_img {
    width: 100%;
    height: 130px;
    position: relative;
    background-size: cover;
    text-align: center;
  }
  .header_inner {
    width: 100% !important;
    margin: 0 !important;
    padding: 15px 0 8px;
  }

  .main_h1 {
    text-align: center;
    font-size: 20px;
    padding: 50px 0 0 0;
  }
  #index .main_h1 {
    display: none;
  }

  .main_p {
    position: absolute;
    top: 73px;
    left: 6%;
    font-size: 13px;
    color: #fff;
    font-weight: bold;
    text-align: left;
    line-height: 1.7;
  }
  #index #content {
    padding-top:10%;
  }

  /*---------------------------------------------
 ** w1100
---------------------------------------------*/
  .w1100 {
    width: 80% !important;
    margin: 0 auto !important;
  }

  /*---------------------------------------------
 ** セクション
---------------------------------------------*/
  .section_block {
    margin-bottom: 50px;
  }
  .section_block_bg_pink {
    margin-bottom: 30px;
    padding: 40px 0 40px;
  }
  /*---------------------------------------------
 ** ボタン
---------------------------------------------*/
  .bt_01 {
    font-size: 14px;
    width: 90%;
  }
  .bt_02 {
    font-size: 14px;
    width: 90%;
  }

  /*---------------------------------------------
 ** flex box
---------------------------------------------*/

  .flex_item_clounm_2,
  .flex_item_clounm_3,
  .flex_item_clounm_4 {
    margin-bottom: 30px;
  }
  .flex_item_clounm_2:last-of-type,
  .flex_item_clounm_3:last-of-type,
  .flex_item_clounm_4:last-of-type {
    margin-bottom: 0;
  }

  /*---------------------------------------------
 ** ヘッダー記述
---------------------------------------------*/
  #header {
  }
  .header_wrapper {
  }

  /*---------------------------------------------
 **  ロゴ
---------------------------------------------*/
  #logo {
    width: 165px;
    height: 67px;
    margin: 0px auto 0px;
  }
  #footer {
    padding-top: 50px;
  }
  #footer #logo {
    width: 224px;
    height: 77px;
    margin: 0 auto 15px;
  }
  .sp_tel {
    width: 51px;
    height: 51px;
    position: absolute;
    top: 19px;
    left: 3%;
  }

  #about .inner_main_img,
  #safety .inner_main_img,
  #cultureclass .inner_main_img,
  #history .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #e7bee6, #d896d6);
  }
  #education .inner_main_img,
  #flow .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #ffcfbf, #ff9673);
  }
  #schedule .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #bfefff, #99b3ff);
  }
  #support .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #e7efcf, #91e487);
  }
  #accsess .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #ece37b, #d9d900);
  }
  #guide .inner_main_img,
  #preclass .inner_main_img,
  #parentchild .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #FFD5BB, #FFB591);
  }
  #recruit .inner_main_img {
    background: url(../img/main_img/inner_main_bg2.png) no-repeat top right, linear-gradient(-135deg, #E7E78C, #D9D900);
  }

  /*---------------------------------------------
 **  タイトル
---------------------------------------------*/
  h2 {
    font-size: 2.2rem;
    margin-bottom: 2.7rem;
    line-height: 1.3;
  }
  h2.icon:before {
    width: 40px;
    height: 40px;
    background-size: 100%;
  }
  h2 div {
    margin: 0px auto;
    width: 100%;
  }

  /* h2背景 */
  .icon.h2_bg,
  .h2_bg.white {
    background-size: 90%;
  }

  h3 {
    font-size: 19px;
    margin-left: auto;
    margin-right: auto;
  }

  /*=================================================================================================================================*/
  /**  TOP	*/
  /*=================================================================================================================================*/
  /* カレンダー */
  .calendar_large {
    width: 100%;
    background: #ffffff;
    padding: 15px 10px 0 !important;
    margin-bottom: 70px !important;
    -moz-border-radius:8px; -webkit-border-radius:8px; border-radius:8px;
    _zoom: 1; overflow: hidden;
  }
  /*=================================================================================================================================*/
  /**  フッター	*/
  /*=================================================================================================================================*/
  .footer_wrapper {
    margin: 0;
    padding-bottom: 10px;
  }

  /* フッターナビ */
  #footer nav ul {
    background: #f6f6f6;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 1px 0 1px 0;
  }
  #footer nav li {
    width: 49.3%;
    margin: 1px;
  }
  #footer nav a {
    width: 100%;
    background: #fff;
    font-size: 12px;
    padding: 10px 0;
    text-align: center;
    text-decoration: none;
    display: block;
    position: relative;
  }
  #footer nav a:after {
    width: 10px;
    height: 10px;
    position: absolute;
    top: 15px;
    right: 11px;
    background: url(../img/common/bt_icon_blue.png) 0 0 no-repeat;
    background-size: 100%;
    content: "";
  }

  #copyright {
    font-size: 10px !important;
  }

  /* ページTOPへ */
  #pageTop {
    right: 6%;
    bottom: 0;
  }
  #pageTop a {
    width: 40px;
    height: 57px;
  }

  /* 服部幼稚園からのお知らせ */
  .news {
    padding: 25px 5% 25px;
  }
  .news dl {
    padding: 0em 10px 10px;
    margin-bottom: 15px;
  }
  .news dl dt {
    padding-left: 60px;
  }
  .category_base:before {
    position: absolute;
    top: -27px;
    left: 0;
    margin-right: 0;
    font-size: 11px;
    height: auto;
    width: auto;
  }

  .sp_mb20 {
    margin-bottom: 20px !important;
  }

  /*=================================================================================================================================*/
  /**  内部ページ	*/
  /*=================================================================================================================================*/

  /* 中ページメインイメージ */
  .inner_main_img {
    height: 172px;
    padding: 15px 0;
  }
  /*=================================================================================================================================*/
  /**  当園について	*/
  /*=================================================================================================================================*/
  /* 園内施設のご紹介 */
  #about .sp-horizontal .sp-previous-arrow {
    left: -10px !important;
  }
  #about .sp-horizontal .sp-next-arrow {
    right: -10px !important;
  }
  .about_img_0 {
    width: 90%;
    margin: 20px auto 20px;
  }
  #about .sp-arrow {
    background: #de105c;
    display: block;
    padding: 15px;
  }

  /* 服部幼稚園の教育方針 */
  .h_bg_sakura {
    width: 90%;
    height: 280px;
    margin: 0 auto 20px;

  }
  /* 服部幼稚園ってどんなところ？ */
  .pink_slash_bg h3 {
    font-size: 19px;
  }
  /* アレルギーへの対策 */
  .pink_dl {
    display: table;
    width: 100%;
    text-align: center;
  }
  .pink_dl dt {
    padding: 15px 10px 6px;

    border-bottom: 1px solid #dd0b59;
  }
  .pink_dl dd {
    padding: 15px 10px 8px;
  }
  .pink_dl dd span {
    font-size: 70%;
    display: block;
  }

  .bd_pink {
    border: 2px solid #dd0b59;
    padding: 22px 8% 8px;
    background: #fff;
  }

  /* アレルギーへの対策 */
  .pink_dl dt h4 {
    font-size: 18px;
  }
  .pink_dl dd {
    padding-top: 10px;
  }

  /* 文化教室 */
  .dl_dt_pink dt {
    margin-bottom: 8px;
  }

  .dl_dt_pink dd {
    width: 90%;
    padding: 0 5%;
  }

  /* 沿革 */
  .his_tbl{
    width:100%;
    margin:0 auto 40px;
    border-top:1px solid #DD0B59;
  }
  .his_tbl tr{
    border-bottom:1px solid #DD0B59;
  }
  .his_tbl th{
    width:100%;
    display: block;
    color:#DD0B59;
    font-size:18px;
    font-weight: bold;
    text-align: center;
    vertical-align: middle;
    padding:15px;
    background:#FFE8F3;
  }

  .his_tbl td{
    width:100%;
    display: block;
    text-align: center;
    padding:15px;
  }
  .his_tbl p{
    text-align: left;
    padding-bottom:20px;
  }
  .his_tbl img{
    margin:0 auto 10px;
    display: block;
    float:none;
  }
  .his_tbl div p{
    height:auto;
  }
  .his_tbl .p_br{
    margin-top:0;
  }



  /*=================================================================================================================================*/
  /**  保育内容	*/
  /*=================================================================================================================================*/

  /* 独自の保育内容 */
  .icon_bg_light_pink:after {
    top: -5px;
  }

  /* 感性と優しい心を育てる取り組み */
  .icon_bg_white_clounm_2_L:after {
    top: -15px;
    right: -10px;
  }
  .icon_bg_white_clounm_2_R:after {
    top: 0;
    left: 0px;
  }

  .class_name {
    _zoom: 1;
    overflow: hidden;
    margin: -50px 5% 20px;
    z-index: 1;
    position: relative;
    text-align: center;
  }
  .class_name li {
    display: inline-block;
    margin: 0 0 0 10px;
  }

  /* h3リボン型 */
  .h3_ribbon {
    width: 100%;
    height: auto;
    background: unset;
    padding: 10px 0 13px 0;
    display: inline-block;
    text-align: center;
    border-bottom: 2px dashed #ffe8f3;
  }
  .h3_ribbon:after {
    display: none;
  }

  /* アクセス */
  .icon_access_train,
  .icon_access_bus {
    text-align: center;
    padding: 15px 0 0 0;
  }
  .icon_access_train:before,
  .icon_access_bus:before {
    position: relative;
    margin: 0 auto;
  }

  .access_span{
    line-height: 1.6;
    margin-bottom:30px;
    display: inline-block;
  }

  /* 1日の流れ */

  .oneday01{
    width:100%;
    margin:0 auto;
    background:url(../img/childcare/flow/line_b.png) left repeat-y;
    position:static;
    height:100%;
  }
  .oneday01 img.illust01,.oneday01 img.illust02,
  .oneday01 img.illust03{
    display: none;
  }

  .oneday01 .box01, .oneday01 .box03,
  .oneday01 .box05, .oneday01 .box07,
  .oneday01 .box02, .oneday01 .box04,
  .oneday01 .box06, .oneday01 .box08{
    width:100%;
    position:static;
    padding-top:260px;
    margin-right:0px;
    margin-left:0px;
    right:auto;
    left:auto;
    margin-bottom:10px;
  }

  .oneday01 h3{margin-left:30px;}

  .oneday01 h3 span{ background:url(../img/childcare/flow/clock_b.png) no-repeat left 20px top 0;}

  .oneday01 h3::before{
    content:'';
    width:220px;
  }
  .oneday01 .box01 h3::before, .oneday01 .box02 h3::before,
  .oneday01 .box03 h3::before, .oneday01 .box04 h3::before,
  .oneday01 .box05 h3::before, .oneday01 .box06 h3::before,
  .oneday01 .box07 h3::before, .oneday01 .box08 h3::before {
    top:-220px;
    right:0;
    left:0;
    margin:0 auto;
    background-size:100%;
    text-align: center;
  }

  .oneday01 .box01 h3::after, .oneday01 .box03 h3::after,
  .oneday01 .box05 h3::after, .oneday01 .box07 h3::after,
  .oneday01 .box02 h3::after, .oneday01 .box04 h3::after,
  .oneday01 .box06 h3::after, .oneday01 .box08 h3::after{
    top:0px;
    right:auto;
    left:-30px;
  }

  .oneday01 p{margin-left:30px;}
  .oneday01 .tac{margin-left:30px;}

/*
  .flow_block:nth-child(2n) .flow_box{
    width:100%;
    margin:0 0 30px 0;
    padding:10% 5%;
  }
  .flow_block:nth-child(2n+1) .flow_box{
    width:100%;
    margin:0 0 30px 0;
    padding:8% 5%;
  }
  .flow_block:nth-child(2n) .flow_box .flow_img{
    float:none;
    margin:0 auto;
  }

  .flow_block:nth-child(2n+1) .flow_box .flow_img{
    float:none;
    margin:0 auto;
  }


  .flow_block .flow_img{
    width:90%;
    max-width: 365px;
    margin:0 auto 20px;
  }
  .flow_block:nth-child(2n) .flow_text{
    width:100%;
    margin:2% 0 0 0;
    float:none;
    text-align: left;
  }
  .flow_block:nth-child(2n+1) .flow_text{
    width:100%;
    margin:2% 0 0 0;
    float:none;
    text-align: left;
  }

  .flow_block .flow_text h3{
    text-align: center;
    border-bottom:2px dotted #4A391F;
    padding-bottom:10px;
    margin-bottom:10px;
  }
  .flow_block .flow_text h3 span{
    font-size:90%;
    padding-top:2px;
    padding-bottom:5px;
    margin-bottom:0;
    margin-top:5px;
  }
  .flow_block .flow_text p{
    line-height: 1.8;
  }

  .flow_block .flow_text .btn{
    width:100%;
  }

  .flow_block .flow_text .btn p{
    width:100%;
    float:none;
    margin-bottom:10px!important;
  }
  .flow_block .flow_text .tac{
    width:90%;
    float:none;
    text-align: center!important;
    margin:5px auto;
  }
  .flow_block .flow_text .tac .bt_01{
    width:90%!important;;
  }
  .flow_block .flow_text::after{
    content:'';
    clear:both;
    display: block;
  }
*/
  /*=================================================================================================================================*/
  /**  年間行事	*/
  /*=================================================================================================================================*/
  .schedule_block {
    width:90%;
    margin:0 auto;
    text-align: center;
  }
  .schedule {
    width:100%;
    margin:0 auto;
    border-radius: 10px;
    padding: 30px 15px!important;
    position:relative;
    display: flex;
    flex-wrap: wrap;
  }

  .lsize{
    margin-top:120px!important;
  }
  .msize{
    width: 100%;
    margin-top:120px!important;
  }


  .mon04::before, .mon07::before,
  .mon09::before, .mon12::before,
  .mon03::before{
    top:-100px;
    left:0;
    right:0;
    margin:0 auto;
  }
  .mon05::before, .mon06::before,
  .mon08::before, .mon10::before,
  .mon11::before, .mon01::before,
  .mon02::before{
    top:-100px;
    left:0;
    right:0;
    margin:0 auto;
  }


  .wide .small{
    width:47%;
    margin-right:6%;
  }
  .wide .small:nth-child(2){
    margin-right:0px;
  }
  .mon04 .small, .mon12 .small{
    width:47%;
    margin-left:0;
    margin-right:6% !important;
  }
  .mon04{
    display: block!important;
  }
  .mon04 .small{
    width:47%;
    margin:0 auto;
  }

  .mon04 .last, .mon12 .last{
    margin-right:0px !important;
  }

  .narrow .small{
    width: 47%;
    margin-right:6%;
  }
  .narrow .small:nth-child(2){
    margin-right:0!important;
  }
  .narrow .small:nth-child(3){
    width: 100%;
    margin-right:0;
    margin:5% auto 0;
  }
  .schedule .large{
    width:100%;
    margin:5% auto;
    position:relative;
  }
  .schedule .large img{
    max-width: 250px;
    position:static;
  }
  .schedule .large p{
    margin-top:10px;
  }

  .schedule_wrapper div:nth-of-type(1) {
    padding: 30px 5%;
  }
  /* 春 */
  .spring_header_img,
  .summer_header_img,
  .autumn_header_img,
  .winter_header_img {
    width: 85% !important;
    margin: -50px auto 18px;
  }
  /* 見出し */
  .schedule_h {
    width: 150px;
    margin: 0 auto 10px;
    background-size: contain !important;
  }
  /* 下の文言 */
  .schedule_box_bg > p {
    font-size: 16px;
    margin-bottom: 20px !important;
    text-align: center;
  }
  /* 下につく画像 */
  .schedule_list:after {
    width: 80px;
    height: 121px;
    position: absolute;
    bottom: -50px;
    left: unset;
    right: -6px;
    margin: 0 auto;
    content: "";
    background-size: contain !important;
  }

  /*=================================================================================================================================*/
  /**  入園案内	*/
  /*=================================================================================================================================*/

  .g_main{
    background-size:contain;
    padding-top:53%;
  }
  #guide .g_main, #preclass .g_main, #parentchild .g_main{ border-bottom:none}

  .g_main p{
    width:100%;
    font-size:17px;
    padding:2% 0;
  }
  .g_message{
    max-width:1100px;
    border:2px solid #FF0000;
    margin:3% auto;
  }
  .g_message p{
    text-align:center;
    padding:2%;
    color:#FF0000;
  }

  .guide_tbl{
    width:100%;
    margin-top:5%;
  }
  .guide_tbl tr{
    border-bottom: none;
  }

  .guide_tbl th{
    width:100%;
    display: block;
    font-size:16px;
    box-shadow: 0 0 0 0 #fff inset;
    padding:5% 0;
    line-height: 1.2;
  }
  #parentchild .guide_tbl th{
    width:100%;
    display: block;
    padding:3% 0;
  }
  .guide_tbl td{
    width:100%;
    display: block;
    padding:4% 5% 10%;
    vertical-align: middle;
  }
  #parentchild .guide_tbl td{
    padding:2% 5% 10%;
  }
  .guide_tbl td.sp_c{ text-align: center;}

  .guide_tbl td .b30{
    color:#DD0B59;
    font-size:20px;
    font-weight:bold;
  }
  .guide_tbl td .b30a{font-size:26px;}

  .guide_tbl td .b18{
    color:#DD0B59;
    font-size:16px;
    font-weight:bold;
  }
  .guide_tbl td .b24{
    color:#DD0B59;
    font-size:18px;
    font-weight:bold;
  }
  .guide_tbl td .b20{
    color:#DD0B59;
    font-size:16px;
    font-weight:bold;
  }
  .guide_tbl td .m_left{
    margin-left:1%;
    display: block;
    line-height: 1.2;
    font-size:90%;
  }
  .guide_tbl td .r_waku{
    width:100%;
    margin-right:0;
    margin-bottom:6px;
    padding:3% 0;
  }
  .guide_tbl .waku2{
    margin-top:8%;
  }
  .guide_tbl td p{
    margin:2% 0 0;
  }
  .guide_tbl .ac_btn{
    position:relative;
  }
  .guide_tbl .ac_btn .bt_01{
    width:250px;
    height:50px;
    position:absolute;
    text-align: center;
    bottom:-30%;
    left:0;
    right:0;
    margin:0 auto;
  }
  .guide_tbl td .b18 p{
    font-size:15px;
    font-weight:normal;
    color:#4a391f;
  }
  .guide_tbl td .b18 p strong{
    font-size:15px;
    font-weight:bold;
    color:#F34E52;
  }
  .smile_genki{
    width:100%;
    display:block;
    margin:5% auto;
  }
  .smile_genki h3{
    font-size: 2.4rem;
  }
  .smile_genki .smile, .smile_genki .genki{
    width:100%;
    margin:10% auto 0;
  }
  .smile_genki .smp{
    height:auto;
    margin:0;
  }

  .smile_genki .h140{
    height: auto;
  }
  .smile_genki .h120{
    height: auto;
  }
  .smile_genki .genki .h120{
    background-color: #F9FFE6!important;
  }

  #guide .g_main, #preclass .g_main, #parentchild .g_main{ border-bottom:none}



  /*=================================================================================================================================*/
  /**  採用情報	*/
  /*=================================================================================================================================*/
  .r_main, .r_main2{ border-bottom:none}

  .r_main{ padding-top:53%;}

  .r_main2{ margin-top:100px;}

  .r_main p, .r_main2 p{
    width:100%;
    font-size:17px;
    padding:2% 0;
  }
  .youkou{
    border-top:none;
  }
  .youkou dl{
    border-bottom:none;
    display: block;
    float:none;
  }
  .youkou dl.dl_h{
    width:100%;
  }
  .youkou dt{
    width:100%;
    display: block;
    height:auto;
    padding:4% 0;
    font-size:1.6rem;
    line-height:1.2;
    text-align: center;
    box-shadow: 0 0 0 0 #fff inset;
  }
  .youkou dd{
    width:100%;
    display: block;
    font-size:1.5rem;
    padding:4% 5% 10%;
  }
  .youkou dd.dd_tbl{
    padding:2% 0 0;
  }
  .youkou dd table{
    width: 100%;
    margin:5% auto 10%;
  }
  .youkou dd table th{
    font-size: 1.4rem;
    text-align: center;
    padding-bottom:10px;
  }
  .youkou dd table td{
    font-size: 1.4rem;
    font-weight: bold;
    text-align: center;
    padding:0 0 10px;
  }
  .youkou dd table td.divide{
    font-size: 1.2rem;
    -ms-text-align-last: auto;
    text-align:left;
    width:20%;
  }

  .youkou .b20{
    font-size:1.6rem;
  }
  .youkou .b30{
    font-size:2.2rem;
  }
  .youkou .bold18{
    font-size:1.6rem;
  }
  .youkou .ac_btn .bt_02{
    height:50px;
    position:absolute;
    bottom:-20%;
    right:0;
    left:0;
    margin:0 auto;
  }
  .youkou .b20 p strong{
    font-size: 1.6rem;
  }

  /*=================================================================================================================================*/
  /**  情報公開	*/
  /*=================================================================================================================================*/

  .release_box {
    margin-bottom: 50px;
  }
  .release_box .box_half:nth-of-type(odd){ float:none;  position: relative; width: calc((100% - 0px));margin-right:0;}
  .release_box .box_half:nth-of-type(even){ float:none; position: relative;width: calc((100% - 0px));margin-right:0;}

  .release_box ul{
    margin: 0 auto 30px;
  }
.release_box ul li{ display:block; text-align: center;}
.release_box ul li span{ width:80%; background:url(../img/release/pdf_icon.png)no-repeat left 2px top 15px; background-size:10%;padding:18px 0 12px;text-align:center; margin:0 auto; }


.release_box ul li .tac{
  margin:0 auto;
}

/*=================================================================================================================================*/
/**  お知らせ（WP）	*/
/*=================================================================================================================================*/

#main_contents .kiji{
  background:none;
}
.kiji-list .text{
  padding-bottom:60px;
  background:none;
}
.kiji-list .text:nth-child(2n){
  background:none;
}
#wp_container { margin:0 0 80px!important; }

#wp_container h2{font-size:20px;margin:20px auto 30px;}



}
