@media screen and (max-width: 1200px) {
  .hoiku-template-header-inner .col-right {
    width: 60%; /* 内包するリストがカラム落ちするので */
  }
  #hoiku-template-header ul li {
    font-size: 14px;
  }
}
@media screen and (max-width: 940px) {

  .wrap {
    padding: 0 4%;
  }
  .img_pc {
    display: none;
  }
  .img_sp {
    display: inline-block;
  }

  .header-inner {
    padding: 25px 0% 0 5%;
  }

  /* トップページ */
  .logo_topForMobile {
    display: block;
  }
  .topics {
    margin: 0 auto;
  }

  #hoiku-template-header {
    padding: 0 3%;
  }
  

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

  /* ----------------------------------------------------------------
   * COMMON
   * ---------------------------------------------------------------- */
  .spbr {
    display: block;
  }
  
  /* ----------------------------------------------------------------
   * COMMON / HEADER
   * ---------------------------------------------------------------- */
   #header {
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 1002;
    width: 100%;
    background: rgba(0, 0, 0, .4);
  }
  #header.is-fixed {
    position: fixed;
    height: 100vh;
  }
  .header-inner , .breadcrumb {
    background: rgba(255, 255, 255, 0.95);
  }
  .header-nav-top, .header-nav-bottom {
    display: none;
  }
  .header-inner {
    height: 56px;
    padding: 0 3%;
  }
  .header-logo {
    width: 207px;
    margin: 13px 0 0;
  }
  .header-logo img {
    width: 207px;
  }
  .spnav-contact, .hnav {
    display: block;
  }
  .hnav-list {
    display: block;
  }
  #offcanvas {
    display: none;
    /*overflow: scroll;*/
    transition: all 300ms 0s ease;
    transform: translateX(101%);
  }
  #offcanvas.is-active {
    transform: translateX(0%);
  }

  /* ----------------------------------------------------------------
   * COMMON / FOOTER
   * ---------------------------------------------------------------- */
  #footer {
    padding: 35px 5% 30px;
  }
  .footer-inner {
    display: block;
  }
  .footer-inner-left {
    display: none;
  }
  .footer-inner-right {
    width: 100%;
    margin: 0 auto;
  }
  .footer-inner-right h3 {
    max-width: 260px;
  }

  .footer-nav-sp {
    display: block;
  }
  .footer-nav-sp ul {
    text-align: center;
    margin: 30px auto -5px;
  }
  .footer-nav-sp ul li {
    font-size: 12px;
    letter-spacing: 0.05rem;
    margin: 0 auto 15px;
  }
  .footer-nav-sp ul li a {
    color: #ffffff;
    text-decoration: none;
  }

  .copy {
    font-size: 10px;
    line-height: 20px;
  }
  #toTop {
    top: inherit;
    bottom: 20px;
    right: 15px;
  }

  /* ----------------------------------------------------------------
   * BREADCRUMB-NAV
   * ---------------------------------------------------------------- */
  .breadcrumb ul {
    padding: 5px 3%;
  }
  .breadcrumb ul li {
    font-size: 11px;
    line-height: 2;
    padding: 0;
    margin: 0 5px 0 0;
  }
  .breadcrumb ul li a {
    margin-right: 5px;
  }

  /* ----------------------------------------------------------------
   * MAIN
   * ---------------------------------------------------------------- */
  #main {
    padding-top: 0;
    margin: 56px auto 0;
  }

  #hoikuService-base {
    padding: 40px 5% 65px;
  }
  #hoikuService-base:before {
    height: calc(100vh - 56px);
    margin-top: 56px;
  }
  .hoikuService-ttl {
    width: 216px;
    height: 38px;
    font-size: 18px;
    line-height: 38px;
    text-align: center;
    letter-spacing: 0.3em;
  }
  .hoikuService-container {
    max-width: 768px;
    padding: 45px 0 0;
    margin: 40px auto 0;
  }
  .hoikuService-container h2 {
    font-size: 20px;
  }
  .hoikuService-container p {
    font-size: 13px;
    text-align: justify;
    margin: 20px 5% 0;
  }
  .hoikuService-container p br {
    display: none;
  }
  .hoikuService-flexRow-wrap {
    padding: 0 5%;
    margin: 40px auto 0;
  }
  .hoikuService-flexRow {
    display: block;
    margin: 0 auto 60px;
  }
  .hoikuService-flexRow .inner-left, .hoikuService-flexRow .inner-right {
    width: 100%;
  }
  .hoikuService-flexRow .inner-right {
    margin: 20px auto 0;
  }
  .hoikuService-flexRow h3 {
    font-size: 18px;
    letter-spacing: 0.1em;
  }
  .hoikuService-flexRow ul li {
    margin: 0 0 10px;
  }
  .hoikuService-flexRow ul li p {
    font-weight: 500;
    font-size: 13px;
    line-height: 1.8;
    padding: 0 0 0 1.2rem;
  }
  .hoikuService-flexRow ul li p:before {
    width: .8rem;
    height: .8rem;
    top: 0;
  }
  .hoikuService-facilitiesList {
    padding: 45px 5%;
    margin: 50px auto 0;
  }
  .hoikuService-container h2{
    font-size: 17px;
    letter-spacing: 0.1em;
  }
  .hoikuService-facilitiesList ul {
    margin: 30px -2% 0;
  }
  .hoikuService-facilitiesList ul li {
    width: 46%;
    margin: 0 2% 20px;
  }
  .hoikuService-facilitiesList ul li p {
    font-size: 13px;
    letter-spacing: 0.05rem;
    margin: 5px 0 0;
  }
  .hoikuService-facilitiesList ul li p:before {
    width: .8rem;
    height: .8rem;
    margin: 0 5px 0 0;
  }
  #widget-contact .inner p {
    font-size: 13px;
  }
  #widget-contact .inner button {
    width: 240px;
    height: 60px;
    margin: 15px auto 0;
  }
  #widget-contact .inner button a p {
    font-size: 16px;
    letter-spacing: 0.1em;
  }

  /* ----------------------------------------------------------------
   * HOIKU-TEMPLATE
   * ---------------------------------------------------------------- */
   #hoiku-template-header {
    position: relative;
    padding: 0;
  }
  #hoiku-template-header h1 {
    font-size: 20px;
    letter-spacing: 0.08rem;
    margin: 15px 0 0;
  }
  #hoiku-template-header ul {
    display: none;
  }
  .nav-service-sp {
    display: block;
  }
  .hoiku-template-header-inner .col-left {
    width: 50%;
    padding-top: 38%;
  }
  .hoiku-template-header-inner .col-right {
    width: 50%;
    padding: 0 3%;
  }
  .hoiku-template-header-inner .col-right .inner {
    top: 50%;
  }
  .tag-service {
    display: inline-block;
    width: auto;
    font-size: 10px;
    letter-spacing: 0.1em;
    padding: 3px 4%;
    border-radius: 3px;
  }
  #hoiku-template-content {
    max-width: 768px;
    padding: 40px 5% 0;
    margin: 0 auto;
    transform: translateY(0px); 
  }
  #hoiku-template-content .inner-col-top {
    display: block;
  }
  #hoiku-template-content .inner-col-top .col-text {
    width: 100%;
  }
  #hoiku-template-content .inner-col-top .col-text h2 {
    font-size: 17px;
    line-height: 1.8;
    letter-spacing: 0.1em;
  }
  #hoiku-template-content .inner-col-top .col-text p {
    font-size: 13px;
  }
  #hoiku-template-content .inner-col-top .col-image {
    width: 100%;
    margin: 35px auto 0;
  }

  #hoiku-template-content .inner-col-middle {
    margin: 60px auto 0;
  }
  .ttl-hoiku {
    cursor: pointer;
    font-size: 18px;
    padding: 0 0 12px;
  }

  .ttl-hoiku .ico-toggle {
    display: inline-block;
    float: right;
  }
  .ttl-hoiku .ico-toggle i {
    position: relative;
  }
  .ttl-hoiku .ico-toggle i:after {
    content: '';
    width: 8px;
    height: 8px;
    border: 0px;
    border-top: solid 2px #D7D7D7;
    border-right: solid 2px #D7D7D7;
    -ms-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: 2px;
    transition: all 400ms 0s ease;
  }
  .ttl-hoiku.is-active .ico-toggle i:after {
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    margin-top: 5px;
  }
  table.hoiku-template-list {
    margin: 20px auto 0;
  }
  table.hoiku-template-list tr th, table.hoiku-template-list tr td {
    padding: 10px 2%;
  }
  table.hoiku-template-list tr th {
    width: 30%;
    font-size: 13px;
    letter-spacing: 0.02rem;
  }
  table.hoiku-template-list tr td p {
    font-size: 13px;
    letter-spacing: 0.02rem;
  }

  #hoiku-template-content .inner-col-bottom {
    margin: 60px auto;
  }
  #hoiku-template-content .inner-col-bottom .inner {
    display: block;
  }
  #hoiku-template-content .inner-col-bottom .inner .col-map , #hoiku-template-content .inner-col-bottom .inner .col-address {
    width: 100%;
  }
  .gmap {
    padding-bottom: 55%;
  }
  #hoiku-template-content .inner-col-bottom .inner .col-address {
    margin: 20px auto 0;
  }
  #hoiku-template-content .inner-col-bottom .inner .col-address p {
    font-size: 13px;
    letter-spacing: 0.02rem;
  }

  #widget-hoiku .inner {
    padding: 28px 5%;
  }
  #widget-hoiku .inner p {
    font-size: 13px;
  }
  #widget-hoiku .inner ul {
    display: block;
  }

  /* ----------------------------------------------------------------
   * HOIKU-SERVICE
   * ---------------------------------------------------------------- */
  .header-service {
    display: block;
    margin: 20px auto 0;
  }
  .header-service h3 {
    font-size: 17px;
    line-height: 1.8;
    letter-spacing: 0.05rem;
    /*text-align: justify;*/
  }
  .header-service h3 br {
    display: none;
  }
  .header-service p {
    line-height: 2;
    font-size: 13px;
    margin: 10px 0 0;
  }
  .header-service p br {
    display: none;
  }
  .header-service .col-left {
    width: 100%;
  }
  .header-service .col-right {
    width: 100%;
    margin: 25px auto 0;
    text-align: center;
  }
  .header-service .col-right img {
    max-width: 280px;
  }
  .row-service {
    margin: 30px auto 0;
  }
  .row-service h3 {
    font-size: 16px;
    letter-spacing: 0.1em;
    margin: 0 0 5px;
  }
  .row-service p {
    line-height: 2;
    font-size: 13px;
    margin: 5px auto 0;
  }
  .row-service p.fz-small {
    font-size: 12px;
    margin: 5px auto 0;
  }
  .row-service .inner-program img {
    display: block;
    width: 90%;
    margin: 0 auto;
  }
  .kidsNote {
    display: block;
    padding: 26px 5%;
    margin: 35px auto 0;
  }
  .kidsNote:after {
    content: "";
    display: block;
    width: 82%;
    height: 100%;
    z-index: 101;
    background: #BBEAFC;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    transform: skew(-10deg) translateX(-50%);
  }
  .kidsNote .col-right , .kidsNote .col-left {
    width: 100%;
  }
  .kidsNote .col-left {
    margin: 20px auto 0;
  }
  .kidsNote .col-right h3 {
    font-size: 15px;
    line-height: 1.8;
  }
  .kidsNote .col-right p {
    font-size: 13px;
  }
  .kidsNote .col-left img {
    display: block;
    max-width: 250px;
    margin: 0 auto;
  }
  .sec-hoikuEnv {
    margin: 30px auto 0;
  }
  .sec-hoikuEnv:last-child {
    margin: 30px auto 50px;
  }
  .spToggle-content {
    margin-bottom: 60px;
  }
  .row-service .inner-map {
    margin: 10px auto 0;
  }
  .row-service .inner-map img {
    display: block;
    max-width: 250px;
    margin: 0 auto;
  }
  .row-service .inner-program {
    margin: 12px auto 0;
  }
  table.list-service {
    margin: 12px auto 0;
  }
  table.list-service tr th, table.list-service tr td {
    padding: 12px 2%;
    vertical-align: middle;
  }
  table.list-service tr th {
    font-size: 13px;
  }
  table.list-service tr td {
    font-size: 13px;
  }
  table.list-service tr td h4 {
    font-size: 13px;
  }
  table.list-service tr td p {
    font-size: 10px;
    letter-spacing: 0;
  }

  /* ----------------------------------------------------------------
   * HOIKU-GALLERY
   * ---------------------------------------------------------------- */
  .gallery-service {
    margin: 20px -2% 0;
  }
  .gallery-service .inner {
    width: 46%;
    margin: 0 2% 15px;
  }
  .gallery-service .inner p {
    font-size: 13px;
    margin: 5px 0 0;
  }
  .sec-usage {
    margin: 45px auto 50px;
  }

  /* トップページ */
  .topMainImage ul li {
    width: 100%;
    float: none;
  }
  .ttl_home {
    font-size: 136%;
    letter-spacing: 2px;
    padding: 0 0 10px 2px;
  }
  .ttl_home::after {
    width: 85px;
  }
  .topics ul li a {
    font-size: 93%;
  }
  .btn_home a {
    font-size: 93%;
  }

  /* 下層共通パーツ */
  h3.catch  {
    font-size: 135%;
    line-height: 1.5;
  }
  .row {
    margin-bottom: 50px;
  }
  .row p {
    font-size: 93%;
  }
  #left_con, #right_con {
    width: 100%;
    float: none;
  }
  #left_con {
    margin-bottom: 60px;
  }
  #left_con:after{
    content: "."; 
    display: block; 
    height: 0; 
    font-size: 0;  
    clear: both; 
    visibility: hidden;
  }
  #ttl_main {
    position: relative;
    height: auto;
    line-height: 1.5;
    margin: 0 0 20px;
    padding: 0 0 50px;
    background: #f7f7f7 !important;
  }
  #ttl_main h2 {
    font-size: 23px;
    height: auto;
    letter-spacing: 1px;
    line-height: 1.5;
    padding: 50px 4% 0;
  }
  #ttl_main h2::before {
    background: #f7f7f7 url("../images/ico_ttlMain.png") no-repeat scroll 0 0 / cover;
    margin: 0 15px 0 0;
  }

  .sideMenu h3 {
    font-size: 120%;
    letter-spacing: 0;
    padding: 16px 0;
  }
  .sideMenu ul li ul.subMenu li {
    margin: 0 2%;
  }
  .sideMenu ul li a {
    font-size: 93%;
    font-weight: bold;
    padding: 16px 4%;
  }
  .recentPost {
    margin: 15px 0 60px;
  }
  .recentPost h3 {
    font-size: 110%;
    letter-spacing: 1px;
  }
  .recentPost dt, .recentPost dd {
    font-size: 93%;
  }
  .tabNav {
    margin: 0 auto 20px;
  }
  .tabNav ul li {
    font-size: 15px;
    letter-spacing: 1px;
  }
  .entryBox h3 {
    font-size: 130%;
    letter-spacing: 1px;
  }
  .entryBox_inner {
    padding: 25px 0 10px;
  }
  .entryBox_inner ul {
    width: 100%;
  }
  .entryBox_inner ul li {
    padding: 15px 2%;
  }
  .entryBox_inner ul li h4 {
    font-size: 120%;
  }
  .entryBox_inner ul li:first-child p {
    font-size: 200%;
    letter-spacing: 1px;
  }
  .btn_to a {
     font-size: 120%;
  }
  .btnBox li a {
    font-size: 100%;
    letter-spacing: 0;
  }
  .photo_box li p {
    font-size: 100%;
    letter-spacing: 0;
  }
  #ideal .ide_box table td {
    border-bottom: none;
    display: block;
    padding: 25px 0 0;
    width: 100%;
  }
  #ideal .ide_box table td:nth-child(2n) {
    text-align: justify;
    padding: 15px 2% 25px;
    border-bottom: 1px solid #e3dccc;
    box-sizing: border-box;
  }
  .btnBox ul {
    display: block;
  }
  .btnBox ul li {
    margin-bottom: 10px;
    display: inline-block;
  }
  .btnBox ul li a {
    padding: 14px 26px;
  }
  .bs_tb th,.bs_tb td {
    font-size: 93%;
  }
  /* ビジョン */
  .vision dl.accordion dd p {
    font-size: 93%;
  }
  /* お問い合わせ */
  .align_c {
    font-size: 100%;
    letter-spacing: 2px;
    padding: 0 4%;
    margin: 50px auto;
    text-align: center;
  }
  .contact_header ul li {
    font-size: 95%;
  }
  .contactTeltable tr th {
    padding: 2% 1%;
  }
  .contactTeltable tr td {
    padding: 5px 1%;
  }
  .contactTeltable tr th, .contactTeltable tr td {
    width: 100%;
    display: block;
    font-size: 93%;
    box-sizing: border-box;
  }
  .contactTeltable tr td:first-child, .contactTeltable tr td:nth-child(2) {
    border-bottom: none;
  }
  #contactForm th, #contactForm td {
    display: block;
    width: 100%;
    float: none;
    padding: 5px 0;
  }
  #contactForm td {
    padding: 0;
  }
  #contactForm th span {
    display: inline-block;
    margin: 0 0 0 8px;
    float: none;
  }
  #btn_submit {
    height: 60px;
    letter-spacing: 4px;
    line-height: 60px;
  }
}
@media screen and (max-width: 480px) {
  .topics ul li time span {
    position: static;
  }
  .topics ul li p {
    margin: 0;
  }
  /* 全ページ共通パーツ */
  .logo_topForMobile {
    margin: 31% auto 17%;
  }
  .copy li {
    font-size: 10px;
    line-height: 1.4;
  }
  /* 下層共通パーツ */
  #ttl_main {
    padding: 0 0 28px;
  }
  #ttl_main h2 {
    font-size: 17px;
    letter-spacing: 0;
    padding: 22px 4% 0;
  }
  #ttl_main h2::before {
    background-size: cover;
    height: 30px;
    margin: 0 15px 0 0;
    width: 53px;
  }
  .ttl_sub {
    font-size: 108%;
    letter-spacing: 1px;
    padding: 8px 3%;
  }
  h3.catch {
    font-size: 115%;
  }
  h3.catch br {
    display: none;
  }
  .slogun ul li {
    font-size: 105%;
  }
  .bs_box li, .bs_box dt, .bs_box dd {
    font-size: 93%;
    line-height: 1.5;
  }
  .tabNav {
    margin: 0 auto 20px;
  }
  .tabNav ul li {
    font-size: 13px;
    letter-spacing: 0;
    height: 35px;
    line-height: 35px;
  }
  .img_flr {
    text-align: center;
    margin: 0 0 15px;
  }
  .img_flr img {
    float: none;
    width: 100%;
    margin: 0;
  }
  .img_flr img.img_preg {
    max-width: 204px;
  }
  .btnBox li a {
    font-size: 90%;
  }
  .bs_tb th, .bs_tb td {
    font-size: 90%;
    letter-spacing: 0;
    line-height: 1.5;
    padding: 12px 3%;
  }
  .entryBox h3 {
    font-size: 110%;
    letter-spacing: 0;
  }
  .entryBox_inner > p {
    font-size: 95%;
    margin: 0 4% 20px;
  }
  .entryBox_inner ul li {
    padding: 12px 6%;
    width: 88%;
  }
  .entryBox_inner ul li h4 {
    font-size: 110%;
  }
  .entryBox_inner ul li:first-child p {
    font-size: 180%;
    letter-spacing: 1px;
  }
  .btn_to.btn_contact_l a {
    height: 60px;
    line-height: 60px;
    width: 100%;
  }
  .btn_to.btn_contact_l i::before {
    margin: 18px -64% 0 107%;
  }
  .btn_to.btn_contact i::before, .btn_to.btn_entry i::before {
    margin: 13px -33% 0 33%;
  }
  /* 法人理念 */
  #ideal h3.ideal02, #ideal .ide_box {
    width: 100%;
  }
  .dh_tb th, .dh_tb td {
    font-size: 13px;
  }
  .his_tb th,.his_tb td {
    line-height: 1.5;
    padding: 5px 0.8%;
    font-size: 12px;
    width: 33%;
  }
  /* 新着情報 */
  #news #left_con {
    margin: 20px auto 80px;
  }
  .summary dl {
    padding: 12px 1%;
  }
  .summary dl dt span {
    position: static;
    font-size: 13px;
  }
  .summary dl dd {
    font-size: 13px;
    margin: 0;
  }
  /* ビジョン */
  .vision dl.accordion dd  {
    padding: 3%;
  }
  .vision dl.accordion dd p {
    padding: 3%;
  }
  .vision dl.accordion dd p br {
    display: none;
    text-align: justify;
  }
  /* 施設の様子 */
  .photo_box li {
    width: 49%;
  }
  .photo_box li:nth-child(3n) {
    margin: 0 2% 15px 0;
  }
  .photo_box li:nth-child(2n) {
    margin-right:0;
  }
  .photo_box li p {
    font-size: 90%;
    letter-spacing: 0;
  }
  #report ul li {
    font-size: 93%;
  }
}