@charset "UTF-8";
/*
 * ======================================
 * つみき保育園 サイト固有CSS（site.css）
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * ======================================
 *
 * .tsumiki-header / -utilbar / -navrow / -gnav / -brand   - 中央ロゴ＋両サイド分割アイコンナビのヘッダー
 * .tsumiki-footer ほか                                     - みんさー帯＋3カラム（情報/ACCESS/MAP）フッター
 * .tsumiki-eyebrow / -sechead / -accent                    - 小英字ラベル＋日本語見出し（中央/左）
 * .tsumiki-btn(--primary/-ghost/-sun)                      - ピル型ボタン3種（ROS .btn と衝突回避のため別名）
 * .tsumiki-section--*                                      - 海ベースのセクション背景（cream/sea/seagrad/sea-soft）
 * .tsumiki-wcaccent / -blob / -hero__deco                  - 水彩あしらい・浮遊装飾の配置（インラインstyle排除のため個別class化）
 * .tsumiki-hero ほか                                        - 3楕円スライドのメインビュー
 * .tsumiki-about / -feat / -dayring / -event / -newslist   - TOP各セクション
 * .tsumiki-flow3 / -admnote / -cta / -crumbs               - 入園フロー・CTA・パンくず
 * .tsumiki-tl(timeline) / -yeargrid / -regular             - 一日の流れ（中央線）・年間行事
 * .tsumiki-gal / -lightbox / -gate / -pg                   - ギャラリー・ライトボックス・保護者ゲート
 * .tsumiki-philosophy / -goals / -featlist / -onbutsu / -ritspo - 教育方針ページ
 * .tsumiki-subsc / -pdf / -topic / -admission              - お知らせページ
 * .c-* (色modifier)                                         - カードのアクセント色（インライン --c 排除用）
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類で整理）
 * ======================================
 * ・構造不足：中央ロゴ＋左右分割アイコンナビ型ヘッダー / 3楕円スライドMV / 円形フロー図 / 中央線タイムライン
 * ・装飾パターン不足：みんさー柄帯（4色repeat）/ 水彩モチーフの自由配置 / SVG波・blob境界
 * ・値の粒度不足：角丸22〜30px帯・section 96px等（共通は120px）
 * ・状態不足：保護者パスワードゲートの解錠表示切替（JS連動 .show/.hide）
 *   → いずれも案件固有色・配置が強いため site.css で対応。汎用化の余地は「円形フロー図」「中央線タイムライン」。
 */

/* ============ パレットトークン ============ */
:root{
  --sea:#ddebf1; --sea-50:#f3f9fc; --sea-100:#eaf4f8; --sea-200:#cfe6ef; --sea-300:#b6d8e6;
  --ocean:#2e8bbf; --ocean-deep:#1d6d99; --ocean-ink:#15536f;
  --ink:#41555f; --ink-soft:#454c50; --cream:#fdfbf6; --white:#fff;
  --t-red:#ef9685; --t-yellow:#f6c75b; --t-green:#93c97e; --t-blue:#79c1e8; --hibiscus:#f08a8a;
  --shadow-sm:0 4px 14px rgba(29,109,153,.08);
  --shadow-md:0 10px 30px rgba(29,109,153,.12);
  --shadow-lg:0 18px 50px rgba(29,109,153,.16);
  --tradius:22px; --tradius-lg:30px; --tmaxw:1200px;
}

/* body 全体のなじみ */
.is-nav-open{ overflow:hidden; }

/* ============ ボタン（ピル型） ============ */
.tsumiki-btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:"Zen Maru Gothic",sans-serif; font-weight:700;
  padding:16px 34px; border-radius:999px; font-size:16px; line-height:1.4;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  cursor:pointer; border:none;
}
.tsumiki-btn svg{ width:18px; height:18px; }
.tsumiki-btn:hover{ opacity:1; }
.tsumiki-btn--primary{ background:var(--ocean); color:#fff; box-shadow:var(--shadow-md); }
.tsumiki-btn--primary:hover{ background:var(--ocean-deep); transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.tsumiki-btn--ghost{ background:#fff; color:var(--ocean-deep); box-shadow:var(--shadow-sm); border:2px solid var(--sea-300); }
.tsumiki-btn--ghost:hover{ background:var(--sea-50); transform:translateY(-2px); }
.tsumiki-btn--sun{ background:var(--t-yellow); color:#6b4a12; box-shadow:0 10px 24px rgba(246,199,91,.35); }
.tsumiki-btn--sun:hover{ transform:translateY(-2px); box-shadow:0 14px 30px rgba(246,199,91,.45); }
.tsumiki-btn--full{ width:100%; justify-content:center; }

/* ============ セクション共通 ============ */
.tsumiki-wrap{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:0 28px; }
.tsumiki-section{ padding:96px 0; position:relative; overflow:hidden; }
.tsumiki-section > .container,
.tsumiki-section > .tsumiki-wrap{ position:relative; z-index:2; }
.tsumiki-section--cream{ background:var(--cream); }
.tsumiki-section--sea{ background:var(--sea); }
.tsumiki-section--seagrad{ background:linear-gradient(180deg,var(--sea-100) 0%, var(--sea) 48%, var(--sea-300) 100%); }
.tsumiki-section--sea-soft{ background:linear-gradient(180deg,var(--sea-50),var(--sea-100)); }
.tsumiki-section--compact{ padding:60px 0; }
.tsumiki-section--pt-sm{ padding-top:48px; }

/* 水彩あしらい（背面配置） */
.tsumiki-wcaccent{ position:absolute; pointer-events:none; user-select:none; z-index:1; display:block; }
.tsumiki-wcaccent--about{ width:168px; right:14px; bottom:10px; opacity:.95; }
.tsumiki-wcaccent--onbutsu{ width:200px; right:18px; bottom:12px; opacity:.95; }

/* ============ 見出し（eyebrow + sechead） ============ */
.tsumiki-eyebrow{
  font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:14px; letter-spacing:.28em;
  color:var(--ocean); text-transform:uppercase;
  display:flex; align-items:center; gap:10px; justify-content:center;
}
.tsumiki-eyebrow::before,.tsumiki-eyebrow::after{
  content:""; width:26px; height:2px; border-radius:2px; background:var(--ocean); opacity:.5;
}
.tsumiki-eyebrow--left{ justify-content:flex-start; }
.tsumiki-eyebrow--left::before{ display:none; }
.tsumiki-sechead{ text-align:center; margin-bottom:54px; }
.tsumiki-sechead h2,.tsumiki-sechead__title{
  font-size:34px; font-weight:700; color:var(--ocean-ink); margin:14px 0 0; letter-spacing:.06em; line-height:1.5;
}
.tsumiki-accent{ color:var(--ocean); }
.tsumiki-sechead__lead{ margin:16px auto 0; max-width:680px; color:var(--ink-soft); font-size:16px; }
.tsumiki-note{ color:var(--ink-soft); font-size:14px; }

/* ============ ヘッダー ============ */
.tsumiki-header{ position:sticky; top:0; z-index:100; background:rgba(253,251,246,.96); backdrop-filter:blur(8px); }
.tsumiki-utilbar{ background:var(--ocean-ink); color:#dff0f6; }
.tsumiki-utilbar__inner{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:0 28px; height:40px; display:flex; align-items:center; justify-content:space-between; }
.tsumiki-utilbar__tag{ font-size:14px; letter-spacing:.1em; opacity:.85; }
.tsumiki-utilbar__contact{ display:flex; align-items:center; gap:16px; }
.tsumiki-utilbar__tel{ display:inline-flex; align-items:center; gap:8px; font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:16px; color:#fff; }
.tsumiki-utilbar__tel:hover{ opacity:.85; }
.tsumiki-utilbar__map{ display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.16); padding:6px 14px; border-radius:999px; font-weight:700; font-size:14px; color:#fff; transition:.15s; }
.tsumiki-utilbar__map:hover{ background:rgba(255,255,255,.3); opacity:1; }
.tsumiki-utilbar__lang{ font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:14px; color:#fff; opacity:.85; }
.tsumiki-utilbar__lang:hover{ opacity:1; text-decoration:underline; }

/* English ページ：英字主体 */
.en-page{ font-family:"M PLUS 1p",sans-serif; }
.en-page .tsumiki-sechead h2,.en-page .tsumiki-pagehero h1,.en-page .tsumiki-gnav__label,.en-page .tsumiki-brand__ja{ font-family:"M PLUS 1p",sans-serif; }
.tsumiki-intro h2{ font-size:28px; }

.tsumiki-navrow{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:0 28px; min-height:100px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px; }
.tsumiki-gnav{ display:flex; align-items:center; gap:4px; }
.tsumiki-gnav--left{ justify-content:flex-end; }
.tsumiki-gnav--right{ justify-content:flex-start; }
.tsumiki-gnav__link{ display:flex; flex-direction:column; align-items:center; gap:6px; padding:8px 10px; border-radius:16px; transition:.15s; text-align:center; min-width:78px; line-height:1.25; }
.tsumiki-gnav__link:hover{ background:var(--sea-100); transform:translateY(-1px); opacity:1; }
.tsumiki-gnav__ic{ width:42px; height:42px; border-radius:14px; display:flex; align-items:center; justify-content:center; transition:.15s; }
.tsumiki-gnav__ic svg{ width:23px; height:23px; }
.tsumiki-gnav__ic--red{ background:rgba(239,150,133,.2); color:#e07a64; }
.tsumiki-gnav__ic--yellow{ background:rgba(246,199,91,.26); color:#d09a22; }
.tsumiki-gnav__ic--green{ background:rgba(147,201,126,.28); color:#549a3b; }
.tsumiki-gnav__ic--blue{ background:rgba(121,193,232,.24); color:#2f86b0; }
.tsumiki-gnav__label{ font-size:14px; font-weight:700; color:var(--ink); letter-spacing:.01em; white-space:nowrap; }
.tsumiki-gnav__link--en .tsumiki-gnav__label{ font-family:"M PLUS 1p",sans-serif; letter-spacing:.06em; }

/* 現在地ハイライト */
body[data-page="top"] .nav-top .tsumiki-gnav__label,
body[data-page="policy"] .nav-policy .tsumiki-gnav__label,
body[data-page="schedule"] .nav-schedule .tsumiki-gnav__label,
body[data-page="news"] .nav-news .tsumiki-gnav__label,
body[data-page="gallery"] .nav-gallery .tsumiki-gnav__label,
body[data-page="english"] .nav-english .tsumiki-gnav__label{ color:var(--ocean-deep); }

/* 中央ロゴ */
.tsumiki-brand{ display:flex; flex-direction:column; align-items:center; gap:5px; padding:6px 10px; }
.tsumiki-brand__logo{ width:54px; height:54px; }
.tsumiki-brand__text{ display:flex; flex-direction:column; align-items:center; line-height:1.15; }
.tsumiki-brand__ja{ font-weight:700; font-size:22px; color:var(--ocean-ink); letter-spacing:.06em; white-space:nowrap; }
.tsumiki-brand__en{ font-family:"M PLUS 1p",sans-serif; font-size:14px; letter-spacing:.28em; color:var(--ocean); font-weight:700; white-space:nowrap; }
.tsumiki-brand:hover{ opacity:1; }

/* ============ フッター ============ */
.tsumiki-footer{ background:var(--ocean-ink); color:#d7e8f0; }
.tsumiki-minsaband{ height:34px; width:100%; background:url("https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28244/minsa_line.png") repeat-x center; background-size:auto 100%; }
/* セクション上下のミンサーライン装飾（画像を白抜きにして表示） */
.tsumiki-section--minsaline::before,
.tsumiki-section--minsaline::after{ content:""; position:absolute; left:0; right:0; height:34px; background:url("https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28244/minsa_line.png") repeat-x center; background-size:auto 100%; filter:brightness(0) invert(1); pointer-events:none; z-index:1; }
.tsumiki-section--minsaline::before{ top:0; }
.tsumiki-section--minsaline::after{ bottom:0; }
.tsumiki-footer__inner{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:64px 28px 28px; display:grid; grid-template-columns:1.1fr 1fr 1fr; gap:48px; }
.tsumiki-footer__block .tsumiki-brand--footer{ flex-direction:row; align-items:center; gap:12px; margin-bottom:18px; justify-content:flex-start; }
.tsumiki-brand--footer .tsumiki-brand__logo{ width:46px; height:46px; }
.tsumiki-brand--footer .tsumiki-brand__text{ align-items:flex-start; }
.tsumiki-brand--footer .tsumiki-brand__ja{ color:#fff; font-size:21px; letter-spacing:.04em; }
.tsumiki-brand--footer .tsumiki-brand__en{ color:var(--sea-300); letter-spacing:.22em; }
.tsumiki-footer__h{ font-size:14px; letter-spacing:.18em; color:var(--sea-300); margin:0 0 16px; font-weight:700; }
.tsumiki-footer__info{ font-size:14px; line-height:2; margin:0 0 14px; }
.tsumiki-footer__info--lead{ opacity:.85; }
.tsumiki-footer__sub{ font-size:14px; opacity:.8; }
.tsumiki-footer__label{ font-size:14px; letter-spacing:.18em; color:var(--sea-300); font-weight:700; }
.tsumiki-footer__num{ font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:22px; color:#fff; }
.tsumiki-footer__num:hover{ opacity:.85; }
.tsumiki-footer__map{ border-radius:18px; overflow:hidden; min-height:170px; box-shadow:0 10px 30px rgba(0,0,0,.2); }
.tsumiki-footer__map iframe{ width:100%; height:100%; min-height:170px; border:0; display:block; }
.tsumiki-footer__bottom{ border-top:1px solid rgba(255,255,255,.14); }
.tsumiki-footer__bottom-inner{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:18px 28px; display:flex; justify-content:space-between; align-items:center; font-size:14px; color:var(--sea-300); }
.tsumiki-footer__bottom-en{ font-family:"M PLUS 1p",sans-serif; }

/* ============ パンくず ============ */
.tsumiki-crumbs{ width:100%; max-width:var(--tmaxw); margin:0 auto; padding:18px 28px; font-size:14px; color:var(--ink-soft); display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.tsumiki-crumbs a{ color:var(--ink-soft); }
.tsumiki-crumbs a:hover{ color:var(--ocean-deep); opacity:1; }
.tsumiki-crumbs .sep{ opacity:.5; }

/* ============ 下層ページヒーロー ============ */
.tsumiki-pagehero{ background:var(--sea); position:relative; overflow:hidden; }
.tsumiki-pagehero__inner{ position:relative; z-index:2; padding:64px 28px 76px; text-align:center; width:100%; max-width:var(--tmaxw); margin:0 auto; }
.tsumiki-pagehero .tsumiki-eyebrow{ justify-content:center; }
/* eyebrow 両サイドの装飾線を消すモディファイア（この要素だけに適用） */
.tsumiki-eyebrow--noline::before,
.tsumiki-eyebrow--noline::after{ display:none; }
.tsumiki-pagehero h1{ font-size:40px; color:var(--ocean-ink); margin:14px 0 0; letter-spacing:.06em; }
.tsumiki-pagehero__lead{ margin:14px auto 0; max-width:680px; color:var(--ocean-ink); opacity:.8; }
.tsumiki-blob{ position:absolute; opacity:.5; }
.tsumiki-blob--tr{ width:160px; height:160px; right:8%; top:-30px; }
.tsumiki-blob--tr2{ width:150px; height:150px; right:9%; top:-20px; }
.tsumiki-blob--bl{ width:90px; height:90px; left:6%; bottom:10px; transform:rotate(12deg); opacity:.35; border-radius:22px; }
.tsumiki-blob--bl2{ width:80px; height:80px; left:7%; bottom:6px; opacity:.4; border-radius:22px; }
.tsumiki-blob--yellow{ background:var(--t-yellow); }
.tsumiki-blob--green{ background:var(--t-green); transform:rotate(-10deg); }
.tsumiki-blob--blue{ background:var(--t-blue); transform:rotate(8deg); }
.tsumiki-blob--hibiscus{ background:var(--hibiscus); transform:rotate(-8deg); }

/* SVG波の区切り */
.tsumiki-wave{ display:block; width:100%; height:60px; }
.tsumiki-wave svg{ width:100%; height:100%; display:block; }

/* ============ 写真プレースホルダ（ギャラリー用） ============ */
.ph{ position:relative; border-radius:var(--tradius); overflow:hidden; background:radial-gradient(120% 120% at 0% 0%, var(--sea-200), transparent 60%), linear-gradient(135deg, var(--sea-100), var(--sea-300)); display:flex; align-items:center; justify-content:center; color:var(--ocean-deep); }
.ph__inner{ text-align:center; padding:18px; }
.ph__label{ font-size:14px; font-weight:700; letter-spacing:.04em; opacity:.85; line-height:1.6; }
.ph__note{ font-size:14px; color:var(--ocean); opacity:.7; margin-top:4px; font-family:"M PLUS 1p",sans-serif; }

/* =========================================================
   TOPページ
   ========================================================= */
/* ----- ヒーロー（3楕円スライド） ----- */
.tsumiki-hero{ background:linear-gradient(180deg,var(--sea) 0%, var(--sea-50) 100%); position:relative; overflow:hidden; display:flex; flex-direction:column; }
.tsumiki-hero__foam{ display:block; width:100%; height:42px; order:0; }
.tsumiki-hero__foam svg{ width:100%; height:100%; display:block; }
.tsumiki-hero__copy{ order:2; text-align:center; max-width:880px; margin:0 auto; padding:30px 28px 30px; position:relative; z-index:5; }
.tsumiki-hero__badge{ display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--ocean-deep); font-weight:700; font-size:14px; padding:8px 18px; border-radius:999px; box-shadow:var(--shadow-sm); letter-spacing:.04em; }
.tsumiki-hero__badge svg{ width:16px; height:16px; }
.tsumiki-hero__copy h1{ font-size:39px; line-height:1.5; color:var(--ocean-ink); margin:20px 0 0; letter-spacing:.04em; font-weight:700; }
.tsumiki-hero__hl{ background:linear-gradient(transparent 62%, rgba(246,199,91,.55) 62%); padding:0 .12em; }
.tsumiki-hero__copy p{ margin:18px auto 0; font-size:16px; color:var(--ocean-ink); opacity:.85; max-width:660px; }
.tsumiki-hero__wave{ order:3; display:block; width:100%; height:60px; }
.tsumiki-hero__wave svg{ width:100%; height:100%; display:block; }

.tsumiki-hero__stage{ order:1; position:relative; height:572px; margin-top:18px; }
.tsumiki-ell{ position:absolute; top:50%; border-radius:50%; overflow:hidden; background:var(--sea-200); border:8px solid #fff; box-shadow:var(--shadow-md); }
.tsumiki-ell--center{ left:50%; transform:translate(-50%,-50%); width:800px; height:520px; z-index:3; }
.tsumiki-ell--left{ left:-100px; transform:translateY(-50%); width:400px; height:316px; z-index:2; }
.tsumiki-ell--right{ right:-100px; transform:translateY(-50%); width:400px; height:316px; z-index:2; }
.tsumiki-ell__slide{ position:absolute; inset:0; opacity:0; transition:opacity .8s ease; }
.tsumiki-ell__slide.is-active{ opacity:1; }
.tsumiki-ell__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.tsumiki-ell__tag{ position:absolute; left:50%; transform:translateX(-50%); bottom:24px; z-index:4; background:rgba(255,255,255,.93); color:var(--ocean-deep); font-weight:700; font-size:14px; padding:6px 16px; border-radius:999px; box-shadow:var(--shadow-sm); white-space:nowrap; }
.tsumiki-ell--left .tsumiki-ell__tag,.tsumiki-ell--right .tsumiki-ell__tag{ display:none; }
.tsumiki-stage-dots{ position:absolute; left:50%; transform:translateX(-50%); bottom:6px; display:flex; gap:9px; z-index:6; }
.tsumiki-stage-dots button{ width:11px; height:11px; border-radius:999px; border:none; background:#fff; opacity:.6; cursor:pointer; padding:0; transition:.2s; box-shadow:var(--shadow-sm); }
.tsumiki-stage-dots button.is-active{ opacity:1; background:var(--ocean); width:30px; }

/* 海の装飾モチーフ */
.tsumiki-hero__deco{ position:absolute; z-index:4; pointer-events:none; }
.tsumiki-hero__deco--ball{ width:100px; left:22%; top:14px; transform:rotate(-6deg); }
.tsumiki-hero__deco--palm{ width:112px; right:20%; top:8px; }
.tsumiki-hero__deco--turtle{ width:112px; left:12%; top:114px; transform:rotate(-8deg); }
.tsumiki-hero__deco--fish{ width:114px; right:11%; top:114px; }
.tsumiki-hero__deco--hibiscus{ width:100px; left:21%; bottom:22px; }
.tsumiki-hero__deco--bouquet{ width:110px; right:20%; bottom:20px; transform:rotate(6deg); }
/* あしらい画像の間に配置する半透明白シェイプ（丸・四角・三角） */
.tsumiki-shape{ position:absolute; z-index:1; pointer-events:none; background:rgba(255,255,255,.9); }
.tsumiki-shape--square{ border-radius:8px; }
/* 角丸の三角形（SVG：太線＋stroke-linejoin:round で頂点を丸める） */
.tsumiki-shape--tri{ background:none; background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2048%2048'%3E%3Cpath%20d='M24%2010%20L40%2038%20L8%2038%20Z'%20fill='%23ffffff'%20stroke='%23ffffff'%20stroke-width='9'%20stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; background-size:contain; }
/* 四隅の余白に配置（中央・左右の楕円スライドと装飾画像の外側）。丸なし・四角／三角は角丸 */
.tsumiki-shape--1{ width:28px; height:28px; left:3%;  top:40px;  opacity:.8; }   /* 左上・四角 */
.tsumiki-shape--2{ width:22px; height:22px; left:9%;  top:95px;  opacity:.7; }   /* 左上・三角 */
.tsumiki-shape--3{ width:24px; height:24px; right:4%; top:46px;  opacity:.8; }   /* 右上・四角 */
.tsumiki-shape--4{ width:20px; height:20px; right:9%; top:100px; opacity:.7; }   /* 右上・三角 */
.tsumiki-shape--5{ width:26px; height:26px; left:4%;  top:480px; opacity:.72; }  /* 左下・四角 */
.tsumiki-shape--6{ width:20px; height:20px; left:9%;  top:522px; opacity:.65; }  /* 左下・三角 */
.tsumiki-shape--7{ width:24px; height:24px; right:4%; top:492px; opacity:.72; }  /* 右下・三角 */

/* ----- 新着情報（コンパクト横並び） ----- */
.tsumiki-newscompact{ display:grid; grid-template-columns:230px 1fr; gap:48px; align-items:start; max-width:1000px; margin:0 auto; }
.tsumiki-newscompact__head{ padding-top:4px; text-align:center; }
.tsumiki-newscompact__head .tsumiki-eyebrow{ justify-content:center; }
.tsumiki-newscompact__head h2{ font-size:30px; font-weight:700; color:var(--ocean-ink); margin:12px 0 18px; letter-spacing:.06em; }
.tsumiki-newscompact__all{ display:inline-flex; align-items:center; gap:6px; font-weight:700; color:var(--ocean-deep); font-size:14px; }
.tsumiki-newscompact__all svg{ width:16px; height:16px; }
.tsumiki-newscompact__list{ max-height:120px; overflow-y:auto; padding-right:10px; scrollbar-width:thin; scrollbar-color:var(--sea-300) transparent; }
.tsumiki-newscompact__list::-webkit-scrollbar{ width:6px; }
.tsumiki-newscompact__list::-webkit-scrollbar-thumb{ background:var(--sea-300); border-radius:999px; }
.tsumiki-newsitem{ display:flex; align-items:center; gap:22px; padding:16px 4px; border-bottom:1px solid var(--sea-100); transition:.15s; }
.tsumiki-newsitem:first-child{ padding-top:2px; }
.tsumiki-newsitem:last-child{ border-bottom:none; }
.tsumiki-newsitem:hover{ color:var(--ocean-deep); opacity:1; }
.tsumiki-newsitem__date{ font-family:"M PLUS 1p",sans-serif; font-size:14px; font-weight:700; color:#fff; background:var(--ocean); border-radius:999px; padding:5px 16px; flex:none; text-align:center; letter-spacing:.02em; }
.tsumiki-newsitem__ttl{ font-size:15px; color:var(--ink); flex:1; }

/* ----- About ----- */
.tsumiki-about{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.tsumiki-about__img{ width:100%; aspect-ratio:5/4; object-fit:cover; border-radius:var(--tradius); box-shadow:var(--shadow-sm); display:block; }
.tsumiki-about__copy h2{ font-size:30px; color:var(--ocean-ink); line-height:1.6; margin:14px 0 18px; }
.tsumiki-about__copy p{ color:var(--ink); margin:0; }
.tsumiki-about__copy .tsumiki-btn{ margin-top:28px; }

/* ----- 特色カード（カラーの淵） ----- */
.tsumiki-feat{ background:#fff; border-radius:var(--tradius); padding:30px; text-align:center; position:relative; border:3px solid var(--sea-300); box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease; overflow:hidden; }
.tsumiki-feat::before{ content:""; position:absolute; left:0; right:0; top:0; height:120px; background:rgba(121,193,232,.1); z-index:0; }
.tsumiki-feat:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.tsumiki-feat > *{ position:relative; z-index:1; }
.tsumiki-feat__img{ width:120px; height:120px; object-fit:contain; margin:4px auto 16px; display:block; }
.tsumiki-feat__badge{ display:inline-block; font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:14px; letter-spacing:.14em; color:#fff; background:var(--ocean); padding:4px 14px; border-radius:999px; margin-bottom:14px; }
.tsumiki-feat h3{ font-size:21px; color:var(--ocean-ink); margin:0 0 10px; }
.tsumiki-feat p{ font-size:15px; color:var(--ink-soft); margin:0; text-align:left; }
/* 特色カード色違い */
.tsumiki-feat--blue{ border-color:rgba(121,193,232,.4); }
.tsumiki-feat--blue::before{ background:rgba(121,193,232,.12); }
.tsumiki-feat--blue .tsumiki-feat__badge{ background:var(--t-blue); }
.tsumiki-feat--yellow{ border-color:rgba(246,199,91,.42); }
.tsumiki-feat--yellow::before{ background:rgba(246,199,91,.14); }
.tsumiki-feat--yellow .tsumiki-feat__badge{ background:var(--t-yellow); color:#6b4a12; }
.tsumiki-feat--green{ border-color:rgba(147,201,126,.42); }
.tsumiki-feat--green::before{ background:rgba(147,201,126,.16); }
.tsumiki-feat--green .tsumiki-feat__badge{ background:var(--t-green); }

/* ----- 一日の流れ（円リング＋左右写真） ----- */
.tsumiki-daystage{ position:relative; max-width:1120px; margin:0 auto; min-height:560px; }
.tsumiki-dayring{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:380px; height:380px; z-index:2; }
.tsumiki-dayring__dotted{ position:absolute; inset:0; border-radius:50%; border:2px dashed var(--sea-300); }
.tsumiki-daycenter{ position:absolute; inset:64px; border-radius:50%; background:#fff; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:18px; }
.tsumiki-daycenter__small{ font-family:"M PLUS 1p",sans-serif; font-size:13px; font-weight:700; color:var(--ocean); letter-spacing:.12em; }
.tsumiki-daycenter__big{ font-size:23px; font-weight:700; color:var(--ocean-ink); line-height:1.5; margin-top:8px; }
.tsumiki-daynode{ position:absolute; left:50%; top:50%; width:88px; height:88px; border-radius:50%; color:#fff; display:flex; align-items:center; justify-content:center; text-align:center; font-size:13px; font-weight:700; line-height:1.3; box-shadow:0 6px 16px rgba(29,109,153,.22); background:var(--ocean); }
.tsumiki-daynode--n1{ transform:translate(-50%,-50%) translate(0,-190px); background:var(--ocean); }
.tsumiki-daynode--n2{ transform:translate(-50%,-50%) translate(134px,-134px); background:var(--t-blue); }
.tsumiki-daynode--n3{ transform:translate(-50%,-50%) translate(190px,0); background:var(--t-green); }
.tsumiki-daynode--n4{ transform:translate(-50%,-50%) translate(134px,134px); background:var(--t-yellow); color:#6b4a12; }
.tsumiki-daynode--n5{ transform:translate(-50%,-50%) translate(0,190px); background:var(--hibiscus); }
.tsumiki-daynode--n6{ transform:translate(-50%,-50%) translate(-134px,134px); background:var(--ocean); }
.tsumiki-daynode--n7{ transform:translate(-50%,-50%) translate(-190px,0); background:var(--t-blue); }
.tsumiki-daynode--n8{ transform:translate(-50%,-50%) translate(-134px,-134px); background:var(--t-green); }
.tsumiki-dayphoto{ position:absolute; width:320px; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-md); border:5px solid #fff; z-index:1; }
.tsumiki-dayphoto img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.tsumiki-dayphoto--1{ left:8%; top:360px; transform:rotate(-5deg); }
.tsumiki-dayphoto--2{ left:8%; top:660px; transform:rotate(3deg); }
.tsumiki-dayphoto--3{ right:8%; top:360px; transform:rotate(5deg); }
.tsumiki-dayphoto--4{ right:8%; top:660px; transform:rotate(-3deg); }

/* ----- 年間行事（4枚カード） ----- */
.tsumiki-events{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.tsumiki-ev{ background:#fff; border-radius:18px; padding:20px; box-shadow:var(--shadow-sm); border-top:5px solid var(--t-blue); text-align:center; transition:transform .2s ease, box-shadow .2s ease; }
.tsumiki-ev:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tsumiki-ev__illwrap{ background:var(--sea-50); border-radius:14px; margin-bottom:14px; overflow:hidden; }
.tsumiki-ev__ill{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.tsumiki-ev__season{ font-size:14px; font-weight:700; color:var(--ocean); font-family:"M PLUS 1p",sans-serif; letter-spacing:.1em; }
.tsumiki-ev__name{ font-size:17px; color:var(--ocean-ink); font-weight:700; margin-top:6px; }
.tsumiki-ev--hibiscus{ border-top-color:var(--hibiscus); }
.tsumiki-ev--hibiscus .tsumiki-ev__season{ color:var(--hibiscus); }
.tsumiki-ev--blue{ border-top-color:var(--t-blue); }
.tsumiki-ev--blue .tsumiki-ev__season{ color:var(--t-blue); }
.tsumiki-ev--yellow{ border-top-color:var(--t-yellow); }
.tsumiki-ev--yellow .tsumiki-ev__season{ color:#d9a52e; }
.tsumiki-ev--green{ border-top-color:var(--t-green); }
.tsumiki-ev--green .tsumiki-ev__season{ color:var(--t-green); }

/* ----- 入園フロー（丸番号＋矢印） ----- */
.tsumiki-flow3{ display:flex; align-items:flex-start; justify-content:center; gap:0; max-width:720px; margin:0 auto; }
.tsumiki-flow3__step{ display:flex; flex-direction:column; align-items:center; text-align:center; width:180px; }
.tsumiki-flow3__ring{ width:104px; height:104px; border-radius:50%; background:var(--ocean); border:3px solid var(--ocean); display:flex; flex-direction:column; align-items:center; justify-content:center; box-shadow:var(--shadow-sm); }
.tsumiki-flow3__ring--green{ background:var(--t-green); border-color:var(--t-green); }
.tsumiki-flow3__ring--hibiscus{ background:var(--hibiscus); border-color:var(--hibiscus); }
.tsumiki-flow3__lab{ font-family:"M PLUS 1p",sans-serif; font-size:12px; font-weight:700; letter-spacing:.14em; color:#fff; opacity:.9; }
.tsumiki-flow3__num{ font-family:"M PLUS 1p",sans-serif; font-size:36px; font-weight:700; color:#fff; line-height:1; }
.tsumiki-flow3__step h3{ font-size:18px; color:var(--ocean-ink); margin:16px 0 0; }
.tsumiki-flow3__conn{ display:flex; align-items:center; justify-content:center; padding:44px 8px 0; }
.tsumiki-flow3__conn svg{ width:30px; height:30px; color:var(--sea-300); }
.tsumiki-admnote{ background:var(--sea-100); border-radius:18px; padding:18px 30px; text-align:center; margin:30px auto 0; width:fit-content; max-width:100%; color:var(--ocean-ink); font-size:15px; }
.tsumiki-admnote b{ color:var(--ocean-deep); }

/* 入園セクション両サイド背景 */
.tsumiki-admbg{ position:absolute; top:0; bottom:0; height:100%; width:auto; max-width:460px; object-fit:contain; z-index:1; pointer-events:none; user-select:none; opacity:.7; }
.tsumiki-admbg--l{ left:0; }
.tsumiki-admbg--r{ right:0; }

/* ----- CTA ----- */
.tsumiki-cta{ background:linear-gradient(135deg,var(--ocean),var(--ocean-deep)); border-radius:var(--tradius-lg); padding:60px; text-align:center; color:#fff; position:relative; overflow:hidden; }
.tsumiki-cta h2{ font-size:32px; margin:0 0 10px; letter-spacing:.04em; }
.tsumiki-cta p{ opacity:.92; margin:0 0 30px; }
.tsumiki-cta__actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.tsumiki-cta__tel{ margin-top:24px; font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:24px; color:#fff; display:inline-flex; gap:10px; align-items:center; }
.tsumiki-cta__tel:hover{ opacity:.85; }

/* =========================================================
   一日の流れ・年間行事ページ（schedule）
   ========================================================= */
.tsumiki-tl{ max-width:760px; margin:0 auto; position:relative; }
.tsumiki-tl::before{ content:""; position:absolute; left:114px; top:14px; bottom:14px; width:3px; background:var(--sea-300); border-radius:3px; }
.tsumiki-tl__row{ display:grid; grid-template-columns:96px 40px 1fr; align-items:flex-start; gap:0; margin-bottom:18px; }
.tsumiki-tl__time{ font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:17px; color:var(--ocean-deep); text-align:right; padding-right:14px; padding-top:14px; }
.tsumiki-tl__dot{ position:relative; display:flex; justify-content:center; padding-top:18px; }
.tsumiki-tl__dot span{ width:16px; height:16px; border-radius:999px; background:#fff; border:4px solid var(--ocean); z-index:2; box-shadow:0 0 0 4px var(--sea-100); }
.tsumiki-tl__card{ background:#fff; border-radius:16px; padding:14px 22px; box-shadow:var(--shadow-sm); }
.tsumiki-tl__card .h{ font-size:17px; font-weight:700; color:var(--ocean-ink); }
.tsumiki-tl__card .d{ font-size:14px; color:var(--ink-soft); margin-top:2px; }
.tsumiki-tl__row--ext .tsumiki-tl__dot span{ border-color:var(--t-yellow); box-shadow:0 0 0 4px rgba(246,199,91,.18); }
.tsumiki-tl__row--ext .tsumiki-tl__card{ background:#fffdf5; border:1px dashed var(--t-yellow); }
.tsumiki-tl__row--ext .tsumiki-tl__card .h{ color:#a9791a; }
.tsumiki-naras{ max-width:760px; margin:30px auto 0; padding:18px 26px; font-size:14px; color:var(--ocean-ink); display:flex; gap:12px; align-items:flex-start; justify-content:center; text-align:center; }
.tsumiki-naras svg{ width:22px; height:22px; flex:none; color:var(--ocean); margin-top:1px; }
/* タイムライン両サイドの写真（TOPと同じ雰囲気の傾き白フチ写真） */
.tsumiki-schedphoto{ position:absolute; width:320px; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-md); border:5px solid #fff; z-index:1; }
.tsumiki-schedphoto img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.tsumiki-schedphoto--1{ left:2%; top:300px; width:320px; transform:rotate(-4deg); }
.tsumiki-schedphoto--5{ left:3%; top:640px; width:255px; transform:rotate(3deg); }
.tsumiki-schedphoto--2{ left:1%; top:960px; width:290px; transform:rotate(3deg); }
.tsumiki-schedphoto--3{ right:2%; top:270px; width:295px; transform:rotate(4deg); }
.tsumiki-schedphoto--7{ right:3%; top:600px; width:230px; transform:rotate(-4deg); }
.tsumiki-schedphoto--4{ right:1%; top:930px; width:310px; transform:rotate(-3deg); }
.tsumiki-schedphoto--6{ left:2%;  top:1270px; width:300px; transform:rotate(3deg); }
.tsumiki-schedphoto--8{ right:2%; top:1245px; width:275px; transform:rotate(-3deg); }

.tsumiki-yeargrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.tsumiki-mon{ background:#fff; border-radius:18px; padding:18px 18px 20px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; text-align:center; border:1px solid rgba(29,109,153,.06); transition:transform .2s ease, box-shadow .2s ease; }
.tsumiki-mon:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tsumiki-mon__imgwrap{ background:var(--sea-50); border-radius:14px; margin-bottom:14px; overflow:hidden; }
.tsumiki-mon__img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.tsumiki-mon__num{ font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:14px; color:#fff; background:var(--ocean); display:inline-block; padding:3px 14px; border-radius:999px; }
.tsumiki-mon h3{ font-size:16px; color:var(--ocean-ink); margin:10px 0 0; line-height:1.5; }
.tsumiki-mon--hibiscus .tsumiki-mon__num{ background:var(--hibiscus); }
.tsumiki-mon--blue .tsumiki-mon__num{ background:var(--t-blue); }
.tsumiki-mon--yellow .tsumiki-mon__num{ background:var(--t-yellow); color:#6b4a12; }
.tsumiki-mon--green .tsumiki-mon__num{ background:var(--t-green); }
.tsumiki-regular{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:26px; }
.tsumiki-reg{ background:var(--sea-100); border-radius:16px; padding:20px 24px; display:flex; gap:14px; align-items:baseline; }
.tsumiki-reg .t{ display:inline-block; background:var(--ocean); color:#fff; border-radius:999px; padding:3px 16px; font-size:14px; font-weight:700; margin-bottom:8px; }
.tsumiki-reg .b{ font-size:15px; color:var(--ocean-ink); font-weight:700; }

/* =========================================================
   教育方針・特色ページ（policy）
   ========================================================= */
.tsumiki-philosophy{ background:#fff; border-radius:var(--tradius-lg); box-shadow:var(--shadow-md); padding:60px; text-align:center; position:relative; overflow:hidden; }
.tsumiki-philosophy__label{ display:inline-block; background:var(--ocean); color:#fff; font-size:18px; font-weight:700; letter-spacing:.2em; padding:8px 26px; border-radius:999px; }
.tsumiki-philosophy h2{ font-size:31px; color:var(--ocean-ink); line-height:1.7; margin:20px auto 0; max-width:800px; letter-spacing:.04em; }
.tsumiki-philosophy__rabbit{ position:absolute; left:2px; bottom:0; width:131px; height:auto; z-index:1; pointer-events:none; }
.tsumiki-philosophy__deco{ position:absolute; right:-20px; bottom:-16px; width:140px; opacity:.3; }
.tsumiki-philosophy__deco rect:nth-of-type(1){ fill:var(--t-red); }
.tsumiki-philosophy__deco rect:nth-of-type(2){ fill:var(--t-blue); }
.tsumiki-philosophy__deco rect:nth-of-type(3){ fill:var(--t-yellow); }
.tsumiki-goals{ display:grid; grid-template-columns:1fr 1fr; gap:18px 28px; }
.tsumiki-goal{ display:flex; gap:16px; align-items:flex-start; background:#fff; border-radius:18px; padding:22px 24px; box-shadow:var(--shadow-sm); }
.tsumiki-goal--full{ grid-column:1 / -1; }
.tsumiki-goal__no{ width:34px; height:34px; flex:none; border-radius:10px; background:var(--sea-100); color:var(--ocean-deep); display:flex; align-items:center; justify-content:center; font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:15px; }
.tsumiki-goal p{ margin:0; font-size:15.5px; color:var(--ink); line-height:1.7; }
.tsumiki-featlist{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.tsumiki-fl{ background:#fff; border-radius:var(--tradius); padding:28px; box-shadow:var(--shadow-sm); text-align:center; }
.tsumiki-fl__ic{ width:72px; height:72px; margin:0 auto 16px; border-radius:20px; display:flex; align-items:center; justify-content:center; }
.tsumiki-fl__ic svg{ width:36px; height:36px; }
.tsumiki-fl__ic--ocean{ background:rgba(121,193,232,.2); color:var(--ocean); }
.tsumiki-fl__ic--red{ background:rgba(239,150,133,.2); color:var(--t-red); }
.tsumiki-fl__ic--yellow{ background:rgba(246,199,91,.22); color:#d9a52e; }
.tsumiki-fl__ic--green{ background:rgba(147,201,126,.24); color:#5da043; }
.tsumiki-fl__ic--hibiscus{ background:rgba(240,138,138,.2); color:var(--hibiscus); }
.tsumiki-fl h3{ font-size:18px; color:var(--ocean-ink); margin:0 0 6px; }
.tsumiki-fl p{ font-size:14px; color:var(--ink-soft); margin:0; }
@media (max-width:900px){ .tsumiki-featlist{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:680px){ .tsumiki-featlist{ grid-template-columns:1fr; } .tsumiki-fl h3{ font-size:16px; } }
.tsumiki-onbutsu{ display:grid; grid-template-columns:1fr 1.05fr; gap:54px; align-items:center; }
.tsumiki-onbutsu__img{ width:100%; aspect-ratio:4/3.4; object-fit:cover; border-radius:var(--tradius); box-shadow:var(--shadow-sm); display:block; }
.tsumiki-onbutsu h2{ font-size:30px; color:var(--ocean-ink); line-height:1.5; margin:14px 0 16px; }
.tsumiki-onbutsu__ruby{ font-size:15px; color:var(--ocean); font-weight:700; }
.tsumiki-onbutsu p{ color:var(--ink); margin:0; }
.tsumiki-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.tsumiki-chips span{ background:var(--sea); color:var(--ocean-deep); font-weight:700; font-size:14px; padding:9px 18px; border-radius:999px; }
.tsumiki-ritspo{ background:linear-gradient(135deg,var(--ocean),var(--ocean-deep)); border-radius:var(--tradius-lg); padding:54px 56px; color:#fff; display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:center; }
.tsumiki-ritspo h2{ font-size:30px; margin:10px 0 16px; }
.tsumiki-ritspo__tag{ display:inline-block; background:rgba(255,255,255,.18); padding:6px 16px; border-radius:999px; font-weight:700; font-size:14px; letter-spacing:.08em; }
.tsumiki-ritspo p{ opacity:.95; margin:0; }
.tsumiki-ritspo__note{ font-size:14px; opacity:.7; margin-top:14px; }
.tsumiki-ritspo__img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--tradius); box-shadow:0 10px 30px rgba(0,0,0,.18); display:block; }

/* =========================================================
   お知らせページ（news）
   ========================================================= */
.tsumiki-subscband{ background:var(--cream); padding:32px 0 40px; }
.tsumiki-subsc{ display:flex; align-items:center; gap:26px; max-width:760px; margin:0 auto; background:linear-gradient(120deg,var(--ocean),var(--ocean-deep)); border-radius:var(--tradius-lg); padding:26px 34px; color:#fff; box-shadow:var(--shadow-md); position:relative; overflow:hidden; }
.tsumiki-subsc__photo{ width:150px; height:120px; flex:none; border-radius:18px; object-fit:cover; display:block; box-shadow:0 8px 20px rgba(0,0,0,.18); }
.tsumiki-subsc__body{ flex:1; min-width:0; position:relative; z-index:1; }
.tsumiki-subsc__tag{ display:inline-flex; align-items:center; gap:6px; background:var(--t-yellow); color:#6b4a12; font-family:"M PLUS 1p",sans-serif; font-weight:700; font-size:14px; letter-spacing:.08em; padding:4px 14px; border-radius:999px; }
.tsumiki-subsc h2{ font-size:24px; margin:10px 0 6px; letter-spacing:.04em; }
.tsumiki-subsc p{ margin:0; font-size:15px; opacity:.94; }
.tsumiki-subsc__deco{ position:absolute; right:-20px; bottom:-30px; width:150px; height:150px; border-radius:50%; background:rgba(255,255,255,.08); }
.tsumiki-pdflist{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; max-width:880px; margin:0 auto; }
.tsumiki-pdf{ display:flex; align-items:center; gap:18px; background:#fff; border:2px solid var(--sea-200); border-radius:18px; padding:22px 26px; box-shadow:var(--shadow-sm); transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.tsumiki-pdf:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--ocean); opacity:1; }
.tsumiki-pdf__ic{ width:52px; height:52px; flex:none; border-radius:14px; background:rgba(239,150,133,.16); color:var(--hibiscus); display:flex; align-items:center; justify-content:center; }
.tsumiki-pdf__ic svg{ width:26px; height:26px; }
.tsumiki-pdf__body{ flex:1; min-width:0; }
.tsumiki-pdf__ttl{ font-size:16px; font-weight:700; color:var(--ocean-ink); line-height:1.5; display:block; }
.tsumiki-pdf__meta{ font-family:"M PLUS 1p",sans-serif; font-size:14px; color:var(--ink-soft); margin-top:3px; display:block; }
.tsumiki-pdf__dl{ flex:none; width:40px; height:40px; border-radius:999px; background:var(--ocean); color:#fff; display:flex; align-items:center; justify-content:center; transition:.18s; }
.tsumiki-pdf:hover .tsumiki-pdf__dl{ background:var(--ocean-deep); }
.tsumiki-pdf__dl svg{ width:20px; height:20px; }
.tsumiki-admission{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.tsumiki-admstep{ background:#fff; border-radius:var(--tradius); padding:32px 26px; text-align:center; box-shadow:var(--shadow-sm); position:relative; }
.tsumiki-admstep__no{ position:absolute; top:-20px; left:50%; transform:translateX(-50%); min-width:80px; height:50px; padding:0 14px; border-radius:999px; background:var(--ocean); color:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; line-height:1; box-shadow:var(--shadow-sm); }
.tsumiki-admstep__no .s{ font-family:"M PLUS 1p",sans-serif; font-size:12px; font-weight:700; letter-spacing:.16em; opacity:.85; }
.tsumiki-admstep__no .n{ font-family:"M PLUS 1p",sans-serif; font-size:19px; font-weight:700; margin-top:2px; }
.tsumiki-admstep h3{ font-size:19px; color:var(--ocean-ink); margin:18px 0 8px; }
.tsumiki-admstep p{ font-size:14px; color:var(--ink-soft); margin:14px 0 0; padding-top:14px; border-top:1px solid rgba(29,109,153,.12); text-align:left; line-height:1.8; }

/* =========================================================
   フォトギャラリー（gallery）
   ========================================================= */
.tsumiki-galgroup{ margin-bottom:56px; }
.tsumiki-galgroup:last-of-type{ margin-bottom:0; }
.tsumiki-galgroup__head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.tsumiki-galgroup__bar{ width:6px; height:26px; border-radius:6px; background:var(--ocean); }
.tsumiki-galgroup--hibiscus .tsumiki-galgroup__bar{ background:var(--hibiscus); }
.tsumiki-galgroup--blue .tsumiki-galgroup__bar{ background:var(--t-blue); }
.tsumiki-galgroup--green .tsumiki-galgroup__bar{ background:var(--t-green); }
.tsumiki-galgroup__head h2{ font-size:22px; color:var(--ocean-ink); margin:0; letter-spacing:.04em; }
.tsumiki-galrow{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.tsumiki-galitem{ border:none; padding:0; margin:0; background:none; cursor:pointer; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-sm); display:block; transition:transform .18s ease, box-shadow .18s ease; }
.tsumiki-galitem:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tsumiki-galitem .ph{ border-radius:0; aspect-ratio:4/3; }
.tsumiki-galitem__img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.tsumiki-galitem__cap{ background:#fff; padding:12px 14px; font-size:14px; color:var(--ink-soft); font-weight:700; text-align:left; }

/* ライトボックス */
.tsumiki-lightbox{ position:fixed; inset:0; z-index:300; background:rgba(21,83,111,.86); display:none; align-items:center; justify-content:center; padding:40px; }
.tsumiki-lightbox.is-open{ display:flex; }
.tsumiki-lightbox__inner{ position:relative; max-width:840px; width:100%; }
.tsumiki-lightbox__stage{ background:var(--sea-200); border-radius:20px; overflow:hidden; box-shadow:var(--shadow-lg); }
.tsumiki-lightbox__stage .ph{ border-radius:0; aspect-ratio:4/3; }
.tsumiki-lightbox__cap{ text-align:center; color:#fff; font-weight:700; margin-top:18px; font-size:16px; }
.tsumiki-lightbox__close{ position:absolute; top:-14px; right:-14px; width:46px; height:46px; border-radius:999px; background:#fff; color:var(--ocean-deep); border:none; cursor:pointer; box-shadow:var(--shadow-md); display:flex; align-items:center; justify-content:center; }
.tsumiki-lightbox__close svg{ width:22px; height:22px; }
.tsumiki-lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px; border-radius:999px; background:rgba(255,255,255,.92); color:var(--ocean-deep); border:none; cursor:pointer; box-shadow:var(--shadow-md); display:flex; align-items:center; justify-content:center; }
.tsumiki-lightbox__nav svg{ width:26px; height:26px; }
.tsumiki-lightbox__prev{ left:-22px; }
.tsumiki-lightbox__next{ right:-22px; }

/* =========================================================
   保護者専用ページ（pass）
   ========================================================= */
.tsumiki-gatewrap{ display:flex; align-items:center; justify-content:center; padding:16px 0; }
.tsumiki-gate{ width:480px; max-width:100%; background:#fff; border-radius:var(--tradius-lg); box-shadow:var(--shadow-lg); padding:48px 46px; text-align:center; position:relative; overflow:hidden; }
.tsumiki-gate__top{ position:absolute; left:0; right:0; top:0; height:8px; background:repeating-linear-gradient(90deg,var(--t-red) 0 14px,var(--t-yellow) 14px 28px,var(--t-green) 28px 42px,var(--t-blue) 42px 56px); }
.tsumiki-gate__lock{ width:84px; height:84px; margin:8px auto 18px; border-radius:24px; background:var(--sea); display:flex; align-items:center; justify-content:center; }
.tsumiki-gate__lock svg{ width:40px; height:40px; color:var(--ocean-deep); }
.tsumiki-gate h1{ font-size:24px; color:var(--ocean-ink); margin:0 0 8px; }
.tsumiki-gate > p{ font-size:14px; color:var(--ink-soft); margin:0 0 26px; line-height:1.8; }
.tsumiki-gate__field{ display:flex; flex-direction:column; gap:10px; text-align:left; }
.tsumiki-gate label{ font-size:14px; font-weight:700; color:var(--ocean-deep); }
.tsumiki-gate input{ font-family:"M PLUS 1p",sans-serif; font-size:16px; padding:14px 18px; border-radius:14px; border:2px solid var(--sea-300); background:var(--sea-50); outline:none; transition:.15s; }
.tsumiki-gate input:focus{ border-color:var(--ocean); background:#fff; }
.tsumiki-gate__field .tsumiki-btn{ margin-top:18px; }
.tsumiki-gate__err{ color:#d9534f; font-size:14px; font-weight:700; margin-top:14px; min-height:18px; }
.tsumiki-gate__hint{ font-size:14px; color:var(--ocean); background:var(--sea-50); border-radius:10px; padding:8px 14px; margin-top:18px; }
.tsumiki-pg{ display:none; }
.tsumiki-pg.is-show{ display:block; }
.tsumiki-gatesec.is-hide{ display:none; }
.tsumiki-pgbar{ display:flex; align-items:flex-start; justify-content:center; gap:12px; color:var(--ocean-ink); font-size:14px; margin-bottom:30px; text-align:left; }
.tsumiki-pgbar svg{ width:22px; height:22px; color:var(--ocean); flex:none; margin-top:2px; }
.tsumiki-pggrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.tsumiki-pggrid .cell{ border-radius:18px; overflow:hidden; box-shadow:var(--shadow-sm); }
.tsumiki-pggrid .ph{ border-radius:0; aspect-ratio:1/1; }
.tsumiki-pggrid .cap{ background:#fff; padding:10px 14px; font-size:14px; color:var(--ink-soft); font-weight:700; }

/* =========================================================
   汎用ユーティリティ（design 由来）
   ========================================================= */
.tsumiki-center{ text-align:center; }
.tsumiki-mt-m{ margin-top:28px; }
.tsumiki-mt-l{ margin-top:48px; }
/* SP専用の改行（PC固定レイアウトでは非表示） */
.br-sp{ display:none; }
