/* recruit.css
   Extracted from recruit.html embedded <style> (Phase B-2-a, 2026-05-15).
*/

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-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-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)}}

/* SCROLL: 中央固定 縦アニメ */

@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;align-items:baseline;gap:14px;margin-bottom:40px}

.sec-ja{font-size:14px;color:var(--text-mid);letter-spacing:.08em;font-weight:400}
.sec-line{width:28px;height:1px;background:var(--accent);display:inline-block;vertical-align:middle}

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

/* 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 
.about-inner .sec-ja{color:rgba(255,255,255,.35)}

/* 共通 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: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)}
.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}

/* ── 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 
.rec-inner .sec-ja{color:rgba(255,255,255,.35)}
.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:11px;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:11px;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{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,.28);line-height:2.0;letter-spacing:.04em;font-weight:300}
.ft-hours{font-size:12px;color:rgba(255,255,255,.22);line-height:1.9;letter-spacing:.04em;font-weight:300;margin-top:8px;border-top:1px solid rgba(255,255,255,.06);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,.13);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .2s}
.sns-btn:hover{border-color:var(--accent)}
.sns-btn svg{width:14px;height:14px;fill:rgba(255,255,255,.42)}
.sns-btn svg.si{fill:none;stroke:rgba(255,255,255,.42);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,.42);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,.26);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.ft-policies a:hover{color:rgba(255,255,255,.52)}
.ft-copy{font-size:11px;color:rgba(255,255,255,.18);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::before,

.mq-wrap{overflow:hidden;position:relative}
.mq-row{overflow:hidden}
.mq-row-sq{}

.sq-track{animation:mq 15s linear infinite}
.wd-track{animation:mq 30s linear infinite reverse}

@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:11px;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}

/* ── RECRUIT BASE ── */
body{font-family:"Noto Sans JP",sans-serif;background:#fff;color:#1a1a1a;overflow-x:hidden}
.r-inner{max-width:1040px;margin:0 auto}
.r-sec{padding:88px 80px}
.sec-label{font-size:11px;letter-spacing:.28em;color:var(--accent);text-transform:uppercase;font-weight:500;display:flex;align-items:center;gap:12px;margin-bottom:12px}
.sec-label::before{content:"";display:block;width:24px;height:1px;background:var(--accent)}
.sec-label.dk{color:var(--accent)}
.sec-en{font-family:"Bebas Neue",sans-serif;font-size:clamp(36px,5.5vw,64px);letter-spacing:.06em;line-height:1;margin-bottom:4px}
.sec-jp{font-family:"Noto Serif JP",serif;font-size:clamp(16px,2vw,22px);font-weight:400;letter-spacing:.08em;line-height:1.55}
.sec-body{font-size:15px;line-height:1.9;letter-spacing:.04em;font-weight:300;margin-top:12px}
.rv{transform:translateY(14px);transition:opacity .65s ease,transform .65s ease}
.rv.on{transform:translateY(0);opacity:1}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}

/* ── HERO ── */
#r-hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding-bottom:80px;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to right,rgba(8,22,38,.72) 0%,rgba(8,22,38,.42) 55%,rgba(8,22,38,.08) 100%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:80px 80px;pointer-events:none;z-index:1}
.hero-content{position:relative;z-index:2;padding:0 80px;width:100%;max-width:1200px}
.hero-ttl{font-family:"Bebas Neue",sans-serif;font-size:clamp(80px,12vw,145px);letter-spacing:.06em;line-height:.88;color:#fff;margin-bottom:22px}
.hero-ttl .ac{color:var(--accent)}
.hero-sub{font-family:"Noto Serif JP",serif;font-size:clamp(14px,1.5vw,17px);color:rgba(255,255,255,.78);line-height:2;letter-spacing:.06em;margin-bottom:32px;font-weight:300}
.hero-sub strong{font-weight:500;color:#fff}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-solid{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:14px 30px;font-size:13px;letter-spacing:.1em;font-weight:500;text-decoration:none;transition:background .2s}
.btn-solid:hover{background:#c94d0e}
.btn-outline{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.4);color:rgba(255,255,255,.85);padding:14px 30px;font-size:13px;letter-spacing:.1em;text-decoration:none;transition:all .2s}
.btn-outline:hover{border-color:#fff;color:#fff}
.hero-scroll{position:absolute;bottom:32px;right:48px;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:9px;letter-spacing:.18em;color:rgba(255,255,255,.35);z-index:2}
.scroll-line{width:1px;height:44px;background:rgba(255,255,255,.2);overflow:hidden;position:relative}
.scroll-line::after{content:"";position:absolute;top:-100%;width:100%;height:50%;background:rgba(255,255,255,.5);animation:scrollDown 1.8s ease infinite}
@keyframes scrollDown{to{top:200%}}

/* ── SECTION BG ── */
.r-sec-navy{background:#0F2742}
.r-sec-gray{background:#F2F4F6}
.r-sec-white{background:#fff}
.r-sec-light{background:#EBF0F8}
/* ── NUMS ── */
.nums-bar{background:#081b30;display:flex;justify-content:center}
.nums-inner{display:grid;grid-template-columns:repeat(4,1fr);max-width:860px;width:100%}
.ni{text-align:center;padding:22px 20px;border-right:1px solid rgba(255,255,255,.07)}
.ni:last-child{border-right:none}
.ni-n{font-family:"Bebas Neue",sans-serif;font-size:clamp(28px,3.5vw,40px);color:#fff;letter-spacing:.04em;line-height:1}
.ni-n span{font-size:clamp(14px,1.8vw,17px);color:var(--accent);margin-left:1px}
.ni-l{font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.04em;margin-top:5px;line-height:1.6}

/* ── MVV ── */
.mvv-list{display:flex;flex-direction:column;gap:0;margin-top:48px}
.mvv-item{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.07)}
.mvv-item-rev{direction:rtl}.mvv-item-rev>*{direction:ltr}
.mvv-item-img{position:relative;overflow:hidden;min-height:300px}
.mvv-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.mvv-item:hover .mvv-item-img img{transform:scale(1.04)}
.mvv-item-ov{position:absolute;inset:0;background:linear-gradient(to right,rgba(8,18,38,.45),transparent)}
.mvv-item-rev .mvv-item-ov{background:linear-gradient(to left,rgba(8,18,38,.45),transparent)}
.mvv-item-body{padding:48px 40px;display:flex;flex-direction:column;justify-content:center;background:rgba(15,39,66,.7)}
.mvv-lbl{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.28em;color:var(--accent);margin-bottom:12px;display:block}
.mvv-ttl{font-family:"Noto Serif JP",serif;font-size:clamp(17px,2vw,22px);color:#fff;font-weight:400;letter-spacing:.06em;line-height:1.65;margin-bottom:16px}
.mvv-desc{font-size:15px;color:rgba(255,255,255,.6);line-height:2.1;letter-spacing:.04em;font-weight:300}
.mvv-vals{display:flex;flex-direction:column;gap:5px;margin-top:4px}
.mvv-val{display:grid;grid-template-columns:24px 1fr 1fr;gap:8px;align-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.mvv-val-n{font-family:"Bebas Neue",sans-serif;font-size:15px;color:rgba(255,255,255,.2)}
.mvv-val-t{font-size:14px;color:rgba(255,255,255,.85);font-weight:500}
.mvv-val-d{font-size:12px;color:rgba(255,255,255,.45);font-weight:300}

/* ── MARQUEE WORKPLACE ── */
.mq-outer{overflow:hidden;position:relative;margin-top:36px;height:320px}
.mq-outer::before,.mq-outer::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.mq-outer::before{left:0;background:linear-gradient(to right,#F2F4F6,transparent)}
.mq-outer::after{right:0;background:linear-gradient(to left,#F2F4F6,transparent)}
.mq-track{display:flex;gap:4px;width:max-content;animation:mqScroll 36s linear infinite}
.mq-track:hover{animation-play-state:paused}
@keyframes mqScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-card{position:relative;width:290px;height:320px;overflow:hidden;flex-shrink:0}
.mq-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.mq-card:hover img{transform:scale(1.04)}
.mq-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,22,38,.6) 0%,transparent 50%)}
.mq-lbl{position:absolute;bottom:12px;left:14px;font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.75);text-transform:uppercase}
.wp-msg{background:#0F2742;padding:20px 80px;display:flex;align-items:center;gap:18px}
.wp-msg-txt{font-size:15px;color:rgba(255,255,255,.75);letter-spacing:.04em;line-height:1.7;font-weight:300}
.wp-msg-txt strong{font-weight:500;color:#fff;font-family:"Bebas Neue",sans-serif;font-size:15px;letter-spacing:.14em;margin-right:12px}

/* ── EDUCATION ── */
.edu-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:48px}
.edu-photo{position:relative}
.edu-photo img{width:100%;height:400px;object-fit:cover;display:block}
.edu-badge{position:absolute;bottom:0;left:0;background:#0F2742;color:#fff;padding:14px 20px;font-family:"Noto Serif JP",serif;font-size:13px;letter-spacing:.05em;line-height:1.8}
.edu-badge strong{color:var(--accent)}
.edu-steps{display:flex;flex-direction:column}
.edu-step{display:grid;grid-template-columns:36px 1fr;gap:14px;padding:20px 0;border-bottom:1px solid rgba(15,39,66,.07)}
.edu-step:last-child{border-bottom:none}
.edu-n{font-family:"Bebas Neue",sans-serif;font-size:26px;color:var(--accent);opacity:.5;line-height:1;padding-top:3px}
.edu-t{font-family:"Noto Serif JP",serif;font-size:15px;color:var(--navy);font-weight:400;letter-spacing:.04em;margin-bottom:4px}
.edu-d{font-size:14px;color:var(--text-mid);line-height:1.9;letter-spacing:.03em;font-weight:300}

/* ── CAREERS ── */
.career-layout{display:grid;grid-template-columns:190px 1fr;gap:0;margin-top:44px;border:1px solid rgba(15,39,66,.12)}
.career-nav{background:#F2F4F6;padding:18px 0;border-right:1px solid rgba(15,39,66,.08)}
.l1-tabs{display:flex;gap:0;padding:0 12px 8px;border-bottom:2px solid rgba(15,39,66,.08);margin-bottom:4px}
.l1-btn{padding:7px 14px;font-size:12px;letter-spacing:.04em;color:var(--text-mid);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:"Noto Sans JP",sans-serif;transition:all .2s}
.l1-btn:hover{color:var(--navy)}
.l1-btn.active{color:var(--navy);border-bottom-color:var(--accent);font-weight:500}
.l2-wrap{padding:6px 0}
.cn-btn{display:block;width:100%;text-align:left;padding:9px 16px;font-size:12px;letter-spacing:.04em;color:var(--text-mid);background:none;border:none;border-left:2px solid transparent;cursor:pointer;transition:all .2s;font-family:"Noto Sans JP",sans-serif}
.cn-btn:hover{color:var(--navy);background:rgba(15,39,66,.04)}
.cn-btn.active{color:var(--navy);border-left-color:var(--accent);background:rgba(15,39,66,.05);font-weight:500}
.career-content{background:#fff;overflow:hidden}
.career-panel{display:none;padding:28px 32px}
.career-panel.active{display:block}
.cp-head{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(15,39,66,.07)}
.cp-ttl{font-family:"Noto Serif JP",serif;font-size:19px;color:var(--navy);font-weight:400;letter-spacing:.06em;margin-bottom:8px}
.cp-desc{font-size:15px;color:var(--text-mid);line-height:2;letter-spacing:.04em}
.steps-section{background:#F2F4F6;padding:18px 20px;margin-bottom:20px}
.steps-lbl{font-size:11px;letter-spacing:.2em;color:var(--text-mid);text-transform:uppercase;margin-bottom:12px;opacity:.7}
.tl{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:2px solid rgba(15,39,66,.1);position:relative}
.tl::before{content:"";position:absolute;top:-2px;left:0;height:2px;background:linear-gradient(to right,var(--blue),var(--accent));animation:tlGrow .7s ease forwards}
@keyframes tlGrow{from{width:0}to{width:100%}}
.tl-step{padding:12px 12px 10px;border-right:1px solid rgba(15,39,66,.07)}
.tl-step:last-child{border-right:none}
.tl-yr{font-size:11px;letter-spacing:.06em;color:var(--text-mid);margin-bottom:3px}
.tl-role{font-size:12px;color:var(--navy);font-weight:500;margin-bottom:5px}
.tl-sal{font-family:"Bebas Neue",sans-serif;font-size:21px;color:var(--accent);letter-spacing:.04em}
.tl-man{font-size:11px;color:var(--text-mid);margin-left:1px;font-family:"Noto Sans JP",sans-serif;font-weight:300}
.tl-bar{height:3px;background:rgba(15,39,66,.08);margin-top:8px;border-radius:2px;overflow:hidden}
.tl-bar-fill{height:100%;width:0;background:linear-gradient(to right,var(--blue),var(--accent));border-radius:2px;transition:width 1s cubic-bezier(.25,.46,.45,.94)}
.tl-bar-fill.vis{width:var(--bw,50%)}
.iv-section{padding-top:4px}
.iv-lbl{font-size:11px;letter-spacing:.2em;color:var(--text-mid);text-transform:uppercase;margin-bottom:10px;opacity:.6}
.ivc{border:1px solid rgba(15,39,66,.07);margin-bottom:4px}
.ivc-hd{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;transition:background .2s}
.ivc-hd:hover{background:rgba(15,39,66,.03)}
.ivc-av{width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Bebas Neue",sans-serif;font-size:15px;flex-shrink:0}
.ivc-nm{font-size:13px;font-weight:500;color:var(--navy)}
.ivc-sb{font-size:12px;color:var(--text-mid)}
.ivc-chv{margin-left:auto;font-size:11px;color:var(--text-mid);transition:transform .2s}
.ivc.open .ivc-chv{transform:rotate(180deg)}
.ivc-bd{display:none;padding:4px 14px 14px}
.ivc.open .ivc-bd{display:block}
.ivc-qa{margin-bottom:9px}
.ivc-q{display:block;font-size:11px;font-weight:700;color:var(--blue);margin-bottom:3px;letter-spacing:.04em}
.ivc-a{display:block;font-size:13px;color:var(--text-mid);line-height:1.95}
.sch-bar{margin-top:12px;border-top:1px solid rgba(15,39,66,.06);padding-top:10px}
.sch-lbl{font-size:11px;letter-spacing:.2em;color:var(--text-mid);margin-bottom:7px;text-transform:uppercase;opacity:.55}
.sch-row{display:flex;overflow-x:auto;gap:0;padding-bottom:2px}
.sch-row::-webkit-scrollbar{height:2px}
.sch-ev{flex-shrink:0;border-right:1px solid rgba(15,39,66,.08);padding:5px 8px}
.sch-ev:last-child{border-right:none}
.sch-t{font-size:11px;font-weight:700;color:var(--accent);display:block;margin-bottom:2px}
.sch-w{font-size:11px;color:var(--text-mid)}

/* ── BENEFITS ── */
.ben-nums{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);margin:36px 0 40px;border:1px solid rgba(255,255,255,.07)}
.ben-num{background:rgba(8,22,38,.5);padding:20px 16px;text-align:center}
.ben-n{font-family:"Bebas Neue",sans-serif;font-size:clamp(26px,3.5vw,38px);color:#fff;letter-spacing:.04em;line-height:1}
.ben-n span{font-size:clamp(13px,1.6vw,17px);color:var(--accent);margin-left:1px}
.ben-l{font-size:12px;color:rgba(255,255,255,.42);letter-spacing:.04em;margin-top:5px;line-height:1.6}
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.06)}
.ben-card{background:rgba(8,22,38,.5);padding:24px 22px;border-top:2px solid rgba(255,255,255,.07);transition:border-top-color .25s,background .25s}
.ben-card:hover{border-top-color:var(--accent);background:rgba(8,22,38,.7)}
.ben-ic{width:34px;height:34px;border:1px solid rgba(232,93,27,.4);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.ben-ic svg{width:15px;height:15px;stroke:var(--accent);stroke-width:1.5;fill:none}
.ben-ttl{font-family:"Noto Serif JP",serif;font-size:14px;color:#fff;font-weight:400;letter-spacing:.06em;margin-bottom:10px}
.ben-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:5px}
.ben-list li{font-size:13px;color:rgba(255,255,255,.48);line-height:1.7;letter-spacing:.03em;font-weight:300;padding-left:12px;position:relative}
.ben-list li::before{content:"";position:absolute;left:0;top:9px;width:4px;height:1px;background:var(--accent)}
.ben-list strong{color:rgba(255,255,255,.82);font-weight:500}

/* ── CERTIFICATIONS ── */
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px}
.cert-card{background:#fff;border:1px solid rgba(15,39,66,.08);padding:20px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;transition:box-shadow .25s,transform .25s;border-top:2px solid rgba(15,39,66,.08)}
.cert-card:hover{box-shadow:0 4px 16px rgba(15,39,66,.12);transform:translateY(-2px);border-top-color:var(--accent)}
.cert-card-img{width:72px;height:72px;display:flex;align-items:center;justify-content:center}
.cert-card-img img{width:100%;height:100%;object-fit:contain}
.cert-card-lbl{font-size:11px;color:var(--text-mid);letter-spacing:.04em;line-height:1.55;text-align:center}

/* ── APPLY ── */
.apply-sec{position:relative;min-height:480px;display:flex;align-items:center}
.apply-bg{position:absolute;inset:0}
.apply-bg img{width:100%;height:100%;object-fit:cover}
.apply-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to right,rgba(8,22,38,.95) 0%,rgba(8,22,38,.88) 50%,rgba(8,22,38,.55) 100%)}
.apply-in{position:relative;z-index:1;padding:72px 80px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1200px;width:100%}
.apply-trust{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}
.apply-trust-item{font-size:13px;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.14);padding:4px 11px;letter-spacing:.06em}
.apply-cards{display:flex;flex-direction:column;gap:14px}
.apply-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:22px 22px;transition:border-color .25s,background .25s}
.apply-card:hover{border-color:rgba(232,93,27,.4);background:rgba(255,255,255,.08)}
.ac-type{font-size:11px;letter-spacing:.22em;color:var(--accent);text-transform:uppercase;margin-bottom:4px}
.ac-ttl{font-family:"Noto Serif JP",serif;font-size:16px;color:#fff;font-weight:400;margin-bottom:6px}
.ac-desc{font-size:13px;color:rgba(255,255,255,.5);line-height:1.9;margin-bottom:12px;font-weight:300}
.ac-btn{display:inline-flex;align-items:center;padding:9px 18px;background:var(--accent);color:#fff;font-size:12px;letter-spacing:.08em;text-decoration:none;transition:background .2s}
.ac-btn:hover{background:#c94d0e}

/* ── FLOAT CTA ── */
.r-float{position:fixed;right:20px;bottom:20px;z-index:150;display:flex;flex-direction:column;gap:8px;opacity:0;transform:translateY(10px);transition:opacity .4s,transform .4s;pointer-events:none}
.r-float.show{opacity:1;transform:translateY(0);pointer-events:auto}
.r-float-btn{display:flex;align-items:center;gap:8px;padding:11px 16px;font-size:12px;letter-spacing:.08em;text-decoration:none;font-family:"Noto Sans JP",sans-serif;white-space:nowrap;box-shadow:0 3px 16px rgba(0,0,0,.22)}
.r-float-btn.primary{background:var(--accent);color:#fff}
.r-float-btn.secondary{background:#0F2742;color:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.12)}
.r-float-btn svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none;flex-shrink:0}

/* ── MEDIA ── */
@media(max-width:1100px){
  .r-sec{padding:72px 40px}
  .hero-content{padding:0 40px}
  .mvv-item{grid-template-columns:1fr}
  .mvv-item-img{min-height:220px}
  .mvv-item-body{padding:32px 28px}
  .career-layout{grid-template-columns:160px 1fr}
  .apply-in{padding:56px 40px;gap:40px}
}
@media(max-width:768px){
  .r-sec{padding:56px 20px}
  .hero-content{padding:0 20px}
  .nums-inner{grid-template-columns:repeat(2,1fr)}
  .ni:nth-child(2n){border-right:none}
  .ni:nth-child(n+3){border-top:1px solid rgba(255,255,255,.05)}
  .edu-layout{grid-template-columns:1fr;gap:32px}
  .edu-photo img{height:260px}
  .career-layout{grid-template-columns:1fr;border:none}
  .career-nav{display:flex;flex-direction:column;background:none;padding:0;margin-bottom:16px}
  .l1-tabs{padding:0 0 8px;border-bottom:1px solid rgba(15,39,66,.1);margin-bottom:4px}
  .l1-btn{color:var(--text-mid);border-bottom-color:transparent}
  .l1-btn.active{color:var(--navy);border-bottom-color:var(--accent);font-weight:500}
  .l2-wrap{display:flex;flex-wrap:wrap;gap:4px}
  .cn-btn{border:1px solid rgba(15,39,66,.12);border-left:2px solid transparent;padding:7px 10px;font-size:12px;color:var(--text-mid)}
  .cn-btn.active{background:rgba(15,39,66,.07);border-left-color:var(--accent);color:var(--navy);font-weight:500}
  .career-content{background:#fff}
  .career-panel{padding:20px 0}
  .tl{grid-template-columns:1fr 1fr}
  .ben-nums{grid-template-columns:repeat(2,1fr)}
  .ben-grid{grid-template-columns:1fr}
  .cert-grid{grid-template-columns:repeat(2,1fr)}
  .apply-sec{min-height:auto}
  .apply-in{grid-template-columns:1fr;padding:48px 20px;gap:32px}
  .hero-btns{flex-direction:column}
  .r-float{right:12px;bottom:12px;gap:5px}
  .wp-msg{padding:18px 20px}
}
@media(max-width:680px){
  #r-float-entry{padding:12px 18px;font-size:12px}
  #r-float-casual{padding:9px 12px;font-size:12px}
}

@media(max-width:960px){  .hero-content{padding:0 20px}  .r-sec{padding:56px 20px}  .wp-msg{padding:18px 20px}}
@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,.sus-grid{grid-template-columns:1fr}
  .saf-photo-row,.sus-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-grid{grid-template-columns:1fr!important}
  .svc-sub-grid .svc-card{border-right:none;border-bottom:1px solid rgba(13,31,53,.1)}
  .svc-body-main{padding:28px 20px!important}

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

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

