/*
Theme Name: ひだまり保育園
Theme URI: https://example.com/hidamari
Author: Hidamari Web Team
Description: 保育園「ひだまり保育園」のオリジナルテーマ。フレーム型の大判ヒーロー、流れるマーキー、アーチ型の写真、横スクロールの一日タイムラインなど、現行トレンドのデザインで構成。有効化すると必要な固定ページとメニューが自動で作成されます。
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hidamari
*/

/* ==========================================================
   0. トークン
   ========================================================== */
:root{
  --bg:#fffbf1;
  --bg-soft:#fff3d3;
  --ink:#28342b;
  --ink-soft:#6e7a6c;
  --green:#1f7a4d;
  --green-deep:#14502f;
  --yellow:#ffc93c;
  --yellow-deep:#f5b300;
  --coral:#ff8a5c;
  --sky:#bfe3f2;
  --white:#ffffff;
  --line:rgba(40,52,43,.12);
  --r-xl:40px;
  --r-l:28px;
  --r-m:18px;
  --shadow:0 14px 40px rgba(40,52,43,.10);
  --shadow-s:0 6px 18px rgba(40,52,43,.08);
  --disp:"Zen Maru Gothic","Noto Sans JP",sans-serif;
  --body:"Noto Sans JP",-apple-system,"Hiragino Kaku Gothic ProN",sans-serif;
  --head-h:84px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--head-h) + 16px)}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  font-size:15.5px;
  line-height:2.05;
  letter-spacing:.05em;
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:.25s ease}
a:focus-visible,button:focus-visible{outline:3px solid var(--yellow);outline-offset:3px;border-radius:6px}
ul{list-style:none}
button{font-family:inherit}

.wrap{width:min(1140px,calc(100% - 40px));margin-inline:auto}
.wrap--narrow{width:min(780px,calc(100% - 40px));margin-inline:auto}

/* 見出し */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--disp);font-weight:700;font-size:.85rem;
  color:var(--green);letter-spacing:.2em;
  background:var(--white);border:1.5px solid var(--green);
  border-radius:999px;padding:.2em 1.3em;margin-bottom:1.1em;
}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--yellow)}
.h-jp{
  font-family:var(--disp);font-weight:900;
  font-size:clamp(1.7rem,3.8vw,2.6rem);
  line-height:1.7;letter-spacing:.08em;
}
.h-en{
  font-family:var(--disp);font-weight:900;color:var(--green);
  font-size:clamp(1.6rem,3.4vw,2.3rem);letter-spacing:.04em;
}
.h-sub{font-family:var(--disp);font-weight:700;color:var(--green);font-size:1.1rem;letter-spacing:.12em}
.lead{max-width:42em}
.note{color:var(--ink-soft);font-size:.85rem}
.center{text-align:center}
.center .lead{margin-inline:auto}

.sec{padding:clamp(72px,10vw,128px) 0}
.sec--tight{padding-top:clamp(40px,5vw,64px)}
.sec--soft{background:var(--bg-soft)}
.sec--white{background:var(--white)}

/* ふわっと表示（JSがある時だけ初期非表示） */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.js .reveal.is-in{opacity:1;transform:none}
.js .reveal[data-delay="1"]{transition-delay:.12s}
.js .reveal[data-delay="2"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
}

/* ボタン */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--disp);font-weight:700;letter-spacing:.1em;
  background:var(--green);color:#fff;
  padding:.95em 2.4em;border-radius:999px;
  box-shadow:var(--shadow-s);border:none;cursor:pointer;
}
.btn::after{
  content:"";width:9px;height:9px;
  border-top:2.5px solid currentColor;border-right:2.5px solid currentColor;
  transform:rotate(45deg);transition:transform .25s ease;
}
.btn:hover{background:var(--green-deep);transform:translateY(-2px)}
.btn:hover::after{transform:rotate(45deg) translate(2px,-2px)}
.btn--yellow{background:var(--yellow);color:var(--ink)}
.btn--yellow:hover{background:var(--yellow-deep)}
.btn--ghost{background:var(--white);color:var(--green);border:1.5px solid var(--green)}
.btn--ghost:hover{background:var(--green);color:#fff}

.textlink{
  font-family:var(--disp);font-weight:700;letter-spacing:.1em;color:var(--ink);
  display:inline-flex;align-items:center;gap:.7em;
}
.textlink::before{
  content:"";width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  background:var(--yellow) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'><path d='M3 2l3 3-3 3' fill='none' stroke='%2328342b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/46% no-repeat;
  transition:transform .25s ease;
}
.textlink:hover::before{transform:translateX(4px)}
.textlinks{display:flex;flex-wrap:wrap;gap:1em 2.2em;margin-top:1.8em}

/* ==========================================================
   1. ヘッダー（固定・白ガラス）
   ========================================================== */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease,box-shadow .3s ease;
}
.topbar.is-scrolled{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 2px 24px rgba(40,52,43,.08);
}
.topbar__inner{
  height:var(--head-h);
  width:min(1320px,calc(100% - 32px));margin-inline:auto;
  display:flex;align-items:center;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand a{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand__mark{width:50px;height:50px;flex:0 0 auto}
.brand__name{font-family:var(--disp);font-weight:900;letter-spacing:.1em;font-size:1.05rem;line-height:1.4}
.brand__name small{display:block;font-size:.58rem;font-weight:700;color:var(--ink-soft);letter-spacing:.34em}

.gnav ul{display:flex;align-items:center;gap:1.9em}
.gnav a{
  font-family:var(--disp);font-weight:700;font-size:.9rem;
  color:var(--ink);letter-spacing:.08em;position:relative;padding:.4em 0;
}
.gnav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;border-radius:3px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .25s ease;
}
.gnav a:hover::after{transform:scaleX(1)}

.cta-pill{
  font-family:var(--disp);font-weight:700;font-size:.88rem;letter-spacing:.08em;
  background:var(--yellow);color:var(--ink);
  padding:.75em 1.7em;border-radius:999px;box-shadow:var(--shadow-s);
  display:inline-flex;align-items:center;gap:.5em;white-space:nowrap;
}
.cta-pill:hover{background:var(--yellow-deep);transform:translateY(-2px)}
.cta-pill svg{width:16px;height:16px}

.nav-toggle{display:none}

@media (max-width:1020px){
  :root{--head-h:70px}
  .gnav{
    position:fixed;top:0;right:0;bottom:0;width:min(82vw,340px);
    background:var(--white);padding:110px 36px 40px;
    transform:translateX(105%);transition:transform .35s cubic-bezier(.22,1,.36,1);
    box-shadow:-16px 0 50px rgba(40,52,43,.16);z-index:90;overflow-y:auto;
  }
  .gnav.is-open{transform:none}
  .gnav ul{flex-direction:column;align-items:stretch;gap:0}
  .gnav li{border-bottom:1px solid var(--line)}
  .gnav a{display:block;padding:1em 0;font-size:1rem}
  .gnav a::after{content:none}
  .cta-pill{display:none}
  .nav-toggle{
    display:grid;place-items:center;gap:0;
    width:52px;height:52px;border:none;border-radius:50%;
    background:var(--green);cursor:pointer;z-index:95;position:relative;
  }
  .nav-toggle span{
    grid-area:1/1;display:block;width:20px;height:2px;background:#fff;border-radius:2px;
    transition:transform .3s ease,opacity .3s ease;
  }
  .nav-toggle span:nth-child(1){transform:translateY(-6px)}
  .nav-toggle span:nth-child(3){transform:translateY(6px)}
  .nav-toggle.is-open span:nth-child(1){transform:rotate(45deg)}
  .nav-toggle.is-open span:nth-child(2){opacity:0}
  .nav-toggle.is-open span:nth-child(3){transform:rotate(-45deg)}
}

/* ==========================================================
   2. ヒーロー（フレーム型）＋ マーキー
   ========================================================== */
.hero{padding:calc(var(--head-h) + 12px) 12px 0}
.hero__media{
  position:relative;height:min(82vh,760px);min-height:500px;
  border-radius:var(--r-xl);overflow:hidden;
}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.hero__media::after{
  content:"";position:absolute;top:0;right:0;bottom:0;left:0;
  background:linear-gradient(200deg,rgba(40,52,43,0) 55%,rgba(40,52,43,.34));
}
.hero__copy{
  position:absolute;left:clamp(20px,5vw,64px);bottom:clamp(28px,6vh,64px);z-index:5;
  color:#fff;
}
.hero__copy strong{
  display:block;
  font-family:var(--disp);font-weight:900;
  font-size:clamp(2.1rem,5.6vw,4.2rem);
  line-height:1.5;letter-spacing:.1em;
  text-shadow:0 4px 30px rgba(40,52,43,.35);
}
.hero__copy small{
  display:inline-block;margin-top:1em;
  font-family:var(--disp);font-weight:700;font-size:clamp(.85rem,1.6vw,1rem);
  letter-spacing:.18em;background:rgba(255,255,255,.92);color:var(--ink);
  border-radius:999px;padding:.5em 1.6em;
}
/* 回転バッジ */
.hero__badge{
  position:absolute;right:clamp(18px,4vw,52px);bottom:clamp(22px,5vh,56px);z-index:6;
  width:clamp(108px,12vw,150px);height:clamp(108px,12vw,150px);display:block;
}
.hero__badge svg{width:100%;height:100%;overflow:visible}
.hero__badge .ring{animation:spin 16s linear infinite;transform-origin:50% 50%}
.hero__badge:hover .face{transform:scale(1.06)}
.hero__badge .face{transition:transform .3s ease;transform-origin:50% 50%}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.hero__badge .ring{animation:none}}

/* マーキー */
.marquee{
  overflow:hidden;padding:26px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee__track{
  display:flex;gap:0;width:max-content;
  animation:marquee 26s linear infinite;
}
.marquee__unit{
  display:flex;align-items:center;gap:.9em;padding-right:.9em;white-space:nowrap;
  font-family:var(--disp);font-weight:900;
  font-size:clamp(1.5rem,3.4vw,2.4rem);letter-spacing:.14em;
  color:var(--green);
}
.marquee__unit .sun{width:.95em;height:.95em;flex:0 0 auto}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){
  .marquee__track{animation:none}
}

/* ==========================================================
   3. ステートメント（浮かぶ写真つき）
   ========================================================== */
.statement{position:relative;text-align:center}
.statement .h-jp{font-size:clamp(1.8rem,4.4vw,3rem)}
.statement .lead{margin:1.8em auto 0}
.statement__float{
  position:absolute;border-radius:50%;overflow:hidden;box-shadow:var(--shadow);
  border:6px solid var(--white);
}
.statement__float img{width:100%;height:100%;object-fit:cover}
.statement__float--a{width:clamp(110px,13vw,180px);height:clamp(110px,13vw,180px);left:3%;top:-8%;transform:rotate(-5deg)}
.statement__float--b{width:clamp(90px,10vw,150px);height:clamp(90px,10vw,150px);right:5%;top:6%;transform:rotate(4deg)}
.statement__float--c{width:clamp(100px,11vw,160px);height:clamp(100px,11vw,160px);right:12%;bottom:-16%;transform:rotate(-3deg)}
@media (max-width:760px){
  .statement__float--a{left:-4%;top:-12%}
  .statement__float--c{display:none}
}
.pillfacts{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:2.6em}
.pillfacts li{
  font-family:var(--disp);font-weight:700;font-size:.92rem;letter-spacing:.08em;
  background:var(--white);border:1.5px solid var(--line);border-radius:999px;
  padding:.55em 1.5em;box-shadow:var(--shadow-s);
}
.pillfacts b{color:var(--green)}

/* ==========================================================
   4. 園の一日：横スクロールタイムライン
   ========================================================== */
.dayline__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.dayline__btns{display:flex;gap:10px}
.dayline__btn{
  width:52px;height:52px;border-radius:50%;border:1.5px solid var(--green);
  background:var(--white);color:var(--green);cursor:pointer;
  display:grid;place-items:center;transition:.25s ease;
}
.dayline__btn:hover{background:var(--green);color:#fff}
.dayline__btn svg{width:18px;height:18px}
.dayline{
  display:flex;gap:18px;overflow-x:auto;padding:34px 4px 26px;
  scroll-snap-type:x mandatory;scrollbar-width:none;
}
.dayline::-webkit-scrollbar{display:none}
.day-card{
  flex:0 0 min(270px,72vw);scroll-snap-align:start;
  background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);
  padding:26px 24px 28px;position:relative;
  border-top:6px solid var(--yellow);
}
.day-card:nth-child(3n+2){border-top-color:var(--coral)}
.day-card:nth-child(3n){border-top-color:var(--sky)}
.day-card__time{
  font-family:var(--disp);font-weight:900;font-size:1.5rem;color:var(--green);
  letter-spacing:.04em;font-variant-numeric:tabular-nums;
}
.day-card__title{font-family:var(--disp);font-weight:700;font-size:1.05rem;margin:.2em 0 .5em;letter-spacing:.08em}
.day-card p{font-size:.84rem;color:var(--ink-soft);line-height:1.95}
.day-card__icon{position:absolute;top:22px;right:22px;width:40px;height:40px;opacity:.95}

/* ==========================================================
   5. クラス紹介：アーチ型カード
   ========================================================== */
.classes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,34px);margin-top:clamp(30px,5vw,52px)}
.class-card{text-align:center}
.class-card figure{
  border-radius:300px 300px var(--r-l) var(--r-l);
  overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:3/3.6;
}
.class-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.class-card:hover img{transform:scale(1.05)}
.class-card__age{
  display:inline-block;margin-top:-1.1em;position:relative;z-index:2;
  font-family:var(--disp);font-weight:700;font-size:.8rem;letter-spacing:.12em;
  background:var(--ink);color:#fff;border-radius:999px;padding:.35em 1.4em;
}
.class-card__name{
  font-family:var(--disp);font-weight:900;font-size:1.35rem;letter-spacing:.12em;
  margin:.5em 0 .4em;display:flex;justify-content:center;align-items:center;gap:.45em;
}
.dot{width:13px;height:13px;border-radius:50%;flex:0 0 auto}
.dot--pink{background:#f59ab0}
.dot--yellow{background:var(--yellow)}
.dot--green{background:#65b07f}
.class-card > p{font-size:.86rem;color:var(--ink-soft);text-align:left;max-width:30em;margin-inline:auto}
@media (max-width:860px){.classes{grid-template-columns:1fr;max-width:440px;margin-inline:auto}}

/* ==========================================================
   6. 年間行事
   ========================================================== */
.seasons{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:clamp(28px,5vw,48px)}
.season{
  background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);
  overflow:hidden;transition:transform .3s ease;
}
.season:hover{transform:translateY(-6px)}
.season figure{aspect-ratio:16/10;overflow:hidden;position:relative}
.season img{width:100%;height:100%;object-fit:cover}
.season__name{
  position:absolute;left:14px;bottom:-16px;z-index:2;
  font-family:var(--disp);font-weight:900;font-size:1rem;letter-spacing:.22em;
  color:#fff;border-radius:999px;padding:.4em 1.4em;
}
.season__name--spring{background:#e96d8c}
.season__name--summer{background:#3d92c4}
.season__name--autumn{background:#d8742e}
.season__name--winter{background:#7c93a8}
.season ul{padding:30px 22px 24px;font-size:.85rem;color:var(--ink-soft)}
.season li{padding:.5em 0;border-bottom:1px dashed var(--line);line-height:1.9}
.season li:last-child{border-bottom:none}
@media (max-width:980px){.seasons{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.seasons{grid-template-columns:1fr}}

/* ==========================================================
   7. 給食バンド（フルブリード・緑）
   ========================================================== */
.lunchband{
  background:var(--green-deep);color:#fff;border-radius:var(--r-xl);
  width:min(1280px,calc(100% - 24px));margin-inline:auto;
  padding:clamp(40px,6vw,80px);
  display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(30px,5vw,72px);align-items:center;
  position:relative;overflow:hidden;
}
.lunchband::before{
  content:"";position:absolute;top:-90px;right:-90px;width:260px;height:260px;border-radius:50%;
  background:rgba(255,201,60,.16);
}
.lunchband .eyebrow{background:transparent;border-color:var(--yellow);color:var(--yellow)}
.lunchband .h-jp{color:#fff}
.lunchband p{color:rgba(255,255,255,.85)}
.lunchband__photo{border-radius:var(--r-l);overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.lunchband__photo img{width:100%;aspect-ratio:4/3;object-fit:cover}
.lunchband .btn--yellow{margin-top:1.8em}
@media (max-width:860px){.lunchband{grid-template-columns:1fr}}

/* ==========================================================
   8. お知らせ
   ========================================================== */
.news-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(22px,3vw,36px)}
.news-list{display:grid}
.news-row{
  display:grid;grid-template-columns:auto auto 1fr auto;gap:1.6em;align-items:center;
  padding:22px 10px;border-bottom:1px solid var(--line);color:var(--ink);
  transition:background .25s ease;border-radius:14px;
}
.news-row:hover{background:var(--white)}
.news-row time{font-size:.84rem;color:var(--ink-soft);letter-spacing:.08em;font-variant-numeric:tabular-nums}
.news-row .cat{
  font-family:var(--disp);font-size:.74rem;font-weight:700;letter-spacing:.1em;
  color:var(--green);border:1.5px solid var(--green);border-radius:999px;
  padding:.15em 1.1em;white-space:nowrap;
}
.news-row .title{font-family:var(--disp);font-weight:700;line-height:1.8}
.news-row .arrow{
  width:36px;height:36px;border-radius:50%;background:var(--yellow);
  display:grid;place-items:center;transition:transform .25s ease;
}
.news-row:hover .arrow{transform:translateX(5px)}
.news-row .arrow svg{width:12px;height:12px}
@media (max-width:640px){
  .news-row{grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:.3em 1.2em;padding:18px 6px}
  .news-row .title{grid-column:1/3}
  .news-row .arrow{display:none}
}

/* ==========================================================
   9. アクセス
   ========================================================== */
.access{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(28px,5vw,64px);align-items:start;margin-top:clamp(26px,4vw,44px)}
.access__info strong{font-family:var(--disp);font-size:1.15rem;letter-spacing:.1em}
.access__list{margin:1.4em 0}
.access__list li{position:relative;padding:.55em 0 .55em 1.7em;border-bottom:1px dashed var(--line);font-size:.9rem}
.access__list li:last-child{border-bottom:none}
.access__list li::before{
  content:"";position:absolute;left:0;top:1.05em;width:10px;height:10px;border-radius:50%;background:var(--yellow);
}
.access__map svg,.access__map img{
  width:100%;height:auto;border-radius:var(--r-l);box-shadow:var(--shadow);
  border:1px solid var(--line);background:var(--white);
}
@media (max-width:860px){.access{grid-template-columns:1fr}}

/* ==========================================================
   10. CTAバナー＋フッター
   ========================================================== */
.cta-banner{
  width:min(1280px,calc(100% - 24px));margin:clamp(60px,9vw,110px) auto 0;
  background:var(--yellow);border-radius:var(--r-xl);
  padding:clamp(44px,7vw,90px) clamp(24px,5vw,80px);
  text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before,.cta-banner::after{
  content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.35);
}
.cta-banner::before{width:220px;height:220px;left:-70px;bottom:-90px}
.cta-banner::after{width:160px;height:160px;right:-40px;top:-60px}
.cta-banner h2{
  font-family:var(--disp);font-weight:900;
  font-size:clamp(1.6rem,4vw,2.6rem);letter-spacing:.12em;line-height:1.8;
  position:relative;z-index:2;
}
.cta-banner p{position:relative;z-index:2;margin:.8em auto 1.8em;max-width:36em}
.cta-banner .btn{position:relative;z-index:2;background:var(--ink);font-size:1rem;padding:1.1em 3.2em}
.cta-banner .btn:hover{background:var(--green-deep)}

.foot{background:var(--green-deep);color:#fff;margin-top:clamp(60px,9vw,110px);padding:clamp(50px,7vw,84px) 0 0;border-radius:var(--r-xl) var(--r-xl) 0 0}
.foot__grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:clamp(30px,5vw,70px)}
.foot .brand__name{color:#fff}
.foot .brand__name small{color:rgba(255,255,255,.6)}
.foot__addr{font-size:.86rem;color:rgba(255,255,255,.78);line-height:2.1;margin-top:1.2em}
.foot__title{
  font-family:var(--disp);font-weight:700;font-size:.85rem;letter-spacing:.22em;
  color:var(--yellow);margin-bottom:1em;
}
.foot__nav li{padding:.32em 0}
.foot__nav a{color:rgba(255,255,255,.85);font-size:.9rem;display:inline-flex;align-items:center;gap:.6em}
.foot__nav a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--yellow);opacity:.9}
.foot__nav a:hover{color:#fff;transform:translateX(3px)}
.foot__copy{
  margin-top:clamp(36px,5vw,60px);padding:18px 0;
  border-top:1px solid rgba(255,255,255,.14);
  text-align:center;font-size:.74rem;letter-spacing:.2em;color:rgba(255,255,255,.55);
}
@media (max-width:860px){.foot__grid{grid-template-columns:1fr}}

/* ==========================================================
   11. 下層共通
   ========================================================== */
.ph-hero{padding:calc(var(--head-h) + clamp(36px,6vw,72px)) 0 0}
.ph-hero .eyebrow{margin-bottom:.9em}
.ph-hero h1{
  font-family:var(--disp);font-weight:900;
  font-size:clamp(2rem,5vw,3.2rem);letter-spacing:.1em;line-height:1.6;
}
.ph-hero__photo{
  margin-top:clamp(28px,4vw,48px);
  border-radius:300px 300px var(--r-l) var(--r-l);
  overflow:hidden;box-shadow:var(--shadow);
}
.ph-hero__photo img{width:100%;aspect-ratio:21/10;object-fit:cover}
.ph-hero__photo--flat{border-radius:var(--r-xl)}
.page-band{padding:calc(var(--head-h) + clamp(36px,6vw,72px)) 0 0}
.page-band h1{
  font-family:var(--disp);font-weight:900;
  font-size:clamp(1.8rem,4.4vw,2.8rem);letter-spacing:.1em;line-height:1.7;
}

.wide-photo{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow)}
.wide-photo img{width:100%;aspect-ratio:21/9;object-fit:cover}

/* 園について */
.philos__grid{display:grid;grid-template-columns:auto 1fr;gap:clamp(30px,6vw,80px);align-items:start}
.tate{
  writing-mode:vertical-rl;font-family:var(--disp);font-weight:900;
  letter-spacing:.34em;font-size:clamp(1.2rem,2.4vw,1.65rem);line-height:2.3;color:var(--green);
  background:var(--white);border-radius:999px;padding:1.2em .55em;box-shadow:var(--shadow-s);
}
.philos__body h3{
  font-family:var(--disp);font-weight:900;font-size:1.3rem;letter-spacing:.1em;
  margin:2.2em 0 .7em;display:flex;align-items:center;gap:.6em;
}
.philos__body h3::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--yellow);flex:0 0 auto}
.philos__body h3:first-child{margin-top:0}
.philos__body p + p{margin-top:1.2em}
@media (max-width:760px){
  .philos__grid{grid-template-columns:1fr}
  .tate{writing-mode:horizontal-tb;letter-spacing:.22em;padding:.5em 1.4em;justify-self:start}
}

.views{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px);margin-top:clamp(30px,5vw,52px)}
.view{background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);overflow:hidden;transition:transform .3s ease}
.view:hover{transform:translateY(-6px)}
.view img{width:100%;aspect-ratio:16/10;object-fit:cover}
.view__body{padding:26px 28px 30px;text-align:center}
.view__title{font-family:var(--disp);font-weight:900;font-size:1.2rem;letter-spacing:.12em}
.view__title b{color:var(--green)}
.view__text{font-size:.88rem;color:var(--ink-soft);margin-top:.5em}
@media (max-width:680px){.views{grid-template-columns:1fr}}

.origins{margin-top:clamp(48px,7vw,84px);text-align:center}
.origins__big{
  font-family:var(--disp);font-weight:900;color:var(--green);
  font-size:clamp(1.6rem,3.6vw,2.4rem);letter-spacing:.3em;line-height:2;
}
.origins__row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px;text-align:left}
.origin{
  background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);
  padding:26px 26px 28px;border-top:6px solid var(--yellow);
}
.origin:nth-child(2){border-top-color:var(--coral)}
.origin:nth-child(3){border-top-color:var(--sky)}
.origin dt{font-family:var(--disp);font-weight:900;color:var(--green);letter-spacing:.2em;font-size:1.1rem;margin-bottom:.4em}
.origin dd{font-size:.86rem;color:var(--ink-soft)}
@media (max-width:680px){.origins__row{grid-template-columns:1fr}}

/* 概要テーブル */
.overview{margin-top:clamp(26px,4vw,40px);overflow-x:auto}
.overview table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);
  overflow:hidden;font-size:.88rem;
}
.overview th,.overview td{
  padding:16px 20px;border-bottom:1px solid var(--line);
  text-align:left;vertical-align:top;line-height:1.95;
}
.overview tr:last-child th,.overview tr:last-child td{border-bottom:none}
.overview th{
  font-family:var(--disp);background:#f3faf0;color:var(--green);font-weight:700;
  white-space:nowrap;width:6em;letter-spacing:.08em;
}
@media (max-width:760px){
  .overview table,.overview tr,.overview th,.overview td{display:block;width:100%}
  .overview th{width:100%;padding:10px 20px}
}

/* あゆみ */
.story-era{margin-top:clamp(60px,9vw,108px);position:relative}
.story-era__year{
  font-family:var(--disp);font-weight:900;font-size:clamp(2.2rem,5vw,3.4rem);
  color:transparent;-webkit-text-stroke:2px var(--yellow-deep);letter-spacing:.06em;line-height:1.2;
}
.story-era__title{
  font-family:var(--disp);font-weight:900;font-size:clamp(1.3rem,2.8vw,1.7rem);
  line-height:1.9;letter-spacing:.08em;margin:.3em 0 1em;
}
.marker{background:linear-gradient(transparent 60%,rgba(255,201,60,.55) 60%)}
.story-era__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center}
.story-era__grid--rev{grid-template-columns:1.1fr 1fr}
@media (max-width:760px){.story-era__grid,.story-era__grid--rev{grid-template-columns:1fr}}

.polaroid{background:var(--white);padding:12px 12px 36px;box-shadow:var(--shadow);border-radius:10px;transform:rotate(-2.5deg)}
.polaroid + .polaroid{transform:rotate(2deg);margin-top:-20px;margin-left:14%}
.polaroid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px}

.idea-box{background:var(--white);border-radius:var(--r-l);box-shadow:var(--shadow-s);padding:clamp(26px,4vw,40px)}
.idea-box h4{font-family:var(--disp);font-weight:900;letter-spacing:.14em;color:var(--green);margin-bottom:1em;text-align:center;font-size:1.05rem}
.idea-box dl{display:grid;gap:16px}
.idea-box dt{font-family:var(--disp);font-weight:900;letter-spacing:.2em;display:flex;align-items:center;gap:.5em}
.idea-box dt::before{content:"";width:11px;height:11px;border-radius:50%;background:var(--yellow);flex:0 0 auto}
.idea-box dd{font-size:.86rem;color:var(--ink-soft);padding-left:1.5em}

.growth{
  background:var(--white);border-radius:var(--r-xl);box-shadow:var(--shadow-s);
  padding:clamp(34px,5vw,60px);margin-top:clamp(56px,8vw,96px);
}
.growth h3{font-family:var(--disp);text-align:center;font-weight:900;letter-spacing:.18em;font-size:1.4rem;margin-bottom:.5em}
.growth > .note{text-align:center}
.growth__row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.growth__item{background:var(--bg);border-radius:var(--r-l);padding:26px 24px;text-align:center}
.growth__tag{font-size:.74rem;font-weight:700;color:var(--ink-soft);letter-spacing:.2em}
.growth__name{font-family:var(--disp);font-weight:900;font-size:1.25rem;margin:.4em 0 .6em}
.growth__name b{color:#fff;background:var(--green);border-radius:10px;padding:.08em .45em;margin-right:.25em}
.growth__item p{font-size:.84rem;color:var(--ink-soft);line-height:2;text-align:left}
@media (max-width:760px){.growth__row{grid-template-columns:1fr}}

.message{display:grid;grid-template-columns:1fr .85fr;gap:clamp(28px,5vw,64px);align-items:center;margin-top:clamp(60px,9vw,100px)}
.message__photo{border-radius:300px 300px var(--r-l) var(--r-l);overflow:hidden;box-shadow:var(--shadow)}
.message__photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
@media (max-width:760px){.message{grid-template-columns:1fr}}

/* 給食ページ */
.food-intro{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.food-intro figure{border-radius:300px 300px var(--r-l) var(--r-l);overflow:hidden;box-shadow:var(--shadow)}
.food-intro img{width:100%;aspect-ratio:4/4.4;object-fit:cover}
@media (max-width:760px){.food-intro{grid-template-columns:1fr}}

.voice{text-align:center;margin-top:clamp(60px,9vw,100px)}
.voice__words{display:flex;justify-content:center;gap:.9em;flex-wrap:wrap;margin-bottom:1.1em}
.voice__words span{
  font-family:var(--disp);font-weight:700;letter-spacing:.1em;font-size:.95rem;
  background:var(--white);border-radius:999px;padding:.5em 1.5em;
  box-shadow:var(--shadow-s);color:var(--green);
}
.voice__words span:nth-child(2){transform:rotate(2deg)}
.voice__words span:nth-child(3){transform:rotate(-2deg)}
.voice h2{font-family:var(--disp);font-size:clamp(1.6rem,3.6vw,2.4rem);font-weight:900;letter-spacing:.12em;line-height:1.9}

.food-sec{margin-top:clamp(64px,9vw,110px)}
.food-sec__no{
  font-family:var(--disp);font-weight:900;font-size:clamp(2rem,4.4vw,3rem);
  color:transparent;-webkit-text-stroke:2px var(--yellow-deep);
  letter-spacing:.06em;line-height:1.2;
}
.food-sec h3{
  font-family:var(--disp);font-weight:900;font-size:clamp(1.3rem,2.8vw,1.7rem);
  letter-spacing:.12em;margin:.25em 0 .9em;
}
.food-sec__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,5vw,64px);align-items:center;margin-top:14px}
.food-sec__grid figure{border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow)}
.food-sec__grid img{width:100%;aspect-ratio:4/3;object-fit:cover}
.food-sec--rev .food-sec__grid figure{order:2}
@media (max-width:760px){
  .food-sec__grid{grid-template-columns:1fr}
  .food-sec--rev .food-sec__grid figure{order:0}
}
.heart-note{
  background:var(--white);border-left:6px solid var(--yellow);
  border-radius:var(--r-m);box-shadow:var(--shadow-s);
  padding:20px 26px;margin-top:20px;font-size:.88rem;color:var(--ink-soft);
}
.heart-note b{color:var(--green)}

/* 記事・固定ページ本文 */
.article{background:var(--white);border-radius:var(--r-xl);box-shadow:var(--shadow-s);padding:clamp(30px,5vw,64px)}
.article h1{font-family:var(--disp);font-size:clamp(1.4rem,3vw,1.9rem);font-weight:900;line-height:1.9;letter-spacing:.08em;margin-bottom:.4em}
.article .meta{font-size:.82rem;color:var(--ink-soft);margin-bottom:2.2em;display:flex;gap:1.2em;align-items:center}
.article .meta .cat{
  font-family:var(--disp);color:var(--green);font-weight:700;border:1.5px solid var(--green);
  border-radius:999px;padding:.1em 1em;font-size:.74rem;
}
.entry h2{
  font-family:var(--disp);font-weight:900;font-size:1.3rem;margin:2.2em 0 .8em;
  letter-spacing:.1em;display:flex;align-items:center;gap:.6em;
}
.entry h2::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--yellow);flex:0 0 auto}
.entry h3{font-family:var(--disp);font-weight:700;font-size:1.05rem;margin:1.8em 0 .6em;color:var(--green)}
.entry p + p{margin-top:1.1em}
.entry ul{margin:1.2em 0;background:var(--bg);border-radius:var(--r-m);padding:1.2em 1.6em}
.entry ul li{position:relative;padding:.35em 0 .35em 1.4em}
.entry ul li::before{content:"";position:absolute;left:0;top:1em;width:9px;height:9px;border-radius:50%;background:var(--yellow)}
.entry img{border-radius:var(--r-m)}
.entry a{text-decoration:underline;text-underline-offset:.3em}

.archive-list{display:grid;margin-top:clamp(10px,2vw,20px)}
.pagination{margin-top:38px;display:flex;justify-content:center;gap:.6em;flex-wrap:wrap}
.pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:44px;height:44px;border-radius:50%;background:var(--white);
  box-shadow:var(--shadow-s);color:var(--ink);font-weight:700;padding:0 .7em;
  font-family:var(--disp);
}
.pagination .current{background:var(--green);color:#fff}
.pagination a:hover{background:var(--yellow)}

/* WP標準クラス最低限 */
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{margin-inline:auto}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.8rem;color:var(--ink-soft);text-align:center;margin-top:.4em}
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;
}
