/* === Dynamics: oversized watermark === */
.sec-watermark{position:absolute;font-family:"Bebas Neue",sans-serif;font-weight:500;color:var(--navy);opacity:.05;pointer-events:none;user-select:none;white-space:nowrap;letter-spacing:-.02em;line-height:.85;z-index:0}
.sec-watermark.wm-light{color:#fff;opacity:.06}
section > .sec-wrap,section > .about-inner,section > .rec-inner{position:relative;z-index:1}
@media(max-width:720px){.sec-watermark{font-size:120px!important;opacity:.04}}
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,height .35s var(--ease-brand),padding .35s var(--ease-brand)}
header.scrolled{background:rgba(15,39,66,.97);border-bottom-color:rgba(255,255,255,.07);height:54px}
header.scrolled .header-logo .logo-symbol{height:34px}
.header-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-logo .logo-symbol{height:40px;width:auto;display:block;transition:height .35s var(--ease-brand)}
.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;transition:background .25s var(--ease-brand),transform .35s var(--ease-brand),box-shadow .35s var(--ease-brand)}
.nav-cta:hover{background:var(--accent-light)!important;transform:translateY(-1px) rotate(-.4deg);box-shadow:0 6px 18px rgba(232,93,27,.32)}

/* ── HERO ── */
#hero{height:100vh;min-height:560px;position:relative;display:flex;align-items:flex-end;padding-bottom:72px;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:20px;font-weight:500}
.hero-main-copy{font-family:"Bebas Neue",sans-serif;font-size:clamp(64px,9.5vw,144px);letter-spacing:.015em;line-height:.9;color:#fff;margin-bottom:24px;text-shadow:0 2px 28px rgba(0,0,0,.55),0 1px 2px rgba(0,0,0,.4);white-space:nowrap}
.hero-main-copy .ac{color:var(--accent)}
@media(max-width:700px){.hero-main-copy{white-space:normal;font-size:clamp(44px,12vw,72px);line-height:.95}}
.hero-sub{font-family:"Noto Serif JP",serif;font-size:clamp(13px,1.3vw,16px);color:rgba(255,255,255,.82);line-height:1.95;letter-spacing:.06em;font-weight:300;border-left:2px solid var(--accent);padding-left:18px;text-shadow:0 1px 18px rgba(0,0,0,.45)}
.hero-sub strong{color:#fff;font-weight:500}
/* SCROLL: 中央固定 縦アニメ */
.hero-scroll{position:absolute;bottom:28px;right:48px;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,.6);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:#fff}
.news-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:48px}
.news-head .sec-head{margin-bottom:0}
.news-see-all{text-decoration:none;color:var(--navy);font-size:13px;letter-spacing:.14em;padding-bottom:6px;border-bottom:1px solid var(--navy);display:inline-flex;align-items:center;gap:10px;transition:gap .2s;font-weight:500;font-family:"Bebas Neue",sans-serif;text-transform:uppercase}
.news-see-all:hover{gap:16px}
.news-see-all .arr{transition:transform .2s;display:inline-block}
.news-see-all:hover .arr{transform:translateX(4px)}
.news-list{display:flex;flex-direction:column}
.news-item{display:grid;grid-template-columns:104px 140px 1fr;gap:28px;align-items:center;padding:18px 0;border-top:1px solid rgba(15,39,66,.12);text-decoration:none;color:var(--navy);transition:padding-left .2s}
.news-item:last-child{border-bottom:1px solid rgba(15,39,66,.12)}
.news-item:hover{padding-left:8px}
.news-item:hover .news-title{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:5px;text-decoration-thickness:1px}
.news-date{font-family:"Bebas Neue",sans-serif;font-size:15px;color:var(--navy);letter-spacing:.05em;font-weight:500}
.news-cat{font-size:10px;color:var(--text-mid);letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.news-title{font-size:15px;color:var(--navy);font-weight:500;letter-spacing:.02em;line-height:1.55;margin:0}
@media(max-width:720px){
  .news-item{grid-template-columns:auto 1fr;grid-template-rows:auto auto;row-gap:4px;column-gap:20px}
  .news-cat{grid-column:2;grid-row:1}
  .news-date{grid-column:1;grid-row:1}
  .news-title{grid-column:1 / -1;grid-row:2}
}

/* ── COMMON ── */
.sec-wrap{max-width:1200px;margin:0 auto;padding:0 80px}
.sec-head{display:flex;flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:56px}
.sec-en{font-family:"Bebas Neue",sans-serif;font-size:clamp(42px,5.2vw,58px);letter-spacing:.02em;color:var(--navy);text-transform:uppercase;font-weight:700;line-height:.95}
.sec-line{width:44px;height:2px;background:var(--accent);display:block;margin:2px 0 4px}
.sec-ja{font-family:"Noto Sans JP",sans-serif;font-size:14px;color:var(--text-mid);letter-spacing:.12em;font-weight:400}
.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:"→"}

/* ── TYPOGRAPHY LAYERS (cross-section utilities) ── */
.eyebrow{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.32em;color:var(--accent);text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;font-weight:500}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent);display:block}
.lead-sentence{font-family:"Noto Serif JP",serif;font-size:clamp(18px,2vw,22px);line-height:1.9;color:var(--navy);font-weight:400;letter-spacing:.04em}
.quote-large{font-family:"Noto Serif JP",serif;font-size:clamp(24px,2.6vw,32px);line-height:1.7;color:var(--navy);font-weight:400;letter-spacing:.04em;font-style:normal;quotes:"「" "」";margin:0}
.quote-large::before{content:open-quote;color:var(--accent);margin-right:.1em}
.quote-large::after{content:close-quote;color:var(--accent);margin-left:.05em}

/* ── WHAT WE DO ── */
#whatwedo{padding:128px 0 96px;background:var(--white);position:relative;overflow:hidden}
.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-sub-grid .svc-card[style*="flex-direction:row"] > .svc-photo{flex:0 0 45%;height:280px}
.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:1.9;letter-spacing:.04em;font-weight:400;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(--gray-light);padding:120px 0 0;position:relative}
.about-inner{max-width:1200px;margin:0 auto;padding:0 80px;position:relative;z-index:1}

/* ── ABOUT (full-bleed crane background + fade-in MVV) ── */
#about.about--bg{background:var(--navy);padding:104px 0 96px;position:relative;overflow:hidden}
.about-bg{position:absolute;inset:0;z-index:0}
.about-bg picture{display:block;width:100%;height:100%}
.about-bg img{width:100%;height:100%;object-fit:cover;object-position:70% center;display:block}
/* クレーンは暗くしない。左の空にだけ薄く影を落として MVV パネルの土台にする */
.about-bg-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(9,22,40,.52) 0%,rgba(10,24,44,.30) 28%,rgba(15,39,66,.08) 52%,rgba(15,39,66,0) 72%)}
.about--bg .about-inner{position:relative;z-index:2}
.about--bg .sec-en{color:#fff}
.about--bg .sec-ja{color:rgba(255,255,255,.7)}
.about--bg .sec-line{background:var(--accent)}

/* 共通 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:1.9;letter-spacing:.04em;font-weight:400}

/* 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:11px;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);margin:0}
.values-grid dt,.values-grid dd{margin:0}
.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:11px;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}

/* ── MVV flow (背景の上に半透明パネルを縦に積み、スクロールで順次フェードイン) ── */
.mvv-flow{margin-top:40px;max-width:560px;display:flex;flex-direction:column;gap:16px}
.mvv-block{background:rgba(11,26,46,.74);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-left:3px solid var(--accent);padding:28px 32px;box-shadow:0 8px 30px rgba(0,0,0,.22)}
.mvv-block .ab-tag{margin-bottom:12px;color:var(--accent-light);font-family:"Bebas Neue",sans-serif;font-size:14px;letter-spacing:.26em;text-transform:uppercase;display:flex;align-items:center;gap:12px}
.mvv-block .ab-tag::before{content:"";width:22px;height:1px;background:var(--accent);display:block}
.mvv-block .ab-title{font-family:"Noto Serif JP",serif;font-size:clamp(20px,2.2vw,26px);margin-bottom:14px;line-height:1.55;color:#fff;font-weight:400;letter-spacing:.03em}
.mvv-block .ab-desc{font-size:15px;line-height:2.0;color:rgba(255,255,255,.8);letter-spacing:.03em}
.mvv-block.mvv-philo{background:rgba(150,52,12,.78);border-left-color:#fff}
.mvv-values .mvv-sub{font-size:13px;color:rgba(255,255,255,.6);letter-spacing:.12em;margin-bottom:16px;font-weight:300}
.mvv-values .values-grid{display:grid;grid-template-columns:1fr;gap:0;background:transparent;margin-top:0}
.mvv-values .values-grid dt,.mvv-values .values-grid dd{margin:0}
.mvv-values .val-card{display:flex;align-items:baseline;gap:24px;background:transparent;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12);transition:padding-left .2s}
.mvv-values .val-card:last-child{border-bottom:none}
.mvv-values .val-card:hover{padding-left:6px}
.mvv-values .val-title{font-size:16px;margin-bottom:0;width:160px;flex-shrink:0;color:#fff;font-weight:500;font-family:"Noto Serif JP",serif;letter-spacing:.04em;white-space:nowrap}
.mvv-values .val-action{font-size:12.5px;line-height:1.7;margin:0;flex:1;color:rgba(255,255,255,.68)}
.mvv-cta{margin-top:20px;display:flex;justify-content:flex-end}
.mvv-cta .arr{font-size:12px;color:#fff;letter-spacing:.08em;background:rgba(11,26,46,.72);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.28);padding:12px 26px;transition:background .25s,gap .25s}
.mvv-cta .arr:hover{background:var(--accent);border-color:var(--accent)}
/* 数字（白文字・カウントアップ維持） */
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin:36px 0 0;padding:36px 40px;background:rgba(11,26,46,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-left:3px solid var(--accent);box-shadow:0 8px 30px rgba(0,0,0,.22)}
.stat-item{text-align:left}
.stat-num{font-family:"Bebas Neue",sans-serif;font-size:clamp(52px,7vw,84px);color:#fff;line-height:1;letter-spacing:-.02em;font-weight:500;display:flex;align-items:baseline;gap:4px}
.stat-num .stat-suffix{font-size:.4em;color:var(--accent-light);margin-left:2px;font-weight:500}
.stat-label{font-size:12px;color:var(--accent-light);letter-spacing:.2em;margin-top:12px;font-weight:500;text-transform:uppercase;font-family:"Bebas Neue",sans-serif}
.stat-note{font-size:13px;color:rgba(255,255,255,.84);margin-top:8px;letter-spacing:.04em;font-weight:400;line-height:1.65}
@media(max-width:900px){
  #about.about--bg{padding:72px 0 64px}
  .about-bg-ov{background:rgba(10,24,44,.9)}
  .mvv-flow{max-width:none;gap:14px}
  .mvv-block{padding:26px 22px}
  .about-stats{grid-template-columns:repeat(2,1fr);gap:24px 20px;margin:28px 0 0;padding:28px 24px}
  .stat-num{font-size:56px}
  .mvv-values .val-card{flex-direction:column;gap:6px;padding:14px 0}
  .mvv-values .val-title{width:auto;font-size:16px;white-space:normal}
}

/* === Dynamics: Full-bleed band === */

/* === Dynamics: vertical side-label === */

/* === Dynamics: hero scroll indicator bob === */
@keyframes hero-scroll-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.hero-scroll{animation:hero-scroll-bob 2.2s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.hero-scroll{animation:none}}

/* ── SAFETY ── */
#safety{padding:128px 0 64px;background:var(--white);position:relative;overflow:hidden}
.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;list-style:none;padding:0;margin:0}
.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:0 0 9px;letter-spacing:.04em}
.saf-desc{font-size:15px;color:var(--text-mid);line-height:1.9;letter-spacing:.03em;font-weight:400}

/* ── SUSTAINABILITY: Full-bg photo hero section ── */
#sustainability{padding:128px 0 96px;position:relative;overflow:hidden;background:var(--navy);isolation:isolate}
.sus-bg{position:absolute;inset:0;z-index:-2;pointer-events:none}
.sus-bg img{width:100%;height:100%;object-fit:cover;object-position:center 45%;display:block}
.sus-bg-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,24,44,.66) 0%,rgba(10,24,44,.50) 45%,rgba(10,24,44,.62) 100%);pointer-events:none}
#sustainability .sec-en{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.45),0 1px 3px rgba(0,0,0,.4)}
#sustainability .sec-ja{color:rgba(255,255,255,.9);text-shadow:0 1px 10px rgba(0,0,0,.45)}
#sustainability .sec-line{background:rgba(255,255,255,.32)}
.sus-philo{color:#fff;padding:8px 0 56px 28px;margin:0;position:relative;border-left:3px solid var(--accent)}
.sus-philo-en{font-family:"Bebas Neue",sans-serif;font-size:clamp(40px,5.5vw,72px);letter-spacing:.02em;line-height:.95;font-weight:500;color:#fff;margin:0;text-shadow:0 2px 20px rgba(0,0,0,.45),0 1px 3px rgba(0,0,0,.4)}
.sus-philo-ja{font-family:"Noto Serif JP",serif;font-size:16px;line-height:2.0;color:rgba(255,255,255,.95);margin:20px 0 0;font-weight:400;letter-spacing:.04em;text-shadow:0 2px 16px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.4)}
.sus-pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;list-style:none;padding:0;margin:0}
.sus-pillar{background:rgba(255,255,255,.85);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.5);padding:48px 40px;transition:transform .4s cubic-bezier(.25,.8,.25,1),box-shadow .4s cubic-bezier(.25,.8,.25,1),background .4s ease;box-shadow:0 8px 28px rgba(0,0,0,.20);position:relative;overflow:hidden}
.sus-pillar:hover{background:rgba(255,255,255,.93)}
.sus-pillar::before{content:"";position:absolute;top:0;left:0;width:48px;height:3px;background:var(--accent);transition:width .5s cubic-bezier(.25,.8,.25,1)}
.sus-pillar:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.22)}
.sus-pillar:hover::before{width:100%}
.sus-pnum{font-family:"Noto Serif JP",serif;font-size:32px;color:rgba(15,39,66,.18);font-weight:700;line-height:1;display:block;margin-bottom:10px}
.sus-plabel{font-family:"Bebas Neue",sans-serif;font-size:11.5px;letter-spacing:.28em;color:var(--accent);display:block;margin-bottom:16px;text-transform:uppercase;font-weight:500}
.sus-pttl{font-size:18px;font-weight:700;color:var(--navy);margin:0 0 14px;letter-spacing:.05em;line-height:1.55}
.sus-pdesc{font-size:15px;line-height:1.95;color:rgba(15,39,66,.86);letter-spacing:.03em;margin:0}
.sus-evidence{margin:18px 0 0;padding-top:14px;border-top:1px solid rgba(15,39,66,.08);font-size:12.5px;line-height:1.75;color:var(--navy);letter-spacing:.03em;font-weight:500}
.sus-evlabel{display:inline-block;font-family:"Bebas Neue",sans-serif;font-size:10px;letter-spacing:.22em;color:var(--accent);background:rgba(232,93,27,.08);padding:3px 8px;margin-right:10px;border-radius:1px;font-weight:500;vertical-align:1px}
#sustainability .arr{color:rgba(255,255,255,.9)!important}
#sustainability .arr::after{border-color:rgba(255,255,255,.9)}
@media(max-width:720px){
  .sus-pillars{grid-template-columns:1fr;gap:12px}
  .sus-philo{padding:8px 0 40px 20px}
  .sus-philo-en{font-size:40px}
  .sus-pillar{padding:32px 26px}
  .sus-pnum{font-size:28px}
  .sus-pttl{font-size:17px}
  .sus-bg img{object-position:center 55%}
}

/* ── RECRUIT ── */
#recruit{padding:160px 0 128px;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,.55)}
.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:1.9;letter-spacing:.04em;font-weight:400;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 マーキー（light theme: 独立セクション） */
.cert-section{max-width:1200px;margin:52px auto 0;padding:0 80px}
.cert-a-inner{background:#fff;border:1px solid rgba(13,31,53,.06);border-radius:8px;padding:36px 0;box-shadow:0 2px 14px rgba(13,31,53,.05)}
.cert-label-head{text-align:center;font-size:11px;letter-spacing:.24em;color:rgba(13,31,53,.5);margin-bottom:24px;text-transform:uppercase;display:flex;align-items:center;gap:16px;justify-content:center;padding:0 36px;font-weight:500}
.cert-label-head::before,.cert-label-head::after{content:"";flex:1;height:1px;background:rgba(13,31,53,.14);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,#fff 40%,transparent)}
.cert-mq-outer::after{right:0;background:linear-gradient(to left,#fff 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(13,31,53,.03);border:0.5px solid rgba(13,31,53,.08);border-radius:6px;padding:18px 14px;flex-shrink:0;width:130px;transition:background .25s,border-color .25s}
.cert-mq-card:hover{background:rgba(13,31,53,.06);border-color:rgba(232,93,27,.42)}
.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,.08);border:0.5px solid rgba(13,31,53,.05)}
.cert-mq-img img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.cert-mq-name{font-size:11px;color:rgba(13,31,53,.72);text-align:center;letter-spacing:.04em;line-height:1.65;font-weight:400;width:100%}
/* ── CONTACT ── */
#contact{padding:72px 0 96px;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,.6);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 .25s var(--ease-brand),gap .35s var(--ease-brand),transform .4s var(--ease-brand),box-shadow .4s var(--ease-brand);box-shadow:0 4px 24px rgba(232,93,27,.35)}
.cnt-btn:hover{background:var(--accent-light);gap:18px;transform:translateY(-2px) rotate(-.4deg);box-shadow:0 10px 32px rgba(232,93,27,.42)}

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

.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 — 統一サービスブロック言語 (大小は L/M/S で可変) ════ */
.services-grid-new{display:flex;flex-direction:column;gap:16px}

/* 共通: 左 3px アクセント帯(常時) ＋ 同一の浮上ホバー */
.svc-card-main,
.svc-sub-grid .svc-card-tw,
.svc-school-banner{position:relative;overflow:hidden;transition:transform .3s var(--ease-brand),box-shadow .3s var(--ease-brand),background .3s var(--ease-brand)}
.svc-card-main::before,
.svc-sub-grid .svc-card-tw::before,
.svc-school-banner::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);z-index:3}
.svc-card-main:hover,
.svc-sub-grid .svc-card-tw:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(15,39,66,.12)}

/* index WHAT WE DO ラベル = 2 行構成（井本さん要望）:
   1行目「SERVICE 0N」= 小キッカー＋24px罫線（メタ情報・accent）
   2行目「CRANE LEASING」等 = Bebas Neue ソリッド大（別行・迫力）
   旧 .svc-num-main のアウトライン(-webkit-text-stroke)は Firefox 等で
   不可視バグがあり廃止 → ソリッド塗りで迫力を再現（全ブラウザ可視）。
   英語は詳細ページ準拠（Crane Leasing 等、視覚は CSS で大文字化）。
   詳細ページ .svc-sec-lbl は意図的に小さいまま=不可侵。 */
#whatwedo .eyebrow{display:block;margin-bottom:18px}
#whatwedo .eyebrow::before{display:none}
#whatwedo .eb-txt{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
#whatwedo .eb-no{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.3em;color:var(--accent);line-height:1}
#whatwedo .eb-no::before{content:"";width:24px;height:1px;background:var(--accent);flex-shrink:0}
#whatwedo .eb-name{font-family:"Bebas Neue",sans-serif;color:var(--navy);font-weight:500;text-transform:uppercase;line-height:.88;letter-spacing:.015em;font-size:clamp(30px,3.4vw,44px)}
/* サブカード(02/03)は中サイズ、教習バナー(04)はコンパクト＆白文字 */
#whatwedo .svc-tw-body .eb-name{font-size:clamp(26px,2.6vw,34px)}
/* 教習バナー(04): navy 背景上＝白文字・コンパクト。#whatwedo .eb-name(ID)に
   勝つよう #whatwedo プレフィックスで specificity を確保 */
#whatwedo .svc-school-banner .eyebrow{margin-bottom:0}
#whatwedo .svc-school-banner .eb-txt{gap:6px}
#whatwedo .svc-school-banner .eb-name{font-size:22px;color:#fff}
#whatwedo .svc-school-banner .eb-no{color:rgba(255,255,255,.6)}
#whatwedo .svc-school-banner .eb-no::before{background:rgba(255,255,255,.4)}
@media(max-width:720px){
  #whatwedo .eb-name{font-size:clamp(26px,8vw,36px)}
  #whatwedo .svc-tw-body .eb-name{font-size:clamp(24px,7vw,30px)}
}

/* 共通: タイトル (同一フォント/字面、寸法のみ階層) */
.svc-title-main,.svc-tw-title,.svc-school-title{font-family:"Noto Serif JP",serif;font-weight:400;letter-spacing:.06em;color:var(--navy)}
.svc-title-main{font-size:clamp(24px,2.4vw,30px);margin-bottom:20px;line-height:1.5}
.svc-tw-title{font-size:19px;margin:0 0 14px;line-height:1.5}
.svc-school-title{font-size:16px;color:#fff;line-height:1.3}

/* 共通: CTA (全ブロック同一・04 はダーク面用に色のみ差し替え) */
.svc-tw-arr,.svc-school-cta{display:inline-flex;align-items:center;gap:8px;color:var(--accent);text-decoration:none;font-size:12px;letter-spacing:.1em;transition:gap .25s,color .25s}
.svc-tw-arr::after,.svc-school-cta::after{content:"→"}
.svc-sub-grid .svc-card-tw:hover .svc-tw-arr{gap:14px}
.svc-school-cta{color:rgba(255,255,255,.75);flex-shrink:0}
.svc-school-banner:hover .svc-school-cta{color:#fff;gap:14px}

/* 01 メイン (L): 写真 + 本文 */
.svc-card-main{display:grid;grid-template-columns:64% 36%;background:var(--white);box-shadow:0 1px 3px rgba(15,39,66,.06);min-height:560px;width:100%}
.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 .6s ease}
.svc-card-main:hover .svc-photo-main img{transform:scale(1.03)}
.svc-main-badge{position:absolute;top:32px;left:32px;background:var(--accent);color:#fff;font-size:11px;letter-spacing:.26em;padding:8px 20px;font-weight:500;z-index:4;text-transform:uppercase;font-family:"Bebas Neue",sans-serif}
.svc-body-main{padding:56px 56px 56px 52px;display:flex;flex-direction:column;justify-content:center;background:var(--white);position:relative;max-width:560px}
.svc-body-main .svc-desc{font-size:15px;color:var(--text-mid);line-height:2.0;letter-spacing:.04em;margin-bottom:26px}

/* 01 と揃える共通シェル (全幅で responsive、80px→20px) */
.svc-sub-shell{max-width:1200px;margin:32px auto 0;padding:0 80px}

/* 02/03 サブ (M): 写真なし・タイポ重視 */
.svc-sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.svc-sub-grid .svc-card-tw{display:block;padding:44px 44px 44px 40px;background:#fff;box-shadow:0 1px 3px rgba(15,39,66,.06);text-decoration:none;color:var(--navy)}
.svc-tw-body{display:flex;flex-direction:column}
.svc-tw-desc{font-size:14px;line-height:1.95;color:var(--text-mid);letter-spacing:.04em;margin-bottom:18px}

/* 04 教習センター (S): 別事業 → 紺地は維持、言語のみ共通化 */
.svc-school-banner{display:flex;align-items:center;gap:22px;padding:24px 32px 24px 36px;background:var(--navy);text-decoration:none}
.svc-school-banner:hover{background:var(--navy-mid);transform:translateY(-4px);box-shadow:0 14px 36px rgba(15,39,66,.18)}
.svc-school-txt{display:flex;flex-direction:column;gap:4px;flex:1}

/* ── レスポンシブ追加 ── */
@media(max-width:720px){
  .svc-card-main{min-height:auto}
  .svc-body-main{padding:36px 24px 36px 28px}
  .svc-title-main{font-size:20px}
  .svc-sub-grid .svc-card-tw{padding:32px 24px 32px 28px}
  .svc-tw-title{font-size:16px}
  .svc-school-banner{flex-wrap:wrap;gap:14px 22px;padding:24px 24px 24px 28px}
  .svc-school-cta{width:100%}
}

@media(max-width:960px){
  /* Header */
  header{padding:0 18px}
  nav{display:none}
  .hamburger{display:flex}

  /* Layout */
  .sec-wrap,.about-inner{padding:0 20px}
  .services-grid,.values-grid,.safety-grid{grid-template-columns:1fr}
  .saf-photo-row,.ab,.mission-row{grid-template-columns:1fr}
  .clients-grid{grid-template-columns:repeat(3,1fr)}
  .cnt-phones{flex-direction:column;align-items:center}
  .cert-section,.rec-inner{padding:0 20px}
  .cert-section{padding:0 20px}
  .cert-a-inner{padding:20px 0}
  .rec-inner{grid-template-columns:1fr;gap:40px}

  /* Hero */
  .hero-content{padding-left:24px;padding-right:24px}

  /* WHAT WE DO */
  .svc-card-main{grid-template-columns:1fr!important;min-height:auto!important}
  .svc-photo-main{min-height:240px;position:relative!important}
  .svc-photo-main img{position:relative!important;inset:auto!important;width:100%!important;height:240px!important;object-fit:cover!important}
  .svc-sub-shell{padding:0 20px}
  .svc-sub-grid{grid-template-columns:1fr!important;gap:16px}
  .svc-body-main{padding:28px 20px!important}

  /* ABOUT */
  .ab-text{padding:36px 28px}

  /* MVV */
  .mvv-grid{grid-template-columns:1fr}
  .mvv-photo-col{min-height:420px;margin-left:0}
  .mvv-block{padding:28px 20px}
  .mvv-values .val-card{flex-direction:column;gap:6px;padding:16px 16px}
  .mvv-values .val-title{width:auto;font-size:16px}

  /* News */
  .page-hero-content,main{padding-left:20px;padding-right:20px}
  .news-card{flex-direction:column}
  .nc-thumb,.nc-thumb-placeholder{width:100%!important;min-width:0!important;height:200px}
  .nc-thumb img{width:100%!important;height:200px;object-fit:cover}
  .nc-body{padding:16px 18px}
  .nc-arr{text-align:right}

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