:root{
  --navy-1:#1b3c8e; --navy-2:#13245d; --ink:#212121; --ink-soft:#3a3a3a;
  --muted:#5b5b5b; --line:#e5e5e5; --bg-alt:#f2f2f2; --white:#fff;
  --link:#1a5fb4; --accent-yellow:#cfe25f; --accent-cyan:#5ec8e0;
  --bar:#3a3a3a; --sidebar-w:230px;
  --font-sans:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  --font-serif:"Bitter","Noto Serif JP",Georgia,"Hiragino Mincho ProN","Yu Mincho",serif;
  --font-display:"Montserrat",var(--font-sans);
  --maxw:920px; --space:24px;
}
*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; overflow-x:clip; }
body{
  margin:0; overflow-x:clip;
  font-family:var(--font-sans); color:var(--ink);
  line-height:1.9; font-size:16px; background:var(--white);
  font-weight:400; letter-spacing:.01em;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--space)}
.skip-link{position:absolute;left:-9999px;top:0;background:#fff;padding:8px 14px;z-index:200}
.skip-link:focus{left:8px;top:8px}

/* ---- Sidebar / site bar (Google Sites 左ナビ踏襲) ---- */
.site-bar{
  position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;
  background:var(--white);border-right:1px solid var(--line);
  padding:26px 22px;display:flex;flex-direction:column;gap:22px;z-index:100;
}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink);text-decoration:none}
.brand:hover{text-decoration:none}
.brand__logo{flex:0 0 auto;border-radius:6px}
.brand__name{font-size:14px;line-height:1.45;font-weight:500;word-break:keep-all;overflow-wrap:anywhere}
.brand__sub{display:block;font-size:12px;color:var(--muted);font-weight:400}
.nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.nav a{display:block;padding:9px 10px;border-radius:6px;color:var(--ink-soft);font-size:14.5px;font-weight:500;word-break:keep-all;overflow-wrap:anywhere}
.nav a:hover{background:var(--bg-alt);text-decoration:none}
.nav a.is-active{color:var(--navy-1);background:var(--bg-alt)}
.nav-toggle{display:none}

/* ---- Main column ---- */
.main{margin-left:var(--sidebar-w);min-width:0}

/* ---- Hero (HOME) ---- */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(120deg,var(--navy-1) 0%,var(--navy-2) 70%);
  padding:78px 0 0;
}
.hero__spiro{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    radial-gradient(closest-side, rgba(255,255,255,.10), transparent 70%) -120px -90px/360px 360px no-repeat,
    radial-gradient(closest-side, rgba(255,255,255,.08), transparent 70%) right -80px top -60px/340px 340px no-repeat;}
.hero__art{position:absolute;right:0;bottom:0;width:46%;max-width:620px;z-index:1}
.hero__art img{margin-left:auto}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--space) 64px;min-height:300px}
.hero__title{font-family:var(--font-display);font-weight:700;font-size:clamp(46px,7vw,78px);letter-spacing:.04em;margin:0;line-height:1.05;word-break:keep-all}
.hero__tagline{font-family:var(--font-display);font-weight:700;font-size:clamp(20px,3vw,30px);letter-spacing:.05em;margin:18px 0 0}
.hero__tagline .y{color:var(--accent-yellow)}
.hero__tagline .c{color:var(--accent-cyan)}
/* 外部サイト導線バー */
.hero-bar{background:var(--bar);padding:16px 0}
.hero-bar__row{max-width:var(--maxw);margin:0 auto;padding:0 var(--space);display:flex;flex-wrap:wrap;gap:14px}
.hero-bar a{flex:1 1 180px;text-align:center;border:1px solid #cfcfcf;color:#fff;padding:11px 14px;border-radius:4px;font-size:14.5px;word-break:keep-all}
.hero-bar a:hover{background:rgba(255,255,255,.10);text-decoration:none}
.hero-bar__s{display:block;font-size:11.5px;color:#bdbdbd;margin-top:3px;letter-spacing:.02em} /* v3.7: 4ボタンの副題 */

/* ---- Sections ---- */
.section{padding:76px 0} /* v3.4: セクション境界のブツ切り感緩和（62→76px） */
.section--alt{background:var(--bg-alt)}
.section__head{text-align:center;margin:0 0 38px}
.section__title{font-family:var(--font-serif);font-weight:700;font-size:clamp(24px,3.4vw,30px);color:var(--ink);margin:0;word-break:keep-all;overflow-wrap:anywhere}
.section__lead{margin:14px auto 0;max-width:680px;color:var(--muted);font-size:15px}
.lead{margin:0 0 26px;color:var(--muted)}

h2,h3,h4{word-break:keep-all;overflow-wrap:anywhere}
.prose h3{font-family:var(--font-serif);font-weight:700;font-size:20px;color:var(--ink);margin:34px 0 10px;line-height:1.5}
.prose h4{font-size:17px;font-weight:600;margin:24px 0 8px}
.prose p{margin:0 0 16px}
.prose ul{margin:0 0 18px;padding-left:1.3em}
.prose li{margin:0 0 6px}
.prose .note{font-size:14px;color:var(--muted)}

/* ---- Service cards (HOME) ---- */
.svc{display:grid;gap:30px;margin:0 0 46px}
.svc:last-child{margin-bottom:0}
.svc__media{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;aspect-ratio:500/356;display:flex;align-items:center;justify-content:center}
.svc__media img{width:100%;height:100%;object-fit:cover}
.svc__ph{color:#9aa3b2;font-size:13px;text-align:center;padding:14px}
.svc__title{font-family:var(--font-serif);font-weight:700;font-size:21px;color:var(--navy-1);margin:0 0 6px;word-break:keep-all}
.svc__catch{font-weight:500;margin:0 0 10px;color:var(--ink)}
.svc__cert{font-size:14px;color:var(--muted);margin:10px 0 14px}
@media(min-width:760px){.svc{grid-template-columns:360px 1fr;align-items:center}}

/* ---- Buttons / CTA ---- */
.svc__note{font-size:13.5px;color:var(--muted);margin:8px 0 0} /* v3.74: ラボ導線の受け皿一言（新規クラス） */
.btn{display:inline-block;background:var(--navy-1);color:#fff;padding:12px 26px;border-radius:6px;font-size:15px;font-weight:500}
.btn:hover{background:var(--navy-2);text-decoration:none}
.btn--ghost{background:transparent;color:var(--navy-1);border:1px solid var(--navy-1)}
.btn--ghost:hover{background:var(--bg-alt)}
.linkmore{display:inline-block;font-size:14.5px;font-weight:500}
.cta-row{margin-top:18px;text-align:center} /* v3.8: セクション結びCTAは中央に統一（本文内linkmoreは左のまま） */

/* ---- Footer ---- */
.site-footer{margin-left:var(--sidebar-w);background:#1c1c1c;color:#cfcfcf;padding:50px 0 26px}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--space);display:grid;gap:30px}
.footer-h{font-size:13px;letter-spacing:.08em;color:#fff;margin:0 0 14px;font-weight:600}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer-col a{color:#cfcfcf;font-size:14px}
.footer-col a:hover{color:#fff}
.copyright{max-width:var(--maxw);margin:30px auto 0;padding:0 var(--space);font-size:12.5px;color:#8a8a8a}
@media(min-width:680px){.footer-inner{grid-template-columns:repeat(3,1fr)}}

/* ---- Responsive: collapse sidebar to top bar ---- */
@media(max-width:899px){
  .site-bar{position:sticky;top:0;width:auto;height:auto;flex-direction:row;align-items:center;
    justify-content:space-between;padding:12px 16px;gap:12px;border-right:0;border-bottom:1px solid var(--line)}
  .nav{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    display:none;padding:6px 12px 14px;box-shadow:0 8px 20px rgba(0,0,0,.06)}
  .nav.is-open{display:block}
  .nav ul{flex-direction:column;gap:0} /* v3.13: モバイルのドロップダウンは縦のまま */
  .nav a{padding:12px 8px;border-bottom:1px solid #f0f0f0}
  .nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
    width:42px;height:38px;background:none;border:0;cursor:pointer;padding:8px}
  .nav-toggle span{display:block;height:2px;background:var(--ink);border-radius:2px}
  .main,.site-footer{margin-left:0}
  .hero{padding-top:48px}
  .hero__art{width:54%;opacity:.92}
}
@media(max-width:560px){
  .hero-bar__row{display:grid;grid-template-columns:1fr 1fr} /* v3.8: 4ボタンを2列2行に */
  .hero__art{position:static;width:78%;margin:24px auto 0;max-width:340px}
  .hero__inner{padding-bottom:30px;min-height:0}
}

/* ---- v3.14: ナビ二箇所構成。左=元デザインのサイドバー(中身=ページ内アンカー)、上=ページ間ナビ(JS生成) ---- */
.top-pages{position:sticky;top:0;z-index:95;margin-left:var(--sidebar-w);background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--line);padding:6px 16px;display:none}
.top-pages ul{list-style:none;display:flex;flex-wrap:wrap;gap:2px;margin:0;padding:0}
.top-pages a{display:block;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;color:var(--ink-soft);white-space:nowrap}
.top-pages a:hover{background:var(--bg-alt);text-decoration:none}
.top-pages a.is-active{color:var(--navy-1);background:var(--bg-alt)}
@media(min-width:900px){.top-pages{display:block}}
main h2[id],main .core-line[id]{scroll-margin-top:64px}

/* v3.27: BUG-05 低い画面で目次が見切れないように（デスクトップ限定・サイドバー内のみ） */
@media (min-width:900px){
  .site-bar .nav{min-height:0;overflow-y:auto;overscroll-behavior:contain}
}

/* ===== v3.60: 縦書き統一ルール（各ページ一箇所・第一声の一文のみ・明朝・本文は横書き） ===== */
.vt{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--font-serif);line-height:1;letter-spacing:.16em}
.hero--vt .hero__inner{display:flex;justify-content:space-between;align-items:stretch;gap:24px}
.hero--vt .hero__lead{display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:6px}
.hero--vt .hero__title{font-size:clamp(30px,4vw,44px)}
.hero--vt .hero__tagline{font-size:clamp(13px,1.6vw,16px);letter-spacing:.14em;margin:10px 0 26px;color:rgba(255,255,255,.85)}
.hero__vt{display:flex;flex-direction:row-reverse;gap:clamp(16px,3vw,36px);padding:4px 2px 0 0}
.hero__vt-1{font-size:clamp(26px,3.8vw,38px);font-weight:500}
.hero__vt-2{font-size:clamp(15px,2vw,19px);padding-top:clamp(26px,4.6vw,56px);color:rgba(255,255,255,.92)}
.hero__vt-3{font-size:clamp(12.5px,1.6vw,15px);padding-top:clamp(56px,10vw,124px);color:rgba(255,255,255,.78)}
.hero__vrule{width:1px;background:linear-gradient(rgba(255,255,255,.45),rgba(255,255,255,.06));margin-top:6px}
@media(max-width:700px){
  .hero--vt .hero__inner{flex-direction:column-reverse}
  .hero__vt{justify-content:flex-end}
}
