@charset "UTF-8";
/* Body */
body {
	font-family: source-sans-pro;
	background-color: #f2f2f2;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	font-style: normal;
	font-weight: 200;
}
/* Container */
.container {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	height: 1000px;
	background-color: #FFFFFF;
}
/* Navigation */
header {
	width: 100%;
	height: 5%;
	background-color: #52bad5;
	border-bottom: 1px solid #2C9AB7;
}
.logo {
	color: #fff;
	font-weight: bold;
	text-align: undefined;
	width: 10%;
	float: left;
	margin-top: 15px;
	margin-left: 25px;
	letter-spacing: 4px;
}
nav {
	float: right;
	width: 50%;
	text-align: right;
	margin-right: 25px;
}
header nav ul {
	list-style: none;
	float: right;
}
nav ul li {
	float: left;
	color: #FFFFFF;
	font-size: 14px;
	text-align: left;
	margin-right: 25px;
	letter-spacing: 2px;
	font-weight: bold;
	transition: all 0.3s linear;
}
ul li a {
	color: #FFFFFF;
	text-decoration: none;
}
ul li:hover a {
	color: #2C9AB7;
}
.hero_header {
	color: #FFFFFF;
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	letter-spacing: 4px;
}
/* Hero Section */
.hero {
	background-color: #B3B3B3;
	padding-top: 150px;
	padding-bottom: 150px;
}
.light {
	font-weight: bold;
	color: #717070;
}
.tagline {
	text-align: center;
	color: #FFFFFF;
	margin-top: 4px;
	font-weight: lighter;
	text-transform: uppercase;
	letter-spacing: 1px;
}
/* About Section */
.text_column {
	width: 29%;
	text-align: justify;
	font-weight: lighter;
	line-height: 25px;
	float: left;
	padding-left: 20px;
	padding-right: 20px;
	color: #A3A3A3;
}
.about {
	padding-left: 25px;
	padding-right: 25px;
	padding-top: 35px;
	display: inline-block;
	background-color: #FFFFFF;
	margin-top: 0px;
}
/* Stats Gallery */
.stats {
	color: #717070;
	margin-bottom: 5px;
}
.gallery {
	clear: both;
	display: inline-block;
	width: 100%;
	background-color: #FFFFFF;
	/* [disabled]min-width: 400px;
*/
	padding-bottom: 35px;
	padding-top: 0px;
	margin-top: -5px;
	margin-bottom: 0px;
}
.thumbnail {
	width: 25%;
	text-align: center;
	float: left;
	margin-top: 35px;
}
.gallery .thumbnail h4 {
	margin-top: 5px;
	margin-right: 5px;
	margin-bottom: 5px;
	margin-left: 5px;
	color: #52BAD5;
}
.gallery .thumbnail p {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	color: #A3A3A3;
}
/* Parallax Section */
.banner {
	background-color: #2D9AB7;
	background-image: url(../images/parallax.png);
	height: 400px;
	background-attachment: fixed;
	background-size: cover;
	background-repeat: no-repeat;
}
.parallax {
	color: #FFFFFF;
	text-align: right;
	padding-right: 100px;
	padding-top: 110px;
	letter-spacing: 2px;
	margin-top: 0px;
}
.parallax_description {
	color: #FFFFFF;
	text-align: right;
	padding-right: 100px;
	width: 30%;
	float: right;
	font-weight: lighter;
	line-height: 23px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
/* More info */
footer {
	background-color: #FFFFFF;
	padding-bottom: 35px;
}
.footer_column {
	width: 50%;
	text-align: center;
	padding-top: 30px;
	float: left;
}
footer .footer_column h3 {
	color: #B3B3B3;
	text-align: center;
}
footer .footer_column p {
	color: #717070;
	background-color: #FFFFFF;
}
.cards {
	width: 100%;
	height: auto;
	max-width: 400px;
	max-height: 200px;
}
footer .footer_column p {
	padding-left: 30px;
	padding-right: 30px;
	text-align: justify;
	line-height: 25px;
	font-weight: lighter;
	margin-left: 20px;
	margin-right: 20px;
}
.button {
	width: 200px;
	margin-top: 40px;
	margin-right: auto;
	margin-bottom: auto;
	margin-left: auto;
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
	text-align: center;
	vertical-align: middle;
	border-radius: 0px;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 2px;
	border: 3px solid #FFFFFF;
	color: #FFFFFF;
	transition: all 0.3s linear;
}
.button:hover {
	background-color: #FEFEFE;
	color: #C4C4C4;
	cursor: pointer;
}
.copyright {
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #717070;
	color: #FFFFFF;
	text-transform: uppercase;
	font-weight: lighter;
	letter-spacing: 2px;
	border-top-width: 2px;
}
.footer_banner {
	background-color: #B3B3B3;
	padding-top: 60px;
	padding-bottom: 60PX;
	margin-bottom: 0px;
	background-image: url(../images/pattern.png);
	background-repeat: repeat;
}
footer {
	display: inline-block;
}
.hidden {
	display: none;
}

/* Mobile */
@media (max-width: 320px) {
.logo {
	width: 100%;
	text-align: center;
	margin-top: 13px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
.container header nav {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	float: none;
	display: none;
}
header nav ul {
}
nav ul li {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	text-align: center;
}
.text_column {
	width: 100%;
	text-align: justify;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.thumbnail {
	width: 100%;
}
.footer_column {
	width: 100%;
	margin-top: 0px;
}
.parallax {
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 40%;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 100%;
	font-size: 18px;
}
.parallax_description {
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 90%;
	margin-top: 25px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 12px;
	float: none;
	text-align: center;
}
.banner {
	background-color: #2D9AB7;
	background-image: none;
}
.tagline {
	margin-top: 20px;
	line-height: 22px;
}
.hero_header {
	padding-left: 10px;
	padding-right: 10px;
	line-height: 22px;
	text-align: center;
}
}

/* Small Tablets */
@media (min-width: 321px)and (max-width: 767px) {
.logo {
	width: 100%;
	text-align: center;
	margin-top: 13px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	color: #043745;
}
.container header nav {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	float: none;
	overflow: auto;
	display: inline-block;
	background: #52bad5;
}
header nav ul {
	padding: 0px;
	float: none;
}
nav ul li {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	text-align: center;
	padding-top: 8px;
	padding-bottom: 8px;
}
.text_column {
	width: 100%;
	text-align: left;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.thumbnail {
	width: 100%;
}
.footer_column {
	width: 100%;
	margin-top: 0px;
}
.parallax {
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 40%;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 100%;
	font-size: 18px;
}
.parallax_description {
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	margin-top: 30%;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	float: none;
	width: 100%;
	text-align: center;
}
.thumbnail {
	width: 50%;
}
.parallax {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	padding-top: 20%;
}
.parallax_description {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	padding-top: 30px;
}
.banner {
	padding-left: 20px;
	padding-right: 20px;
}
.footer_column {
	width: 100%;
}
}

/* Small Desktops */
@media (min-width: 768px) and (max-width: 1096px) {
.text_column {
	width: 100%;
}
.thumbnail {
	width: 50%;
}
.text_column {
	width: 100%;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.banner {
	margin-top: 0px;
	padding-top: 0px;
}
	.about-card {
  max-width: 880px;
  margin: 0 auto;               /* センター寄せ */
  padding: 24px 20px;
  background: #f9f9f9;          /* 淡いグレー（必要なら園カラーに変更可） */
  border: 1px solid #ddd;       /* 薄いグレーの枠線 */
  border-radius: 16px;          /* 角丸 */
  box-shadow: 0 4px 10px rgba(0,0,0,.05); /* ほんのり影 */
}

}
.about-card {
  max-width: 880px;
  margin: 0 auto;
  padding: 24px 20px;
}

.block {
  margin-bottom: 24px;
  padding: 18px 16px;
  background: #f9f9f9;         /* 淡い背景色 */
  border: 1px solid #ddd;      /* 薄いグレーの枠線 */
  border-radius: 16px;         /* 角丸 */
  box-shadow: 0 4px 10px rgba(0,0,0,.05);
}

.block h3 {
  margin: 0 0 12px;
  font-size: 1.3rem;
  color: #5e4d2a;
}

.dl {
  display: grid;
  grid-template-columns: 9em 1fr;
  gap: 8px 14px;
  margin: 0;
}
.dl dt { font-weight: 700; }
.dl dd { margin: 0; }

@media (max-width:640px){
  .dl { grid-template-columns: 1fr; }
}

/* ====== 修正1：containerが邪魔しないように ====== */
.container {
  max-width: 1040px;  /* 任意で */
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
  background: transparent !important; /* 白背景を解除 */
  height: auto !important;            /* 固定高さを解除 */
}

/* ====== 修正2：セクションをカード化（余白＋背景＋半透明枠） ====== */
.section {
  padding: 64px 40px;                        /* ガッツリ内側余白 */
  margin-top: 5em;                           /* セクション間の余白 */
  background-color: rgba(245, 249, 255, 0.9);/* 淡い背景色（透け感あり） */
  border: 2px solid rgba(207, 227, 255, 0.6);/* 半透明の枠線 */
  border-radius: 20px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}

/* 次のセクションとの間もゆったり */
.section + .section {
  margin-top: 5em;
}

/* ====== 内側カード（概要／保育など） ====== */
.about-card {
  max-width: 880px;
  margin: 3em auto 0;     /* 上にガッツリ余白＋センター */
  padding: 32px 24px;
  background: #fff;
  border: 1.5px solid rgba(207,227,255,0.5);
  border-radius: 16px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.04);
}

/* 定義リストのレイアウト（常時有効に） */
.dl {
  display: grid;
  grid-template-columns: 9em 1fr;
  gap: 12px 20px;
  margin: 0;
}
.dl dt { font-weight: 700; }
.dl dd { margin: 0; }

@media (max-width: 640px){
  .dl { grid-template-columns: 1fr; }
}

/* 基本方針/目標のブロックもカード調に */
.block {
  margin-bottom: 24px;
  padding: 20px 18px;
  background: #ffffff;
  border: 1.5px solid rgba(207,227,255,0.5);
  border-radius: 16px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.04);
}
/* ===== 強制リセット（競合つぶし） ===== */

/* containerの白背景＆固定高さを無効化 */
.container{
  background: transparent !important;
  height: auto !important;
  max-width: 1040px; /* 任意 */
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
}

/* セクションを“囲みカード”に：余白/背景/半透明枠 */
section.section{
  padding: 64px 40px !important;                  /* ガッツリ内側余白 */
  margin-top: 5em !important;                     /* セクション間の余白 */
  background: rgba(245,249,255,0.9) !important;   /* 淡い背景＋透け感 */
  border: 2px solid rgba(207,227,255,0.6) !important; /* 半透明の枠線 */
  border-radius: 20px !important;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06) !important;
}

/* セクション内の見出しまわり：既存のオレンジ枠/背景を打ち消す */
.section .sec-head,
.section .sec-title{
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* サブカード（概要/保育）を読みやすく */
.section .about-card{
  max-width: 880px !important;
  margin: 3em auto 0 !important;       /* ガッツリ上余白＋中央寄せ */
  padding: 32px 24px !important;
  background: #fff !important;
  border: 1.5px solid rgba(207,227,255,0.5) !important;
  border-radius: 16px !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.04) !important;
}

/* 方針・目標のブロックもカード調に統一 */
.section .block{
  margin-bottom: 24px !important;
  padding: 20px 18px !important;
  background: #fff !important;
  border: 1.5px solid rgba(207,227,255,0.5) !important;
  border-radius: 16px !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.04) !important;
}

/* 定義リスト（概要）レイアウト */
.dl{
  display: grid !important;
  grid-template-columns: 9em 1fr !important;
  gap: 12px 20px !important;
  margin: 0 !important;
}
.dl dt{ font-weight: 700 !important; }
.dl dd{ margin: 0 !important; }

@media (max-width: 640px){
  .dl{ grid-template-columns: 1fr !important; }
}


/* ====== Bootstrapなし用の最小ボタン＆カード ====== */
.cta-wrap{
  display:flex; gap:10px; flex-wrap:wrap; margin-top:10px;
}

.btn{
  display:inline-block;
  padding: 10px 16px;
  border-radius: 999px;
  background: linear-gradient(180deg, #e9fbff 0%, #c4f3f1 100%);
  border:1px solid rgba(0,0,0,.06);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  font-weight:700;
  color: var(--c-text-strong, #3e311a);
  text-decoration:none;
  line-height:1;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, opacity .2s;
}
.btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  background: linear-gradient(180deg, #d6f6f3 0%, #bff0ee 100%);
}
.btn.secondary{
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

.cards{ display:grid; gap:16px; }
.card{
  border:1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background:#fff;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}
.card .pad{ padding:16px 20px; }


/* ===== kosodate: ボタン/タブ 共通スタイル（singlePagesTemplate.css の末尾に貼る） ===== */

/* 汎用ボタン（PDFの「開く」「ダウンロード」など） */
body.kosodate .btn{
  display:inline-block;
  padding:10px 18px;
  border-radius:999px;
  background:linear-gradient(180deg,#e9fbff 0%,#d6f6f3 100%);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  font-weight:700;
  color:var(--c-text-strong,#3e311a);
  text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
body.kosodate .btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  background:linear-gradient(180deg,#d6f6f3 0%,#c4f3f1 100%);
}
body.kosodate .btn.secondary{
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  box-shadow:0 4px 12px rgba(0,0,0,.06);
}
body.kosodate .cta-wrap{ display:flex; gap:10px; flex-wrap:wrap; }

/* ページ内ジャンプの丸ボタン（feature-buttons） */
body.kosodate .feature-buttons{
  display:flex; gap:10px; justify-content:center; padding:16px; flex-wrap:wrap;
}
body.kosodate .feature-buttons .fbtn{
  display:inline-block; padding:10px 16px;
  border-radius:999px; background:#fff;
  border:1px solid rgba(0,0,0,.12);
  font-weight:700; color:#3e311a; text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
body.kosodate .feature-buttons .fbtn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
body.kosodate .feature-buttons .fbtn.is-active,
body.kosodate .feature-buttons .fbtn[aria-current="true"]{
  background:linear-gradient(180deg,#d6f6f3 0%,#c4f3f1 100%);
  border-color:transparent;
}

/* 上部タブ（main-tabs） */
body.kosodate .main-tabs .tabs-wrap{
  max-width:min(1120px,92vw);
  margin:0 auto; padding:16px;
  display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:14px;
}
body.kosodate .main-tabs a{
  display:flex; align-items:center; justify-content:center;
  padding:14px 26px; min-height:56px;
  border-radius:999px;
  background:linear-gradient(180deg,#e9fbff 0%,#d6f6f3 100%);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  font-weight:700; color:#3e311a; text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
body.kosodate .main-tabs a:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  background:linear-gradient(180deg,#d6f6f3 0%,#c4f3f1 100%);
}
body.kosodate .main-tabs a.is-active{
  background:linear-gradient(180deg,#d6f6f3 0%,#c4f3f1 100%);
  border-color:transparent;
}

/* （任意）上に戻るボタンの見た目だけここで統一するなら */
body.kosodate #backToTop{
  position:fixed; bottom:24px; right:24px; width:48px; height:48px;
  border:none; border-radius:50%;
  background:linear-gradient(180deg,#e9fbff 0%,#c4f3f1 100%);
  color:#3e311a; font-size:1.4rem; font-weight:700; cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.12);
  display:none; z-index:1000;
  transition:opacity .3s ease, transform .2s ease;
}
body.kosodate #backToTop:hover{ transform:translateY(-3px); }


/* ===== 印刷用スタイル（全ページ共通） ===== */
@media print {
  /* 基本：白黒でスッキリ */
  html, body {
    background: #fff !important;
    color: #000 !important;
  }
  * {
    box-shadow: none !important;
    text-shadow: none !important;
  }

  /* 画面専用要素は非表示（ヘッダー/ヒーロー/タブ/戻るボタン等） */
  header,
  .main-tabs,
  .feature-buttons,
  .hero,
  #backToTop,
  nav[aria-label="主要ナビゲーション"],
  .cta-wrap,
  footer {
    display: none !important;
  }

  /* 枠や背景を外して本文だけに */
  .section {
    padding: 0 !important;
    margin: 0 0 12mm 0 !important;    /* セクション間の余白だけ少し残す */
    border: 0 !important;
    background: transparent !important;
  }
  .container {
    max-width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
  }

  /* 見出しや本文の改ページ制御 */
  h2, h3 { page-break-after: avoid; }
  section, article { page-break-inside: avoid; }
  img { page-break-inside: avoid; break-inside: avoid; max-width: 100% !important; height: auto !important; }

  /* リンク先URLも紙に出したい場合（外部リンクのみ） */
  a[href^="http"]:after {
    content: " (" attr(href) ")";
    font-size: 0.9em;
  }
  a {
    color: #000 !important;
    text-decoration: underline !important;
  }

  /* 用紙設定（A4/余白） */
  @page {
    size: A4;
    margin: 15mm; /* 必要に応じて 10–20mm で調整 */
  }
}




