body{font-family:"Noto Sans JP",sans-serif;color:var(--text-dark);background:var(--white);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)}
.header-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-logo img{height:40px;width:auto;display:block}
.logo-name{font-family:"Noto Serif JP",serif;color:rgba(255,255,255,.65);font-size:12px;letter-spacing:.1em;font-weight:300;line-height:1.5}
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/staff-three-discussion.jpg") center 35%/cover no-repeat}
.phc{position:relative;z-index:1;padding:0 80px}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.breadcrumb a{font-size:12px;color:rgba(255,255,255,.45);text-decoration:none;letter-spacing:.06em}
.breadcrumb a:hover{color:rgba(255,255,255,.75)}
.breadcrumb span{font-size:12px;color:rgba(255,255,255,.3)}
.breadcrumb .cur{color:rgba(255,255,255,.6)}
.page-en{font-size:12px;letter-spacing:.25em;color:var(--accent);text-transform:uppercase;font-weight:500;margin-bottom:10px;display:block}
.page-title{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 28px;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}
.sec-head{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:48px}
.sec-en{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}
.sec-line{width:28px;height:1px;background:var(--accent);display:block;margin:6px 0}
.sec-ja{font-family:"Noto Serif JP",serif;font-size:clamp(18px,2.2vw,24px);color:var(--navy);font-weight:400;letter-spacing:.08em}
.arr{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-size:12px;letter-spacing:.1em;transition:gap .2s;color:var(--accent)}
.arr:hover{gap:14px}
.arr::after{content:"→"}

/* PHILOSOPHY */
#philosophy{padding:96px 0;background:var(--white)}
.phil-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:64px;box-shadow:0 18px 56px -28px rgba(15,39,66,.22)}
.phil-photo{position:relative;overflow:hidden;min-height:480px}
.phil-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 25%}
.phil-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,39,66,.05) 0%,rgba(15,39,66,.18) 100%);pointer-events:none}
.phil-text{padding:64px 60px;display:flex;flex-direction:column;justify-content:center;background:var(--white);position:relative}
.phil-tag{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);text-transform:uppercase;margin-bottom:22px;font-weight:500;display:inline-flex;align-items:center;gap:14px}
.phil-tag::after{content:"";width:32px;height:1px;background:var(--accent);opacity:.65}
.phil-title{font-family:"Noto Serif JP",serif;font-size:clamp(26px,2.8vw,36px);color:var(--navy);margin-bottom:32px;line-height:1.7;letter-spacing:.06em;font-weight:500}
.phil-body{font-size:15px;color:var(--text-mid);line-height:2.4;letter-spacing:.04em;font-weight:300}

/* MISSION */
#mission{background:var(--navy);padding:96px 0}
.mission-layout{display:grid;grid-template-columns:1fr 1fr;gap:0}
.mission-photo{position:relative;overflow:hidden;min-height:400px}
.mission-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mission-photo-ov{position:absolute;inset:0;background:rgba(15,39,66,.35)}
.mission-text{padding:60px 56px;display:flex;flex-direction:column;justify-content:center;background:var(--navy-mid);border-top:3px solid var(--accent)}
.m-tag{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);text-transform:uppercase;margin-bottom:22px;font-weight:500}
.m-copy{font-family:"Noto Serif JP",serif;font-size:clamp(24px,2.8vw,36px);color:#fff;margin-bottom:22px;line-height:1.55;letter-spacing:.05em;font-weight:500;border-left:3px solid var(--accent);padding-left:20px}
.m-body{font-size:15px;color:rgba(255,255,255,.55);line-height:2.3;letter-spacing:.04em;font-weight:300}

/* VISION */
#vision{padding:96px 0;background:var(--gray-light)}
.vision-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid rgba(13,31,53,.08);margin-bottom:0}
.vision-photo{position:relative;overflow:hidden;min-height:400px}
.vision-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vision-text{padding:60px 56px;display:flex;flex-direction:column;justify-content:center;background:var(--gray-light)}
.v-tag{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);text-transform:uppercase;margin-bottom:22px;font-weight:500}
.v-title{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.5vw,32px);color:var(--navy);margin-bottom:20px;line-height:1.6;letter-spacing:.04em;font-weight:400;border-left:3px solid var(--accent);padding-left:20px}
.v-body{font-size:15px;color:var(--text-mid);line-height:2.4;letter-spacing:.04em;font-weight:300}

/* VALUES */
#values{background:var(--navy);padding:96px 0}
.values-inner{max-width:1200px;margin:0 auto;padding:0 80px}
.values-inner .sec-en{color:#fff}
.values-inner .sec-ja{color:rgba(255,255,255,.85)}
.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;background:rgba(255,255,255,.05)}
.val-card{background:rgba(15,39,66,.75);padding:32px 24px;border-bottom:2px solid transparent;transition:all .3s}
.val-card:hover{background:var(--navy-mid);border-bottom-color:var(--accent)}
.val-num{font-size:11px;letter-spacing:.18em;color:var(--accent);margin-bottom:8px;font-weight:500}
.val-en{font-size:11px;letter-spacing:.14em;color:rgba(255,255,255,.3);text-transform:uppercase;margin-bottom:10px;font-weight:300}
.val-title{font-size:15px;color:#fff;font-weight:500;margin-bottom:12px;letter-spacing:.04em;font-family:"Noto Serif JP",serif}
.val-body{font-size:13px;color:rgba(255,255,255,.42);line-height:1.9;letter-spacing:.03em;font-weight:300}

/* ── MVV: Mission intent note ── */
#mission .sec-en{color:#fff}
#mission .sec-ja{color:rgba(255,255,255,.85)}
#mission .sec-line{background:var(--accent)}
.mission-intent{margin-top:48px;padding:32px 40px;background:rgba(255,255,255,.05);border-left:3px solid var(--accent);max-width:820px}
.mission-intent-label{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.22em;color:var(--accent);margin-bottom:12px;font-weight:500}
.mission-intent-body{font-size:14px;color:rgba(255,255,255,.7);line-height:2.0;letter-spacing:.04em;font-weight:300}

/* ── MVV: Rich value cards ── */
.val-rich-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:8px}
.val-rich-card{display:grid;grid-template-columns:240px 1fr;gap:48px;background:rgba(255,255,255,.04);border-left:3px solid var(--accent);padding:48px 48px}
.val-rich-card:hover{background:rgba(255,255,255,.07)}
.val-rich-head{}
.val-rich-icon{width:52px;height:52px;border-radius:50%;background:rgba(232,93,27,.12);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.val-rich-icon svg{width:26px;height:26px;stroke:var(--accent);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.val-rich-num{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);margin-bottom:14px;font-weight:500;display:inline-flex;align-items:center;gap:14px}
.val-rich-num::after{content:"";width:32px;height:1px;background:var(--accent);opacity:.65}
.val-rich-en{font-family:"Bebas Neue",sans-serif;font-size:32px;color:rgba(255,255,255,.35);line-height:1;letter-spacing:.04em;margin-bottom:14px}
.val-rich-title{font-family:"Noto Serif JP",serif;font-size:24px;color:#fff;font-weight:500;letter-spacing:.05em;line-height:1.4}
.val-rich-body{}
.val-rich-lead{font-family:"Noto Serif JP",serif;font-size:17px;color:#fff;margin-bottom:26px;font-weight:500;line-height:1.85;letter-spacing:.04em;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.14)}
.val-rich-list{list-style:none;padding:0;margin:0}
.val-rich-list li{font-size:13px;color:rgba(255,255,255,.6);line-height:2.05;padding-left:22px;position:relative;margin-bottom:14px;letter-spacing:.03em;font-weight:300}
.val-rich-list li::before{content:"";position:absolute;left:0;top:.85em;width:10px;height:1px;background:var(--accent);opacity:.7}
.val-rich-list li:last-child{margin-bottom:0}
@media(max-width:760px){.val-rich-card{grid-template-columns:1fr;gap:24px;padding:36px 26px}.val-rich-lead{font-size:16px}}

/* ── Philosophy: 3-pillar animated Venn ── */
.phil-venn-wrap{display:flex;justify-content:center;margin:56px 0 80px}
.phil-venn{width:min(620px,100%);height:auto;overflow:visible}

.venn-g{transition:transform 1.4s cubic-bezier(.5,.1,.3,1), opacity 1.2s ease}
.venn-g circle{transition:fill-opacity .9s ease}
.phil-venn-wrap .venn-g-safety{transform:translate(-110px,-55px);opacity:0}
.phil-venn-wrap .venn-g-bond{transform:translate(110px,-55px);opacity:0}
.phil-venn-wrap .venn-g-contrib{transform:translate(0,110px);opacity:0}
.phil-venn-wrap .venn-g-safety circle{fill:#3D8E5C;fill-opacity:0}
.phil-venn-wrap .venn-g-bond circle{fill:#C73E3A;fill-opacity:0}
.phil-venn-wrap .venn-g-contrib circle{fill:#D4A017;fill-opacity:0}
.phil-venn-wrap.on .venn-g-safety,
.phil-venn-wrap.on .venn-g-bond,
.phil-venn-wrap.on .venn-g-contrib{transform:translate(0,0);opacity:1}
.phil-venn-wrap.on .venn-g-safety circle{fill-opacity:.40}
.phil-venn-wrap.on .venn-g-bond circle{fill-opacity:.40}
.phil-venn-wrap.on .venn-g-contrib circle{fill-opacity:.42}

.venn-labels{opacity:0;transition:opacity .9s ease}
.phil-venn-wrap.on .venn-labels{opacity:1;transition-delay:.9s}
.phil-venn-wrap .venn-trust-glow{opacity:0}
.phil-venn-wrap.on .venn-trust-glow{animation:trustGlowAppear 1.8s cubic-bezier(.3,.1,.35,1) 1.0s both}
@keyframes trustGlowAppear{
  0%{r:0;opacity:0}
  35%{opacity:1}
  100%{r:135;opacity:1}
}
.phil-venn-wrap .venn-trust text{opacity:0;transition:opacity 1.1s ease}
.phil-venn-wrap.on .venn-trust text{opacity:1;transition-delay:1.9s}

/* ── Philosophy: Pillar cards with distinct colors ── */
.phil-pillars-intro{text-align:center;margin:64px 0 32px}
.phil-pillars-intro-en{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.24em;color:var(--accent);font-weight:500;margin-bottom:10px;text-transform:uppercase}
.phil-pillars-intro h2,.phil-pillars-intro h3{font-family:"Noto Serif JP",serif;font-size:clamp(20px,2.3vw,28px);color:var(--navy);font-weight:500;letter-spacing:.06em;margin-bottom:16px;line-height:1.5}
.phil-pillars-intro p{font-size:15px;color:var(--text-mid);line-height:2;letter-spacing:.04em;max-width:680px;margin:0 auto;font-weight:300}
.phil-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}
.phil-pillar-card{background:#fff;border-top:4px solid var(--p-color,var(--accent));padding:48px 36px 40px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .3s, box-shadow .3s}
.phil-pillar-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(15,39,66,.1)}
.phil-pillar-card::before{content:"";position:absolute;top:0;right:0;width:140px;height:140px;background:radial-gradient(circle at top right,var(--p-color,var(--accent)) 0%,transparent 70%);opacity:.07;pointer-events:none}
.phil-pillar-card[data-pillar="safety"]{--p-color:#3D8E5C}
.phil-pillar-card[data-pillar="bond"]{--p-color:#C73E3A}
.phil-pillar-card[data-pillar="contrib"]{--p-color:#9F7610}
.pp-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px;position:relative;z-index:1}
.phil-pillar-card[data-pillar="safety"] .pp-icon{background:rgba(61,142,92,.12)}
.phil-pillar-card[data-pillar="bond"] .pp-icon{background:rgba(199,62,58,.12)}
.phil-pillar-card[data-pillar="contrib"] .pp-icon{background:rgba(212,160,23,.14)}
.pp-icon svg{width:26px;height:26px;stroke:var(--p-color);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.pp-en{font-family:"Bebas Neue",sans-serif;font-size:30px;letter-spacing:.08em;line-height:1;margin-bottom:6px;color:var(--p-color);position:relative;z-index:1}
.pp-ja{font-family:"Noto Serif JP",serif;font-size:24px;color:var(--navy);font-weight:500;margin-bottom:18px;letter-spacing:.05em;position:relative;z-index:1}
.pp-body{font-size:15px;color:var(--text-mid);line-height:2.0;letter-spacing:.04em;font-weight:300;position:relative;z-index:1}
@media(max-width:760px){.phil-pillars{grid-template-columns:1fr}.phil-venn{max-width:480px}}

/* CTA */
.cta-banner{background:var(--accent);padding:56px 80px;display:flex;align-items:center;justify-content:space-between;gap:40px}
.cta-text h2{font-family:"Noto Serif JP",serif;font-size:22px;color:#fff;margin-bottom:8px;letter-spacing:.04em;font-weight:400}
.cta-text p{font-size:15px;color:rgba(255,255,255,.8);letter-spacing:.04em}
.cta-btns{display:flex;gap:12px;flex-shrink:0}
.btn-white{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--accent);text-decoration:none;padding:14px 32px;font-size:14px;letter-spacing:.1em;font-weight:500;transition:background .2s;white-space:nowrap}
.btn-white:hover{background:rgba(255,255,255,.9)}

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,.values-inner{padding:0 20px}
  .phil-layout,.mission-layout,.vision-layout{grid-template-columns:1fr}
  .phil-photo,.mission-photo,.vision-photo{min-height:240px}
  .phil-text,.mission-text,.vision-text{padding:36px 24px}
  .values-grid{grid-template-columns:1fr 1fr}
  .cta-banner{flex-direction:column;padding:40px 20px;text-align:center}
  .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}

/* ── ABOUT INTRO BAND (landing intro) ── */
.about-intro-sec{background:var(--navy);padding:80px 0;color:#fff;position:relative;overflow:hidden}
.about-intro-sec::before{content:"";position:absolute;top:-40%;right:-10%;width:60%;height:180%;background:radial-gradient(ellipse,rgba(232,93,27,.08) 0%,transparent 60%);pointer-events:none}
.about-intro-inner{max-width:1200px;margin:0 auto;padding:0 80px;position:relative;z-index:1}
.about-intro-sec .sec-en{color:#fff}
.about-intro-sec .sec-ja{color:rgba(255,255,255,.85)}
.about-intro-sec .sec-line{background:var(--accent)}
.about-intro-headline{font-family:"Noto Serif JP",serif;font-size:clamp(26px,3.2vw,40px);color:#fff;font-weight:500;letter-spacing:.06em;line-height:1.55;margin-bottom:28px;max-width:880px;border-left:3px solid var(--accent);padding-left:24px}
.about-intro-body{font-size:15px;color:rgba(255,255,255,.72);line-height:2.2;letter-spacing:.04em;font-weight:300;max-width:880px;margin-bottom:48px}
.about-intro-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;padding-top:52px;margin-top:8px;border-top:1px solid rgba(255,255,255,.22)}
.about-intro-stats > div{position:relative;padding-left:22px}
.about-intro-stats > div::before{content:"";position:absolute;left:0;top:6px;bottom:10px;width:2px;background:var(--accent);opacity:.85}
.about-intro-stats .num{display:flex;align-items:baseline;font-family:"Bebas Neue",sans-serif;font-size:clamp(56px,7vw,84px);color:#fff;line-height:1;letter-spacing:.02em;font-weight:500}
.about-intro-stats .num .u{font-family:"Noto Sans JP",sans-serif;font-size:.26em;color:var(--accent);margin-left:8px;letter-spacing:.04em;font-weight:500;line-height:1}
.about-intro-stats .lbl{font-size:12.5px;color:rgba(255,255,255,.68);letter-spacing:.06em;margin-top:14px;line-height:1.65;font-weight:300}
@media(max-width:760px){.about-intro-stats{grid-template-columns:1fr 1fr;gap:36px 28px;padding-top:36px}.about-intro-stats > div{padding-left:18px}.about-intro-sec{padding:56px 0}}

/* OUR STRENGTH (dynamic redesign) */
.strength-sec{background:#F2F4F6;padding:112px 0 104px;position:relative;overflow:hidden}
.strength-sec::before{content:"";position:absolute;top:-80px;right:-80px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(232,93,27,.06) 0%,rgba(232,93,27,0) 70%);pointer-events:none}
.strength-inner{max-width:1200px;margin:0 auto;padding:0 80px;position:relative;z-index:1}
.svc-sec-lbl{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.24em;color:var(--accent);font-weight:500;margin-bottom:10px;text-transform:uppercase}
.svc-sec-en{font-family:"Bebas Neue",sans-serif;font-size:clamp(44px,6vw,72px);letter-spacing:.05em;color:var(--navy);line-height:1;font-weight:500;margin-bottom:8px}
.svc-sec-jp{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.6vw,32px);color:var(--navy);font-weight:400;letter-spacing:.06em;margin:0 0 24px}
.strength-lead{font-size:15px;color:var(--text-mid);line-height:2.2;letter-spacing:.04em;font-weight:300;max-width:780px;margin-bottom:64px}

/* 4 行交互 magazine レイアウト */
.strength-rows{display:flex;flex-direction:column;gap:64px}
.strength-row{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:#fff;box-shadow:0 18px 56px -28px rgba(15,39,66,.24),0 4px 12px -6px rgba(15,39,66,.12);transition:box-shadow .4s ease,transform .4s ease;overflow:hidden}
.strength-row:hover{transform:translateY(-4px);box-shadow:0 28px 72px -24px rgba(15,39,66,.32),0 6px 18px -6px rgba(15,39,66,.18)}
.strength-row-photo{position:relative;overflow:hidden;background:var(--navy);min-height:420px}
.strength-row-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.6,.2,1);filter:brightness(.88) saturate(1)}
.strength-row:hover .strength-row-photo img{transform:scale(1.05)}
.strength-row-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,39,66,.10) 0%,rgba(15,39,66,.22) 100%);pointer-events:none}
.strength-row-n{position:absolute;top:28px;left:36px;z-index:2;font-family:"Bebas Neue",sans-serif;font-size:clamp(96px,10vw,150px);color:rgba(255,255,255,.97);line-height:1;letter-spacing:.02em;text-shadow:0 2px 28px rgba(0,0,0,.45)}
.strength-row-content{display:flex;flex-direction:column;justify-content:center;padding:56px 56px}
.strength-row--alt .strength-row-photo{order:2}
.strength-row--alt .strength-row-content{order:1}
.strength-ttl-en{font-family:"Bebas Neue",sans-serif;font-size:13px;letter-spacing:.22em;color:var(--accent);font-weight:500;margin-bottom:10px;display:block}
.strength-ttl{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.4vw,30px);color:var(--navy);font-weight:500;letter-spacing:.06em;margin-bottom:20px;line-height:1.55}
.strength-txt{font-size:15px;color:var(--text-mid);line-height:2.05;letter-spacing:.04em;font-weight:300;margin-bottom:0}
.strength-txt strong{color:var(--navy);font-weight:500}
.strength-pts{margin-top:24px;padding-top:18px;border-top:1px solid rgba(15,39,66,.10);display:flex;gap:8px;flex-wrap:wrap}
.strength-pts span{display:inline-flex;align-items:center;font-family:"Noto Sans JP",sans-serif;font-size:11px;letter-spacing:.12em;color:#fff;font-weight:500;padding:6px 12px;background:var(--accent);border-radius:2px;line-height:1.2;white-space:nowrap}
@media(max-width:960px){
  .strength-rows{gap:40px}
  .strength-row,.strength-row--alt{grid-template-columns:1fr}
  .strength-row--alt .strength-row-photo,.strength-row--alt .strength-row-content{order:initial}
  .strength-row-photo{aspect-ratio:4/3;min-height:240px}
  .strength-row-content{padding:32px 24px}
  .strength-row-n{top:18px;left:22px;font-size:clamp(64px,16vw,96px)}
  .strength-sec{padding:64px 0}
}

/* ── About page navigation cards (bottom of strength page) ── */
.about-nav-sec{background:#F2F4F6;padding:96px 0}
.about-nav-inner{max-width:1200px;margin:0 auto;padding:0 80px}
.about-nav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(15,39,66,.08);margin-top:40px}
.about-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}
.about-nav-card:hover{background:#fff;border-top-color:var(--accent);box-shadow:0 12px 32px -12px rgba(15,39,66,.18);transform:translateY(-2px)}
.an-num{font-family:"Bebas Neue",sans-serif;font-size:13px;letter-spacing:.22em;color:var(--accent);font-weight:500;margin-bottom:10px}
.an-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}
.an-ja{font-family:"Noto Serif JP",serif;font-size:16px;color:var(--navy);font-weight:500;letter-spacing:.05em;margin-bottom:14px}
.an-txt{font-size:13px;color:var(--text-mid);line-height:1.95;letter-spacing:.04em;font-weight:300;flex-grow:1}
.an-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){.about-nav-grid{grid-template-columns:1fr 1fr}.about-nav-sec{padding:64px 0}}
@media(max-width:560px){.about-nav-grid{grid-template-columns:1fr}}

/* ── CEO Message (about-message.html) ── */
.ceo-sec{padding:96px 0;background:var(--white)}
.ceo-layout{display:grid;grid-template-columns:minmax(360px,460px) 1fr;gap:72px;margin-top:48px;align-items:stretch}
.ceo-photo{position:relative;overflow:hidden;background:var(--navy);min-height:560px}
.ceo-photo img{display:block;width:100%;height:100%;object-fit:cover;object-position:center top}
.ceo-photo-band{position:absolute;top:24px;left:0;background:var(--accent);color:#fff;font-family:"Bebas Neue",sans-serif;font-size:11px;letter-spacing:.28em;font-weight:500;padding:7px 18px 7px 22px;z-index:2}
.ceo-photo--fallback img{display:none}
.ceo-photo-fallback{padding:48px 32px;color:#fff;font-family:"Noto Serif JP",serif;font-size:18px;letter-spacing:.06em;line-height:1.7;display:flex;flex-direction:column;justify-content:center;height:100%}
.ceo-photo-fallback span{font-size:24px;margin-top:14px;display:block}
.ceo-body{padding-top:8px}
.ceo-h2{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.5vw,28px);color:var(--navy);font-weight:500;letter-spacing:.06em;line-height:1.7;margin-bottom:32px;border-left:3px solid var(--accent);padding-left:20px}
.ceo-p{font-size:15px;color:var(--text-mid);line-height:2.2;letter-spacing:.04em;font-weight:400;margin-bottom:18px}
.ceo-p strong{color:var(--navy);font-weight:500}
.ceo-p .ceo-accent,.ceo-p strong.ceo-accent{color:var(--accent);font-weight:500}
.ceo-p--last{margin-bottom:48px}
.ceo-pull{position:relative;margin:36px 0 36px;padding:32px 28px 30px 36px;background:linear-gradient(135deg,rgba(232,93,27,.04) 0%,rgba(15,39,66,.04) 100%);border-left:3px solid var(--accent)}
.ceo-pull::before{content:"";position:absolute;top:18px;right:22px;width:48px;height:36px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 36' fill='none' stroke='%23E85D1B' stroke-width='1.5' opacity='.45'><path d='M14 6h-8v12c0 6 0 12 8 12'/><path d='M40 6h-8v12c0 6 0 12 8 12'/></svg>") no-repeat center/contain;pointer-events:none}
.ceo-pull-en{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);font-weight:500;display:block;margin-bottom:10px}
.ceo-pull-jp{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.6vw,30px);color:var(--navy);font-weight:500;letter-spacing:.08em;line-height:1.6;margin:0 0 10px}
.ceo-pull-sub{font-size:13px;color:var(--text-mid);line-height:1.9;letter-spacing:.06em;font-weight:300;margin:0}
.ceo-sign{margin-top:8px}
.ceo-sign-rule{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.ceo-sign-rule::after{content:"";flex:1;height:1px;background:linear-gradient(to right,rgba(15,39,66,.18),rgba(15,39,66,0))}
.ceo-sign-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}
.ceo-sign-co{text-align:right;font-family:"Noto Serif JP",serif;font-size:13px;color:var(--text-mid);letter-spacing:.08em;line-height:1.7;font-weight:400}
.ceo-sign-name{text-align:right;font-family:"Noto Serif JP",serif;font-size:19px;color:var(--navy);letter-spacing:.08em;line-height:1.6;font-weight:500;margin-top:4px}
@media(max-width:760px){.ceo-sec{padding:64px 0}.ceo-layout{grid-template-columns:1fr;gap:36px;align-items:start}.ceo-photo{max-width:360px;margin:0 auto;min-height:auto;aspect-ratio:4/5}.ceo-pull{padding:28px 22px 26px 28px}.ceo-pull::before{width:36px;height:28px;top:14px;right:16px}}

/* ── About Numbers: 3 themed blocks ── */
.numbers-blocks{display:flex;flex-direction:column;gap:80px;margin-bottom:72px}
.numbers-block{position:relative}
.numbers-block-head{margin-bottom:28px;display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.numbers-block-en{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);font-weight:500}
.numbers-block-jp{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.4vw,30px);color:var(--navy);font-weight:500;letter-spacing:.06em;line-height:1.5;margin:0}
.numbers-block-desc{font-size:14px;color:var(--text-mid);line-height:1.95;letter-spacing:.04em;font-weight:300;max-width:680px;margin-top:6px}
.numbers-block-layout{display:grid;grid-template-columns:minmax(320px,440px) 1fr;gap:32px;align-items:stretch}
.numbers-block-photo{position:relative;overflow:hidden;background:var(--navy);aspect-ratio:3/4;min-height:380px}
.numbers-block-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.6,.2,1)}
.numbers-block:hover .numbers-block-photo img{transform:scale(1.04)}
.numbers-block-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,39,66,.04) 0%,rgba(15,39,66,.18) 100%);pointer-events:none}
.numbers-block-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:rgba(15,39,66,.08);align-self:stretch}
.numbers-block-grid .num-card{margin:0}
/* alternate: block 2 has photo on right */
.numbers-block--alt .numbers-block-layout{grid-template-columns:1fr minmax(320px,440px)}
.numbers-block--alt .numbers-block-photo{order:2}
.numbers-block--alt .numbers-block-grid{order:1}
@media(max-width:960px){
  .numbers-blocks{gap:56px}
  .numbers-block-layout,.numbers-block--alt .numbers-block-layout{grid-template-columns:1fr;gap:24px}
  .numbers-block--alt .numbers-block-photo,.numbers-block--alt .numbers-block-grid{order:initial}
  .numbers-block-photo{aspect-ratio:4/3;min-height:240px}
  .numbers-block-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .numbers-block-grid{grid-template-columns:1fr}
}
