/* news-detail.css
   Extracted from news-detail-001.html embedded <style> (Phase B-1, 2026-05-15).
   Shared across news-detail-001..006.html.
*/

body{font-family:"Noto Sans JP",sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden}

/* ── HEADER ── */
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:transparent;border-bottom:1px solid transparent;transition:background .4s,border-color .4s}
header.scrolled{background:rgba(15,39,66,.97);border-bottom-color: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;flex-wrap:nowrap;overflow:hidden}
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{color:var(--accent-light)}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:2px;font-weight:500!important;flex-shrink:0;white-space:nowrap}
.nav-cta:hover{background:var(--accent-light)!important}

/* ── HERO ── */
#hero{height:100vh;min-height:680px;position:relative;display:flex;align-items:flex-end;padding-bottom:80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);transition:transform 8s ease}
.hero-slide.active img{transform:scale(1)}
.hero-dots{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hero-dot{width:28px;height:2px;background:rgba(255,255,255,.3);cursor:pointer;transition:all .3s}
.hero-dot.active{width:44px;background:var(--accent)}
/* メインコンテンツ: 左寄せ */
.hero-content{position:relative;z-index:2;padding-left:80px;max-width:680px}
.hero-label{display:inline-block;background:var(--accent);color:#fff;font-size:11px;letter-spacing:.2em;padding:5px 14px;margin-bottom:24px;font-weight:500}
.hero-main-copy{font-family:"Bebas Neue",sans-serif;font-size:clamp(80px,11vw,140px);letter-spacing:.08em;line-height:.9;color:#fff;line-height:1.25;margin-bottom:26px;text-shadow:0 2px 24px rgba(0,0,0,.35);letter-spacing:.02em;white-space:nowrap}
@media(max-width:700px){.hero-main-copy{white-space:normal;font-size:clamp(32px,8vw,48px)}}
.hero-sub{font-family:"Noto Serif JP",serif;font-size:15px;color:rgba(255,255,255,.85);line-height:2.1;letter-spacing:.08em;font-weight:300;border-left:2px solid var(--accent);padding-left:18px}
/* SCROLL: 中央固定 縦アニメ */
.hero-scroll{position:absolute;bottom:28px;right:48px;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,.4);font-size:9px;letter-spacing:.22em;z-index:3}
.scroll-line{width:1px;height:48px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.scroll-line::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--accent);animation:scrollDown 2s infinite ease-in-out}
@keyframes scrollDown{from{top:-100%}to{top:100%}}

/* ── NEWS ── */
#news{background:var(--navy)}
.news-inner{display:flex;align-items:stretch;max-width:1200px;margin:0 auto}
.news-label{writing-mode:vertical-rl;padding:24px 22px;background:var(--accent);color:#fff;font-size:12px;letter-spacing:.25em;font-weight:500;text-transform:uppercase;display:flex;align-items:center;justify-content:center}
.news-list{flex:1}
.news-item{display:grid;grid-template-columns:130px 100px 1fr;align-items:center;padding:17px 36px;border-bottom:1px solid rgba(255,255,255,.06);text-decoration:none;transition:background .2s}
.news-item:hover{background:rgba(255,255,255,.04)}
.news-tag{font-size:11px;letter-spacing:.1em;padding:3px 0;border:1px solid;white-space:normal;display:inline-block;text-align:center;width:110px}
.news-tag.press{border-color:var(--accent);color:var(--accent)}
.news-tag.info{border-color:var(--gray-mid);color:var(--gray-mid)}
.news-date{font-size:12px;color:var(--gray-mid);letter-spacing:.05em}
.news-title{font-size:14px;color:rgba(255,255,255,.8);letter-spacing:.04em}
.news-more{display:flex;align-items:center;justify-content:flex-end;padding:13px 36px;text-decoration:none;color:var(--accent);font-size:12px;letter-spacing:.1em;gap:8px;transition:gap .2s}
.news-more:hover{gap:14px}

/* ── COMMON ── */
.sec-wrap{max-width:1200px;margin:0 auto;padding:0 80px}
.sec-head{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:40px}
.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:"→"}

/* ── WHAT WE DO ── */
#whatwedo{padding:96px 0 0;background:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(13,31,53,.1)}
.svc-card{position:relative;overflow:hidden;border-right:1px solid rgba(13,31,53,.1);display:flex;flex-direction:column;background:var(--white);transition:box-shadow .3s}
.svc-card:last-child{border-right:none}
.svc-card:hover{box-shadow:0 6px 28px rgba(15,39,66,.1);z-index:1}
.svc-photo{height:200px;position:relative;overflow:hidden;flex-shrink:0}
.svc-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.svc-card:hover .svc-photo img{transform:scale(1.04)}
.svc-ov{position:absolute;inset:0;background:rgba(15,39,66,.12);transition:background .3s}
.svc-card:hover .svc-ov{background:rgba(15,39,66,.04)}
.svc-num{font-family:"Noto Serif JP",serif;font-size:12px;letter-spacing:.2em;color:var(--accent);font-weight:500;margin-bottom:6px}
.svc-body{padding:24px 28px 32px;flex:1;display:flex;flex-direction:column}
.svc-title{font-family:"Noto Serif JP",serif;font-size:15px;color:var(--navy);font-weight:400;letter-spacing:.04em;margin-bottom:10px;line-height:1.5}
.svc-desc{font-size:15px;color:var(--text-mid);line-height:2;letter-spacing:.04em;font-weight:300;flex:1;margin-bottom:16px}
.arr{display:inline-flex;align-items:center;gap:8px;color:var(--accent);text-decoration:none;font-size:12px;letter-spacing:.1em;transition:gap .25s}
.arr::after{content:"→"}
.arr:hover{gap:14px}
.svc-bar{height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.svc-card:hover .svc-bar{transform:scaleX(1)}
.svc-card:hover .svc-bar{transform:scaleX(1)}

/* Clients 2-row */

/* ── ABOUT US ── */
#about{background:var(--navy);padding:96px 0;position:relative;overflow:hidden}
.about-bg-text{position:absolute;bottom:-20px;right:-10px;font-family:"Bebas Neue",sans-serif;font-size:220px;font-weight:700;color:rgba(255,255,255,.025);line-height:1;pointer-events:none;letter-spacing:.05em}
.about-inner{max-width:1200px;margin:0 auto;padding:0 80px;position:relative;z-index:1}
.about-inner .sec-en{color:#fff}
.about-inner .sec-ja{color:rgba(255,255,255,.85)}

/* 共通 2col ブロック */
.ab{display:grid;gap:0;margin-bottom:2px}
.ab.pl{grid-template-columns:2fr 1fr} /* text left, photo right */
.ab.pr{grid-template-columns:1fr 2fr} /* photo left, text right */
.ab-photo{position:relative;overflow:hidden;min-height:380px}
.ab-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ab-photo-ov{position:absolute;inset:0;background:rgba(15,39,66,.28)}
.ab-text{padding:56px 56px;display:flex;flex-direction:column;justify-content:center}
.ab-text.navy-mid{background:var(--navy-mid);border-top:3px solid var(--accent)}
.ab-text.navy-dark{background:rgba(15,39,66,.55);border-top:3px solid var(--accent)}
.ab-tag{font-size:11px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;margin-bottom:12px;font-weight:500;display:flex;align-items:center;gap:10px}
.ab-tag::before{content:"";display:block;width:24px;height:1px;background:var(--accent)}
.ab-title{font-family:"Noto Serif JP",serif;font-size:24px;color:#fff;margin-bottom:18px;line-height:1.7;letter-spacing:.04em;font-weight:400}
.ab-desc{font-size:15px;color:rgba(255,255,255,.65);line-height:2.1;letter-spacing:.04em;font-weight:300}

/* MISSION */
/* mission → ab pr に統一 */

/* VALUES */
.values-divider{display:flex;align-items:center;gap:16px;padding:28px 0 20px}
.vd-line{flex:1;height:1px;background:rgba(255,255,255,.08)}
.vd-label{font-size:9px;letter-spacing:.25em;color:rgba(255,255,255,.3);text-transform:uppercase;white-space:normal}
.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:26px 20px;border-bottom:2px solid transparent;transition:all .3s;cursor:default}
.val-card:hover{background:var(--navy-mid);border-bottom-color:var(--accent)}
.val-en{font-size:9px;letter-spacing:.16em;color:var(--accent);text-transform:uppercase;margin-bottom:7px;font-weight:500}
.val-title{font-size:14px;color:#fff;font-weight:400;margin-bottom:8px;letter-spacing:.04em;font-family:"Noto Serif JP",serif}
.val-action{font-size:12px;color:rgba(255,255,255,.55);line-height:1.8;letter-spacing:.03em}

/* ── SAFETY ── */
#safety{padding:96px 0;background:var(--white)}
.saf-photo-row{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:0;border:1px solid rgba(13,31,53,.08)}
.saf-photo-box{position:relative;overflow:hidden;min-height:300px}
.saf-photo-box img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
.saf-text-box{padding:48px 52px;display:flex;flex-direction:column;justify-content:center;background:var(--gray-light)}
.lead-text{font-family:"Noto Serif JP",serif;font-size:16px;color:var(--navy);line-height:2.1;letter-spacing:.06em;font-weight:400;border-left:3px solid var(--accent);padding-left:18px;margin-top:20px}
.safety-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(13,31,53,.08);border-top:none}
.saf-card{padding:28px 24px;background:var(--white);border-right:1px solid rgba(13,31,53,.08);border-top:2px solid var(--navy);transition:border-top-color .3s}
.saf-card:last-child{border-right:none}
.saf-card:hover{border-top-color:var(--accent)}
.saf-num{font-family:"Noto Serif JP",serif;font-size:28px;color:rgba(15,39,66,.06);font-weight:700;margin-bottom:6px}
.saf-title{font-size:14px;font-weight:500;color:var(--navy);margin-bottom:9px;letter-spacing:.04em}
.saf-desc{font-size:15px;color:var(--text-mid);line-height:1.9;letter-spacing:.03em;font-weight:300}

/* ── SUSTAINABILITY ── */
#sustainability{padding:96px 0;background:#eeeae3}
.sus-photo-row{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:0;border:1px solid rgba(13,31,53,.1)}
.sus-photo-box{position:relative;overflow:hidden;min-height:300px}
.sus-photo-box img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.sus-text-box{padding:48px 52px;display:flex;flex-direction:column;justify-content:center;background:#e5e1da}
.sus-lead{font-family:"Noto Serif JP",serif;font-size:16px;color:#2a2a2a;line-height:2.1;letter-spacing:.06em;font-weight:400;border-left:3px solid var(--navy);padding-left:18px;margin-top:20px}
.sus-grid{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid rgba(13,31,53,.1);border-top:none}
.sus-card{background:#eeeae3;padding:32px 36px;display:flex;gap:20px;align-items:flex-start;border-right:1px solid rgba(13,31,53,.1);border-top:1px solid rgba(13,31,53,.1);transition:background .2s}
.sus-card:nth-child(even){border-right:none}
.sus-card:hover{background:#e5e1da}
.sus-icon{width:34px;height:34px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.sus-icon svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:1.5}
.sus-title{font-size:14.5px;font-weight:500;color:var(--navy);margin-bottom:9px;letter-spacing:.04em}
.sus-ul{list-style:none}
.sus-ul li{font-size:15px;color:var(--text-mid);line-height:1.85;padding-left:13px;position:relative;font-weight:300}
.sus-ul li::before{content:"—";position:absolute;left:0;color:var(--accent);font-size:9px;top:4px}

/* ── RECRUIT ── */
#recruit{padding:96px 0;background:var(--navy);position:relative;overflow:hidden}
.rec-inner{max-width:1200px;margin:0 auto;padding:0 80px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.rec-inner .sec-en{color:#fff}
.rec-inner .sec-ja{color:rgba(255,255,255,.85)}
.rec-title{font-family:"Noto Serif JP",serif;font-size:clamp(22px,2.8vw,33px);color:#fff;line-height:1.65;letter-spacing:.04em;font-weight:400;margin-bottom:18px}
.rec-desc{font-size:15px;color:rgba(255,255,255,.56);line-height:2.1;letter-spacing:.04em;font-weight:300;margin-bottom:32px}
.btn-p{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;text-decoration:none;padding:13px 30px;font-size:14px;letter-spacing:.1em;font-weight:500;transition:background .2s}
.btn-p:hover{background:var(--accent-light)}
.btn-o{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.26);color:rgba(255,255,255,.72);text-decoration:none;padding:13px 28px;font-size:14px;letter-spacing:.1em;transition:border-color .2s,color .2s;margin-left:10px}
.btn-o:hover{border-color:var(--accent);color:var(--accent-light)}
.rec-visual{position:relative;height:380px;overflow:hidden}
.rec-visual img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
.rc-tl{position:absolute;top:12px;left:12px;width:20px;height:20px;border-top:1px solid rgba(232,93,27,.6);border-left:1px solid rgba(232,93,27,.6)}
.rc-br{position:absolute;bottom:12px;right:12px;width:20px;height:20px;border-bottom:1px solid rgba(232,93,27,.6);border-right:1px solid rgba(232,93,27,.6)}

/* CERT マーキー */
.cert-section{max-width:1200px;margin:52px auto 0;padding:0 80px}
.cert-a-inner{background:rgba(10,25,50,.6);border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:28px 0}
.cert-label-head{text-align:center;font-size:9px;letter-spacing:.24em;color:rgba(255,255,255,.28);margin-bottom:20px;text-transform:uppercase;display:flex;align-items:center;gap:16px;justify-content:center;padding:0 36px}
.cert-label-head::before,.cert-label-head::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.08);max-width:80px}
.cert-mq-outer{overflow:hidden;position:relative}
.cert-mq-outer::before,.cert-mq-outer::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.cert-mq-outer::before{left:0;background:linear-gradient(to right,rgba(10,25,50,.95) 40%,transparent)}
.cert-mq-outer::after{right:0;background:linear-gradient(to left,rgba(10,25,50,.95) 40%,transparent)}
.cert-mq-track{display:flex;align-items:stretch;gap:10px;width:max-content;padding:0 10px;animation:certmq 24s linear infinite}
.cert-mq-track:hover{animation-play-state:paused}
@keyframes certmq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.cert-mq-card{display:flex;flex-direction:column;align-items:center;gap:10px;background:rgba(255,255,255,.05);border:0.5px solid rgba(255,255,255,.09);border-radius:6px;padding:18px 14px;flex-shrink:0;width:130px;transition:background .25s,border-color .25s}
.cert-mq-card:hover{background:rgba(255,255,255,.1);border-color:rgba(232,93,27,.4)}
.cert-mq-img{width:70px;height:70px;background:#fff;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6px;box-shadow:0 1px 4px rgba(0,0,0,.18)}
.cert-mq-img img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.cert-mq-name{font-size:9px;color:rgba(255,255,255,.5);text-align:center;letter-spacing:.04em;line-height:1.65;font-weight:300;width:100%}
/* ── CONTACT ── */
#contact{padding:96px 0;text-align:center;position:relative;overflow:hidden}
.cnt-bg{position:absolute;inset:0;z-index:0}
.cnt-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.cnt-bg-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,24,44,.88) 0%,rgba(15,39,66,.75) 100%)}
.cnt-inner{position:relative;z-index:1}
.cnt-inner{max-width:580px;margin:0 auto;padding:0 40px}
.cnt-en{font-size:11px;letter-spacing:.25em;color:rgba(255,255,255,.38);margin-bottom:10px;display:block}
.cnt-title{font-family:"Noto Serif JP",serif;font-size:29px;color:#fff;margin-bottom:9px;letter-spacing:.06em;font-weight:400}
.cnt-sub{font-size:15px;color:rgba(255,255,255,.62);margin-bottom:40px;letter-spacing:.05em}
.cnt-phones{display:flex;justify-content:center;gap:18px;margin-bottom:32px}
.ph-box{padding:16px 26px;border:1px solid rgba(255,255,255,.13);text-align:center}
.ph-label{font-size:11px;color:rgba(255,255,255,.38);letter-spacing:.12em;margin-bottom:6px}
.ph-num{font-size:20px;color:#fff;letter-spacing:.08em;font-weight:300;text-decoration:none;display:block;transition:color .2s}
.ph-num:hover{color:var(--accent-light)}
.cnt-btn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;text-decoration:none;padding:16px 52px;font-size:14px;letter-spacing:.12em;font-weight:500;transition:background .2s,gap .3s;box-shadow:0 4px 24px rgba(232,93,27,.35)}
.cnt-btn:hover{background:var(--accent-light);gap:18px}

/* ── 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}

/* fade-up */
.fu:nth-child(2){transition-delay:.08s}.fu:nth-child(3){transition-delay:.16s}.fu:nth-child(4){transition-delay:.24s}

.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}}
@media(max-width:960px){header{padding:0 18px}nav{display:none}.hamburger{display:flex}}

.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:360px){.logo-name{display:none}}

/* Clients marquee */
.clients-section{padding:32px 0 36px;background:#fff;border-top:1px solid rgba(13,31,53,.08);overflow:hidden}
.clients-label{text-align:center;font-size:11px;letter-spacing:.2em;color:var(--text-mid);margin-bottom:18px}
.mq-outer{max-width:1200px;margin:0 auto;padding:0 80px;position:relative}
.mq-outer::before,.mq-outer::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.mq-outer::before{left:80px;background:linear-gradient(to right,#fff 60%,transparent)}
.mq-outer::after{right:80px;background:linear-gradient(to left,#fff 60%,transparent)}
.mq-wrap{overflow:hidden;position:relative}
.mq-row{overflow:hidden}
.mq-row-sq{}
.mq-track{display:flex;align-items:center;width:max-content}
.sq-track{animation:mq 15s linear infinite}
.wd-track{animation:mq 30s linear infinite reverse}
.mq-track:hover{animation-play-state:paused}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-logo.sq{display:flex;align-items:center;justify-content:center;height:72px;width:88px;padding:10px 14px;flex-shrink:0}
.mq-logo.sq img{max-height:50px;max-width:60px;width:auto;object-fit:contain;display:block}
.mq-logo.wd{display:flex;align-items:center;justify-content:center;height:56px;padding:8px 32px;flex-shrink:0}
.mq-logo.wd img{max-height:32px;max-width:160px;width:auto;object-fit:contain;display:block}

/* WHAT WE DO 新レイアウト */
.services-grid-new{display:flex;flex-direction:column;border:1px solid rgba(13,31,53,.1);overflow:hidden}
.svc-card-main{display:grid;grid-template-columns:55% 45%;position:relative;overflow:hidden;background:var(--white);transition:box-shadow .3s;border-bottom:1px solid rgba(13,31,53,.1);min-height:360px}
.svc-card-main:hover{box-shadow:0 6px 28px rgba(15,39,66,.1)}
.svc-photo-main{position:relative;overflow:hidden}
.svc-photo-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.svc-card-main:hover .svc-photo-main img{transform:scale(1.04)}
.svc-main-badge{position:absolute;top:20px;left:20px;background:var(--accent);color:#fff;font-size:9px;letter-spacing:.18em;padding:5px 14px;font-weight:500;z-index:1}
.svc-body-main{padding:48px 44px;display:flex;flex-direction:column;justify-content:center;background:var(--white)}
.svc-title-main{font-family:"Noto Serif JP",serif;font-size:20px;color:var(--navy);font-weight:400;letter-spacing:.06em;margin-bottom:16px;line-height:1.6}
.svc-sub-grid{display:grid;grid-template-columns:1fr 1fr;border-top:none}
.svc-sub-grid .svc-card{border-right:1px solid rgba(13,31,53,.1)}
.svc-sub-grid .svc-card:last-child{border-right:none}
.svc-sub-grid .svc-photo{height:200px}

/* ── NEWS DETAIL ── */
.nd-hero{position:relative;height:420px;overflow:hidden;background:#0F2742}
.nd-hero-img{position:absolute;inset:0}
.nd-hero-img img{width:100%;height:100%;object-fit:cover;opacity:.45}
.nd-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(8,22,38,.92) 0%,rgba(8,22,38,.6) 60%,rgba(8,22,38,.2) 100%)}
.nd-hero-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:0 80px 52px;max-width:1040px;margin:0 auto}
.nd-breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.45);margin-bottom:20px}
.nd-breadcrumb a{color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s}
.nd-breadcrumb a:hover{color:rgba(255,255,255,.8)}
.nd-breadcrumb span{color:rgba(255,255,255,.25)}
.nd-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.nd-tag{font-size:11px;letter-spacing:.12em;padding:4px 12px;font-weight:500}
.nd-tag.press{background:var(--accent);color:#fff}
.nd-tag.info{background:rgba(255,255,255,.15);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.25)}
.nd-date{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.06em}
.nd-cat{font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.06em;border-left:1px solid rgba(255,255,255,.2);padding-left:12px}
.nd-title{font-family:"Noto Serif JP",serif;font-size:clamp(20px,3.5vw,32px);color:#fff;font-weight:400;letter-spacing:.06em;line-height:1.5}

/* ── ARTICLE BODY ── */
.nd-wrap{max-width:760px;margin:0 auto;padding:72px 40px 96px}
.nd-body h2{font-family:"Noto Serif JP",serif;font-size:20px;color:var(--navy);font-weight:400;letter-spacing:.06em;margin:48px 0 18px;padding-bottom:12px;border-bottom:1px solid rgba(15,39,66,.12);line-height:1.5}
.nd-body p{font-size:15px;color:#333;line-height:2.2;letter-spacing:.04em;margin-bottom:20px;font-weight:300}
.nd-body ul{margin:0 0 24px 0;padding:0;list-style:none}
.nd-body ul li{font-size:15px;color:#333;line-height:2;letter-spacing:.04em;font-weight:300;padding:8px 0 8px 20px;position:relative;border-bottom:1px solid rgba(15,39,66,.05)}
.nd-body ul li::before{content:"";position:absolute;left:0;top:20px;width:8px;height:1px;background:var(--accent)}
.nd-body a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.nd-body strong{font-weight:600;color:var(--navy)}

/* ── LEAD ── */
.nd-lead{font-size:15.5px;color:var(--navy);line-height:2.1;letter-spacing:.05em;padding:28px 32px;border-left:3px solid var(--accent);background:rgba(15,39,66,.03);margin-bottom:40px;font-weight:300}

/* ── 本文写真（リード直後の1枚）── */
.nd-fig{margin:0 0 48px;overflow:hidden;border-radius:4px}
.nd-fig img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}
.nd-fig figcaption{font-size:13px;color:var(--text-mid,#667);letter-spacing:.04em;padding:10px 2px 0;line-height:1.7}
/* 認定・公式ロゴを本文に置く場合: トリミング禁止（ブランド規約）→ 白地に contain */
.nd-fig.is-logo{max-width:480px;border:1px solid rgba(15,39,66,.08)}
.nd-fig.is-logo img{aspect-ratio:3/2;object-fit:contain;background:#fff}

/* ── SHARE ── */
.nd-share{display:flex;align-items:center;gap:14px;padding:32px 0;border-top:1px solid rgba(15,39,66,.08);border-bottom:1px solid rgba(15,39,66,.08);margin:48px 0}
.nd-share-lbl{font-size:12px;letter-spacing:.2em;color:var(--text-mid);text-transform:uppercase}
.nd-share-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;font-size:12px;letter-spacing:.06em;text-decoration:none;border:1px solid rgba(15,39,66,.15);color:var(--text-mid);transition:all .2s}
.nd-share-btn:hover{border-color:var(--navy);color:var(--navy);background:rgba(15,39,66,.03)}
.nd-share-btn svg{width:13px;height:13px}

/* ── BACK / NAV ── */
.nd-nav{max-width:760px;margin:0 auto;padding:0 40px 80px;display:flex;justify-content:center}
.nd-back{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:var(--navy);color:#fff;font-size:12px;letter-spacing:.12em;text-decoration:none;transition:background .2s}
.nd-back:hover{background:var(--navy-mid)}
.nd-back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* ── RELATED ── */
.nd-related{background:#F2F4F6;padding:64px 80px}
.nd-related-inner{max-width:1040px;margin:0 auto}
.nd-related-ttl{font-family:"Noto Serif JP",serif;font-size:18px;color:var(--navy);font-weight:400;letter-spacing:.08em;margin-bottom:32px;display:flex;align-items:center;gap:16px}
.nd-related-ttl::after{content:"";flex:1;height:1px;background:rgba(15,39,66,.1)}
.nd-rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.nd-rel-card{background:#fff;text-decoration:none;display:block;border-top:2px solid transparent;transition:border-top-color .2s,box-shadow .2s}
.nd-rel-card:hover{border-top-color:var(--accent);box-shadow:0 4px 20px rgba(15,39,66,.1)}
.nd-rel-thumb{height:160px;overflow:hidden}
.nd-rel-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.nd-rel-card:hover .nd-rel-thumb img{transform:scale(1.04)}
/* 写真なし記事（thumb_placeholder）: 紺地に南進ロゴを小さく contain */
.nd-rel-thumb.is-ph{background:var(--navy);display:flex;align-items:center;justify-content:center}
.nd-rel-thumb.is-ph img{width:auto;height:auto;max-width:72px;max-height:72px;object-fit:contain;opacity:.5;transition:none}
.nd-rel-card:hover .nd-rel-thumb.is-ph img{transform:none}
.nd-rel-body{padding:16px 18px}
.nd-rel-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.nd-rel-tag{font-size:9px;letter-spacing:.1em;padding:3px 8px;font-weight:500}
.nd-rel-tag.press{background:var(--accent);color:#fff}
.nd-rel-tag.info{background:rgba(15,39,66,.08);color:var(--text-mid)}
.nd-rel-date{font-size:12px;color:var(--text-mid)}
.nd-rel-title{font-size:14px;color:var(--navy);line-height:1.7;letter-spacing:.04em;font-weight:500}

@media(max-width:768px){
  .nd-hero{height:300px}
  .nd-hero-content{padding:0 20px 36px}
  .nd-wrap{padding:48px 20px 64px}
  .nd-body h2{font-size:17px}
  .nd-body p,.nd-body ul li{font-size:15px}
  .nd-lead{padding:20px}
  .nd-related{padding:48px 20px}
  .nd-rel-grid{grid-template-columns:1fr}
  .nd-nav{padding:0 20px 56px}
}

