:root{--sus-bg:#eeeae3;--sus-dark:#e5e1da;}
body{font-family:"Noto Sans JP",sans-serif;color:var(--text-dark);background:var(--sus-bg);overflow-x:hidden}
header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:rgba(15,39,66,.97);border-bottom:1px solid rgba(255,255,255,.07)}
.hl{display:flex;align-items:center;gap:12px;text-decoration:none}.hl .logo-symbol{height:40px;width:auto}
.logo-name{font-family:"Noto Serif JP",serif;color:rgba(255,255,255,.85);font-size:14px;letter-spacing:.13em;font-weight:300;white-space:nowrap}
nav{display:flex;align-items:center;gap:20px}
nav a{color:rgba(255,255,255,.72);text-decoration:none;font-size:12px;letter-spacing:.06em;transition:color .2s;white-space:nowrap}
nav a:hover,nav a.active{color:var(--accent-light)}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:2px;font-weight:500!important}
.page-hero{height:320px;position:relative;display:flex;align-items:flex-end;padding-bottom:52px;margin-top:64px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,rgba(15,39,66,.55) 0%,rgba(15,39,66,.30) 100%),url("../photos/group/community-event.jpg") center 35%/cover no-repeat}
.phc{position:relative;z-index:1;padding:0 80px}
.bc{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.bc a{font-size:12px;color:rgba(255,255,255,.45);text-decoration:none;letter-spacing:.06em}.bc a:hover{color:rgba(255,255,255,.75)}
.bc span{font-size:12px;color:rgba(255,255,255,.3)}.bc .cur{color:rgba(255,255,255,.6)}
.pen{font-size:12px;letter-spacing:.25em;color:var(--accent);text-transform:uppercase;font-weight:500;margin-bottom:10px;display:block}
.pt{font-family:"Noto Serif JP",serif;font-size:clamp(26px,3.5vw,42px);color:#fff;letter-spacing:.06em;font-weight:400}
.sec-nav{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.07);position:sticky;top:64px;z-index:90}
.sec-nav-inner{max-width:1200px;margin:0 auto;padding:0 80px;display:flex}
.sec-nav a{display:flex;align-items:center;padding:16px 24px;color:rgba(255,255,255,.5);text-decoration:none;font-size:12px;letter-spacing:.08em;transition:all .2s;border-bottom:2px solid transparent;white-space:nowrap}
.sec-nav a:hover,.sec-nav a.active{color:#fff;border-bottom-color:var(--accent)}
.sw{max-width:1200px;margin:0 auto;padding:0 80px}
.sh{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:48px}
.se{font-family:"Bebas Neue",sans-serif;font-size:clamp(36px,5vw,56px);letter-spacing:.07em;color:var(--navy);text-transform:uppercase;font-weight:400;line-height:1}
.sl{width:28px;height:1px;background:var(--accent);display:block;margin:6px 0}
.sj{font-family:"Noto Serif JP",serif;font-size:clamp(18px,2.2vw,24px);color:var(--navy);font-weight:400;letter-spacing:.08em}

/* LEAD ROW */
.lead-row{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid rgba(13,31,53,.1);margin-bottom:4px;min-height:340px}
.lead-photo{position:relative;overflow:hidden}
.lead-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lead-text{padding:56px 52px;display:flex;flex-direction:column;justify-content:center;background:var(--sus-dark)}
.lead-body{font-family:"Noto Serif JP",serif;font-size:16px;color:var(--navy);line-height:2.2;letter-spacing:.06em;font-weight:400;border-left:3px solid var(--navy);padding-left:20px;margin-bottom:20px}
.lead-sub{font-size:15px;color:var(--text-mid);line-height:2.2;letter-spacing:.04em;font-weight:300}

/* PILLAR SECTIONS */
.pillar-sec{padding:80px 0;border-bottom:1px solid rgba(13,31,53,.08)}
.pillar-sec:last-of-type{border-bottom:none}
.pillar-sec.alt{background:var(--sus-dark)}
.pillar-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid rgba(13,31,53,.1)}
.pillar-photo{position:relative;overflow:hidden;min-height:360px}
.pillar-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pillar-text{padding:52px 52px;display:flex;flex-direction:column;justify-content:center;background:var(--sus-bg)}
.pillar-sec.alt .pillar-text{background:var(--sus-dark)}
.p-tag{font-size:11px;letter-spacing:.2em;color:var(--navy);text-transform:uppercase;margin-bottom:12px;font-weight:500;opacity:.6}
.p-title{font-family:"Noto Serif JP",serif;font-size:clamp(20px,2.2vw,26px);color:var(--navy);margin-bottom:18px;letter-spacing:.04em;font-weight:500;border-left:3px solid var(--accent);padding-left:16px}
.p-body{font-size:15px;color:var(--text-mid);line-height:2.3;letter-spacing:.04em;font-weight:300;margin-bottom:20px}
.p-ul{list-style:none}
.p-ul li{font-size:13px;color:var(--text-mid);line-height:2.0;padding-left:14px;position:relative;font-weight:300}
.p-ul li::before{content:"—";position:absolute;left:0;color:var(--accent);font-size:9px;top:5px}

/* CERTS */
.cert-section{background:var(--navy);padding:72px 0}
.cert-inner{max-width:1200px;margin:0 auto;padding:0 80px}
.cert-inner .se{color:#fff}
.cert-inner .sj{color:rgba(255,255,255,.85)}
.cert-inner .sl{background:var(--accent)}
/* 件数非依存: 各行中央寄せ。行の分割点は generate_cert.py が .cert-break で挿入
   （7件以上は均等2行＝ほぼ半数ずつ、13件以上は均等3行…と自動で半分割される） */
.cert-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:44px 40px}
.cert-grid .cert-break{flex-basis:100%;height:0;margin:0;padding:0}
.cert-item{display:flex;flex-direction:column;align-items:center;gap:8px;width:120px}
.cert-img-wrap{width:100px;height:100px;border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;padding:8px}
.cert-img-wrap img{max-width:100%;max-height:100%;object-fit:contain}
.cert-name{font-size:12px;color:rgba(255,255,255,.4);text-align:center;letter-spacing:.04em;line-height:1.6;font-weight:300;width:120px}
/* 件数非依存: ABOUT が奇数件のとき末尾カードを全幅化（左寄せ半端を回避） */
#cert-about .hub-card:last-child:nth-child(odd){grid-column:1 / -1}
.cert-about-logo{height:60px;display:flex;align-items:center;margin-bottom:18px}
.cert-about-logo img{height:60px;width:auto;max-width:150px;object-fit:contain;display:block}

footer{background:var(--navy);padding:48px 80px 26px;border-top:1px solid rgba(255,255,255,.07)}
.ft-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
.ft-logo-wrap img{height:28px;width:auto;display:block;margin-bottom:10px}
.ft-co{font-size:13px;color:rgba(255,255,255,.5);letter-spacing:.07em;font-family:"Noto Serif JP",serif;margin-bottom:10px}
.ft-addr{font-size:12px;color:rgba(255,255,255,.55);line-height:2.0;letter-spacing:.04em;font-weight:300}
.ft-hours{font-size:12px;color:rgba(255,255,255,.55);line-height:1.9;letter-spacing:.04em;font-weight:300;margin-top:8px;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}
.ft-sns{display:flex;gap:8px;margin-top:18px}
.sns-btn{width:32px;height:32px;border:1px solid rgba(255,255,255,.36);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .2s,background .2s}
.sns-btn:hover{border-color:var(--accent);background:rgba(255,255,255,.04)}.sns-btn svg{width:14px;height:14px;fill:rgba(255,255,255,.6)}
.sns-btn svg.si{fill:none;stroke:rgba(255,255,255,.6);stroke-width:1.5}
.ft-nav{display:grid;grid-template-columns:repeat(4,auto);gap:8px 36px;align-content:start}
.ft-nav a{font-size:12px;color:rgba(255,255,255,.7);text-decoration:none;letter-spacing:.06em;transition:color .2s;white-space:nowrap}
.ft-nav a:hover{color:var(--accent-light)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center}
.ft-policies{display:flex;gap:18px;flex-wrap:wrap}
.ft-policies a{font-size:11px;color:rgba(255,255,255,.55);text-decoration:none;letter-spacing:.04em}
.ft-copy{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.06em}
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;cursor:pointer;background:none;border:none;padding:0;flex-shrink:0}
.hamburger span{display:block;height:2px;background:rgba(255,255,255,.85);border-radius:1px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:360px){.logo-name{display:none}}
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:98}
.drawer-overlay.open{display:block}
.drawer-menu{position:fixed;top:64px;right:0;width:260px;height:calc(100vh - 64px);background:#0d2540;z-index:99;overflow-y:auto;border-left:1px solid rgba(255,255,255,.1);box-shadow:-4px 0 24px rgba(0,0,0,.4);transform:translateX(100%);transition:transform .28s ease}
.drawer-menu.open{transform:translateX(0)}
.drawer-menu a{display:block;width:100%;padding:0 24px;height:48px;line-height:48px;color:rgba(255,255,255,.85);text-decoration:none;font-size:14px;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.07);box-sizing:border-box;transition:background .15s,color .15s}
.drawer-menu a:hover{background:rgba(255,255,255,.07);color:#fff}
.drawer-menu a.active{color:var(--accent-light);border-left:3px solid var(--accent);padding-left:21px}
.drawer-cta{display:block;padding:0 24px;height:48px;line-height:48px;background:var(--accent);color:#fff!important;text-decoration:none;font-size:14px;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.07);transition:background .15s,color .15s;margin-top:8px}
.drawer-cta:hover{background:var(--accent-light)!important;color:#fff!important}
@media(max-width:960px){
  header{padding:0 18px}
  nav{display:none}
  .hamburger{display:flex}
      .phc,.sw,.cert-inner{padding:0 20px}
  .lead-row,.pillar-layout{grid-template-columns:1fr}
  .lead-photo,.pillar-photo{min-height:220px}.lead-text,.pillar-text{padding:32px 20px}
  .sec-nav-inner{padding:0 20px;overflow-x:auto}
  footer{padding:36px 20px 22px}.ft-top{flex-direction:column;gap:32px}
  .ft-nav{grid-template-columns:1fr 1fr}.ft-bottom{flex-direction:column;gap:12px}
}

header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:rgba(15,39,66,.97);border-bottom:1px solid rgba(255,255,255,.07)}
.header-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-logo .logo-symbol{height:40px;width:auto;display:block}
.header-logo .logo-name{font-family:"Noto Serif JP",serif;color:rgba(255,255,255,.88);font-size:14px;letter-spacing:.12em;font-weight:300;white-space:nowrap}
nav{display:flex;align-items:center;gap:20px}
nav a{color:rgba(255,255,255,.72);text-decoration:none;font-size:12px;letter-spacing:.06em;transition:color .2s;white-space:normal}
nav a:hover{color:var(--accent-light)}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:2px;font-weight:500!important}
.nav-cta:hover{background:var(--accent-light)!important}

/* ── FOOTER ── */
footer{background:var(--navy);padding:48px 80px 26px;border-top:1px solid rgba(255,255,255,.07)}
.ft-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
/* フッターロゴ: 白背景PNG */
.ft-logo-wrap{display:inline-block;margin-bottom:14px}
.ft-logo-wrap .logo-symbol{height:48px;width:auto;display:block}
.ft-co{font-size:13px;color:rgba(255,255,255,.5);letter-spacing:.07em;font-family:"Noto Serif JP",serif;margin-bottom:10px}
.ft-addr{font-size:12px;color:rgba(255,255,255,.55);line-height:2.0;letter-spacing:.04em;font-weight:300}
.ft-hours{font-size:12px;color:rgba(255,255,255,.55);line-height:1.9;letter-spacing:.04em;font-weight:300;margin-top:8px;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}
.ft-sns{display:flex;gap:8px;margin-top:18px}
.sns-btn{width:32px;height:32px;border:1px solid rgba(255,255,255,.36);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .2s,background .2s}
.sns-btn:hover{border-color:var(--accent);background:rgba(255,255,255,.04)}
.sns-btn svg{width:14px;height:14px;fill:rgba(255,255,255,.6)}
.sns-btn svg.si{fill:none;stroke:rgba(255,255,255,.6);stroke-width:1.5}
.ft-nav{display:grid;grid-template-columns:repeat(4,auto);gap:8px 36px;align-content:start}
.ft-nav a{font-size:12px;color:rgba(255,255,255,.7);text-decoration:none;letter-spacing:.06em;transition:color .2s;white-space:normal}
.ft-nav a:hover{color:var(--accent-light)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center}
.ft-policies{display:flex;gap:18px;flex-wrap:wrap}
.ft-policies a{font-size:11px;color:rgba(255,255,255,.55);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.ft-policies a:hover{color:rgba(255,255,255,.85)}
.ft-copy{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.06em}

/* Hub card pattern (pillars-overview section) */
.hub-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(15,39,66,.08);margin-top:32px}
.hub-card{background:#fff;padding:36px 32px;text-decoration:none;color:var(--navy);transition:background .25s;border-top:3px solid transparent;display:block}
.hub-card:hover{background:var(--gray-light)}
.hub-eyebrow{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:.22em;color:var(--accent);font-weight:500;margin-bottom:8px}
.hub-title{font-family:'Noto Serif JP',serif;font-size:18px;color:var(--navy);font-weight:400;letter-spacing:.05em;margin:0 0 12px}
.hub-desc{font-size:14px;line-height:1.95;color:var(--text-mid);margin:0 0 16px}
.hub-readmore{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:.18em;color:var(--accent)}
.hub-cta-h2{font-family:'Noto Serif JP',serif;font-size:clamp(20px,2.4vw,26px);color:var(--navy);font-weight:400;letter-spacing:.06em;margin:0 0 28px;line-height:1.55}
/* AWARDS button-style hub link */
.hub-cert-wrap{margin-top:48px;text-align:center}
.hub-cert-link{display:inline-flex;align-items:center;gap:14px;padding:14px 28px;border:1px solid rgba(15,39,66,.18);text-decoration:none;color:var(--navy);transition:background .25s,color .25s,border-color .25s}
.hub-cert-link:hover{background:var(--gray-light);border-color:rgba(15,39,66,.4)}
.hub-cert-eyebrow{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:.22em;color:var(--accent);font-weight:500}
.hub-cert-label{font-family:'Noto Serif JP',serif;font-size:14px;color:var(--navy)}
.hub-cert-arrow{color:var(--accent)}

/* Section navigation cards (about-nav と同形式・サステナ名前空間) */
.sus-nav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(15,39,66,.08);margin-top:40px}
.sus-nav-card{background:#fff;padding:36px 28px;text-decoration:none;color:var(--navy);transition:background .25s;display:flex;flex-direction:column;border-top:3px solid transparent;min-height:200px}
.sus-nav-card:hover{background:#fff;border-top-color:var(--accent);box-shadow:0 12px 32px -12px rgba(15,39,66,.18);transform:translateY(-2px)}
.sn-num{font-family:"Bebas Neue",sans-serif;font-size:13px;letter-spacing:.22em;color:var(--accent);font-weight:500;margin-bottom:10px}
.sn-en{font-family:"Bebas Neue",sans-serif;font-size:22px;color:var(--navy);letter-spacing:.06em;line-height:1.1;margin-bottom:6px;font-weight:500}
.sn-ja{font-family:"Noto Serif JP",serif;font-size:16px;color:var(--navy);font-weight:500;letter-spacing:.05em;margin-bottom:14px}
.sn-txt{font-size:13px;color:var(--text-mid);line-height:1.95;letter-spacing:.04em;font-weight:300;flex-grow:1}
.sn-arr{font-family:"Bebas Neue",sans-serif;font-size:11px;letter-spacing:.18em;color:var(--accent);margin-top:16px;font-weight:500}
@media(max-width:960px){.sus-nav-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sus-nav-grid{grid-template-columns:1fr}}
