/* =================================================================
   アルプスロジスティクス松本 — Design System
   信頼の青 × 躍動のオレンジ × 人の温かみ
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  --navy:#0F3D6E;
  --navy-deep:#0A2C50;
  --navy-darker:#071F3A;
  --orange:#F5A623;
  --orange-deep:#E08A06;
  --sky:#2E8BC0;
  --sky-soft:#5BA9D6;
  --bg:#FFFFFF;
  --bg-alt:#EEF3F8;
  --bg-alt2:#E3ECF5;
  --ink:#1A1A1A;
  --muted:#5E6A78;
  --muted-soft:#8A94A1;
  --line:#DCE4ED;
  --line-strong:#C4D1DF;
  --white:#FFFFFF;

  --accent:var(--orange);        /* tweakable */
  --accent-deep:var(--orange-deep);

  --maxw:1200px;
  --gutter:clamp(20px,5vw,64px);
  --radius:14px;
  --radius-sm:9px;
  --radius-lg:22px;
  --shadow-sm:0 2px 8px rgba(15,61,110,.06);
  --shadow:0 14px 40px -18px rgba(15,61,110,.28);
  --shadow-lg:0 30px 70px -30px rgba(7,31,58,.42);

  --ff-jp:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --ff-en:"Barlow",-apple-system,sans-serif;
  --ff-cond:"Barlow Semi Condensed","Barlow",sans-serif;

  --header-h:84px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-jp);
  color:var(--ink);
  background:var(--bg);
  line-height:1.85;
  font-weight:400;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--navy);color:#fff}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1340px;margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
.sec{padding-block:clamp(64px,9vw,128px)}
.sec-tight{padding-block:clamp(48px,6vw,84px)}
.bg-alt{background:var(--bg-alt)}
.bg-navy{background:var(--navy);color:#fff}
.bg-navy-deep{background:var(--navy-deep);color:#fff}

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--ff-en);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sky);
  display:inline-flex;
  align-items:center;
  gap:.6em;
}
.eyebrow::before{
  content:"";
  width:26px;height:3px;border-radius:2px;
  background:var(--accent);
}
.eyebrow.on-dark{color:var(--sky-soft)}
.sec-title{
  font-weight:900;
  font-size:clamp(1.75rem,3.6vw,2.85rem);
  line-height:1.3;
  letter-spacing:.01em;
  margin-top:.5em;
  text-wrap:balance;
}
.sec-title .accent{color:var(--accent)}
.sec-title .sky{color:var(--sky)}
.sec-lead{
  color:var(--muted);
  font-size:1.04rem;
  margin-top:1.1em;
  max-width:48ch;
  text-wrap:pretty;
}
.bg-navy .sec-lead,.bg-navy-deep .sec-lead{color:#C6D6E8}
.sec-head{margin-bottom:clamp(36px,5vw,60px)}
.sec-head.center{text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head.center .sec-lead{margin-inline:auto}

.num{font-family:var(--ff-cond);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:0}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--navy);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.65em;
  font-family:var(--ff-jp);font-weight:700;font-size:1rem;
  padding:1.05em 1.9em;border-radius:var(--radius-sm);
  background:var(--bg);color:var(--fg);
  border:2px solid transparent;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s,background .25s;
  box-shadow:0 10px 24px -12px rgba(15,61,110,.5);
  line-height:1.2;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 34px -14px rgba(15,61,110,.55)}
.btn svg{width:1.2em;height:1.2em;flex:none}
.btn-accent{--bg:var(--accent);--fg:#231400;box-shadow:0 10px 26px -10px rgba(245,166,35,.7)}
.btn-accent:hover{box-shadow:0 20px 38px -12px rgba(245,166,35,.7)}
.btn-ghost{--bg:transparent;--fg:var(--navy);border-color:var(--line-strong);box-shadow:none}
.btn-ghost:hover{border-color:var(--navy);box-shadow:none}
.btn-ghost.on-dark{--fg:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost.on-dark:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-lg{font-size:1.08rem;padding:1.2em 2.2em}
.btn-block{width:100%}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:700;color:var(--navy);font-size:.96rem;
  transition:gap .25s;
}
.link-arrow svg{width:1.1em;height:1.1em;transition:transform .25s}
.link-arrow:hover{gap:.85em}
.link-arrow.accent{color:var(--accent-deep)}

/* =================================================================
   HEADER
   ================================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:90;
  background:rgba(255,255,255,.0);
  transition:background .3s,box-shadow .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.site-header.solid{
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(1.4) blur(10px);
  box-shadow:0 6px 24px -16px rgba(7,31,58,.4);
  border-color:var(--line);
}
.header-top{display:none}
.header-inner{
  display:flex;align-items:center;gap:24px;
  height:var(--header-h);
  max-width:1340px;margin-inline:auto;padding-inline:var(--gutter);
}
/* logo */
.brand{display:flex;align-items:center;gap:13px;flex:none}
.brand-mark{width:46px;height:46px;flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-jp{font-weight:900;font-size:1.12rem;letter-spacing:.02em;color:var(--navy);white-space:nowrap}
.site-header:not(.solid) .brand-jp{color:#fff}
.brand-en{font-family:var(--ff-en);font-weight:600;font-size:.62rem;letter-spacing:.26em;color:var(--muted-soft);text-transform:uppercase}
.site-header:not(.solid) .brand-en{color:rgba(255,255,255,.7)}
.brand-loc{font-size:.68rem;font-weight:700;color:var(--accent-deep);letter-spacing:.04em}
.site-header:not(.solid) .brand-loc{color:var(--orange)}

.header-nav{margin-left:auto;display:flex;align-items:center;gap:2px}
.header-nav a{
  font-weight:700;font-size:.92rem;padding:.6em .85em;border-radius:8px;
  color:var(--navy);transition:color .2s,background .2s;white-space:nowrap;
}
.site-header:not(.solid) .header-nav a{color:rgba(255,255,255,.92)}
.header-nav a:hover{color:var(--sky)}
.site-header:not(.solid) .header-nav a:hover{color:#fff;background:rgba(255,255,255,.12)}

.header-cta{display:flex;align-items:center;gap:12px;flex:none}
.header-tel{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;margin-right:4px}
.header-tel .tlabel{font-size:.6rem;font-weight:700;letter-spacing:.1em;color:var(--muted-soft)}
.site-header:not(.solid) .header-tel .tlabel{color:rgba(255,255,255,.7)}
.header-tel .tnum{font-family:var(--ff-cond);font-weight:700;font-size:1.32rem;color:var(--navy);letter-spacing:.01em}
.site-header:not(.solid) .header-tel .tnum{color:#fff}
.header-cta .btn{padding:.78em 1.25em;font-size:.92rem}

.nav-toggle{display:none}

/* =================================================================
   HERO
   ================================================================= */
.hero{
  position:relative;min-height:min(94vh,860px);
  display:flex;align-items:flex-end;
  background:var(--navy-deep);
  color:#fff;overflow:hidden;
  padding-top:var(--header-h);
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media image-slot{width:100%;height:100%}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(7,31,58,.92) 0%,rgba(10,44,80,.78) 42%,rgba(10,44,80,.28) 100%),
    linear-gradient(0deg,rgba(7,31,58,.85),rgba(7,31,58,0) 45%);
}
.hero-ridge{
  position:absolute;left:0;right:0;bottom:-1px;z-index:1;
  width:100%;height:auto;display:block;color:var(--bg);
}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1340px;margin-inline:auto;padding:0 var(--gutter) clamp(72px,10vw,128px)}
.hero-loc{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-en);font-weight:700;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  background:rgba(245,166,35,.12);border:1px solid rgba(245,166,35,.4);
  padding:.5em 1.1em;border-radius:50px;margin-bottom:1.4em;
}
.hero h1{
  font-weight:900;
  font-size:clamp(2.1rem,5.4vw,4.4rem);
  line-height:1.22;letter-spacing:.01em;
  text-wrap:balance;
  text-shadow:0 2px 30px rgba(0,0,0,.3);
}
.hero h1 .accent{color:var(--orange)}
.hero h1 .line2{display:block}
.hero-sub{
  margin-top:1.3em;font-size:clamp(1rem,1.7vw,1.22rem);
  color:#D7E3F0;max-width:40ch;font-weight:500;line-height:1.8;
}
.hero-entries{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;
  margin-top:2.6em;max-width:740px;
}
.entry-card{
  position:relative;display:flex;flex-direction:column;gap:.3em;
  padding:1.5em 1.6em 1.4em;border-radius:var(--radius);
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(6px);
  transition:transform .3s,background .3s,border-color .3s;
  overflow:hidden;
}
.entry-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--sky);transition:width .3s;
}
.entry-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.13)}
.entry-card .ec-en{font-family:var(--ff-en);font-weight:700;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#9FC2DE}
.entry-card .ec-title{font-weight:900;font-size:1.32rem;line-height:1.3;display:flex;align-items:center;gap:.5em}
.entry-card .ec-desc{font-size:.86rem;color:#C6D6E8;line-height:1.7;margin-top:.3em}
.entry-card .ec-go{margin-top:1em;display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:.92rem}
.entry-card .ec-go svg{width:1.15em;height:1.15em;transition:transform .3s}
.entry-card:hover .ec-go svg{transform:translateX(4px)}
.entry-card.accent::before{background:var(--orange)}
.entry-card.accent:hover::before{width:8px}
.entry-card.accent .ec-en{color:var(--orange)}
.entry-card.accent .ec-go{color:var(--orange)}
.entry-card.primary:hover::before{width:8px}
.entry-card.primary .ec-go{color:#fff}
.entry-icon{width:30px;height:30px;flex:none}

/* hero stats strip */
.hero-strip{
  position:relative;z-index:2;background:var(--navy);
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-strip-inner{
  max-width:1340px;margin-inline:auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.hstat{padding:1.6em 1.2em;text-align:center;border-left:1px solid rgba(255,255,255,.1)}
.hstat:first-child{border-left:0}
.hstat .hs-num{font-family:var(--ff-cond);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);color:#fff;line-height:1}
.hstat .hs-num small{font-size:.5em;font-weight:600}
.hstat .hs-num .accent{color:var(--orange)}
.hstat .hs-label{font-size:.78rem;color:#9FB8D2;margin-top:.5em;font-weight:500}

/* =================================================================
   REASONS (選ばれる理由)
   ================================================================= */
.reasons-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.reason{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2em 1.7em;position:relative;overflow:hidden;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.reason:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.reason-no{
  font-family:var(--ff-cond);font-weight:700;font-size:3.6rem;line-height:.8;
  color:var(--bg-alt2);position:absolute;top:.15em;right:.25em;z-index:0;
}
.reason-ic{
  width:56px;height:56px;border-radius:13px;display:grid;place-items:center;
  background:var(--navy);color:#fff;margin-bottom:1.1em;position:relative;z-index:1;
}
.reason:nth-child(2) .reason-ic{background:var(--sky)}
.reason:nth-child(3) .reason-ic{background:var(--accent);color:#231400}
.reason:nth-child(4) .reason-ic{background:var(--navy-deep)}
.reason-ic svg{width:30px;height:30px}
.reason h3{font-size:1.18rem;font-weight:900;position:relative;z-index:1;line-height:1.4}
.reason p{font-size:.92rem;color:var(--muted);margin-top:.6em;position:relative;z-index:1;line-height:1.8}

/* =================================================================
   SERVICES (事業内容)
   ================================================================= */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{
  display:grid;grid-template-columns:1.05fr 1fr;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  transition:box-shadow .3s,transform .3s;
}
.svc:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.svc-media{position:relative;min-height:230px}
.svc-media image-slot{width:100%;height:100%}
.svc-tag{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:var(--ff-en);font-weight:700;font-size:.66rem;letter-spacing:.14em;
  background:var(--navy);color:#fff;padding:.5em .9em;border-radius:6px;
}
.svc-body{padding:1.8em 1.7em;display:flex;flex-direction:column}
.svc-body h3{font-size:1.3rem;font-weight:900;line-height:1.35}
.svc-body .svc-sub{font-family:var(--ff-en);font-weight:600;font-size:.72rem;letter-spacing:.1em;color:var(--sky);text-transform:uppercase;margin-bottom:.5em}
.svc-body p{font-size:.9rem;color:var(--muted);margin-top:.7em;line-height:1.8;flex:1}
.svc-feats{display:flex;flex-wrap:wrap;gap:7px;margin-top:1.1em}
.svc-feats li{font-size:.76rem;font-weight:700;color:var(--navy);background:var(--bg-alt);padding:.4em .8em;border-radius:50px}

/* =================================================================
   RESULTS / AREA (実績・対応エリア)
   ================================================================= */
.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.bigstats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.bigstat{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6em 1.5em;position:relative;
}
.bigstat .bs-num{font-family:var(--ff-cond);font-weight:700;font-size:clamp(2.6rem,6vw,4rem);line-height:.85;color:var(--navy)}
.bigstat .bs-num .unit{font-size:.34em;font-weight:700;color:var(--muted);margin-left:.25em;letter-spacing:.02em}
.bigstat .bs-num .accent{color:var(--accent-deep)}
.bigstat .bs-label{font-size:.92rem;font-weight:700;margin-top:.6em}
.bigstat .bs-note{font-size:.74rem;color:var(--muted-soft);margin-top:.2em}

.area-card{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:clamp(1.8em,3vw,2.6em);position:relative;overflow:hidden}
.area-card::after{content:"";position:absolute;right:-40px;bottom:-50px;width:230px;height:230px;border-radius:50%;background:radial-gradient(circle,rgba(46,139,192,.4),transparent 70%)}
.area-card h3{font-size:1.3rem;font-weight:900;position:relative;z-index:1}
.area-card .area-en{font-family:var(--ff-en);font-weight:600;letter-spacing:.16em;font-size:.72rem;color:var(--sky-soft);text-transform:uppercase}
.area-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:1.3em;position:relative;z-index:1}
.area-chips li{font-weight:700;font-size:.88rem;border:1px solid rgba(255,255,255,.28);padding:.5em 1em;border-radius:50px;color:#EAF2FA}
.area-chips li.core{background:var(--accent);border-color:var(--accent);color:#231400}
.area-map{
  margin-top:1.5em;position:relative;z-index:1;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:16/9;border:1px solid rgba(255,255,255,.18);
}
.area-map iframe{width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}

.clients{margin-top:clamp(40px,5vw,64px)}
.clients-label{text-align:center;font-size:.84rem;font-weight:700;color:var(--muted-soft);letter-spacing:.08em;margin-bottom:1.4em}
.clients-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.client-chip{
  font-weight:700;color:var(--navy);background:#fff;border:1px solid var(--line);
  padding:.7em 1.4em;border-radius:10px;font-size:.92rem;
}

/* =================================================================
   SAFETY (安全への取り組み)
   ================================================================= */
.safety{background:var(--navy-deep);color:#fff;overflow:hidden;position:relative}
.safety .blueprint{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:42px 42px}
.safety-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(32px,5vw,72px);align-items:center;position:relative;z-index:1}
.safety-photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg)}
.safety-photo image-slot{width:100%;height:100%}
.safety-badge{
  position:absolute;left:-14px;bottom:24px;z-index:3;
  background:var(--accent);color:#231400;border-radius:14px;padding:1em 1.3em;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.6);display:flex;align-items:center;gap:.8em;
}
.safety-badge .sb-num{font-family:var(--ff-cond);font-weight:700;font-size:2.7rem;line-height:.8}
.safety-badge .sb-txt{font-size:.78rem;font-weight:800;line-height:1.3}
.safety-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:2em}
.safety-item{display:flex;gap:.9em;align-items:flex-start;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.1em 1.1em}
.safety-item .si-ic{width:42px;height:42px;border-radius:10px;flex:none;background:rgba(46,139,192,.25);color:var(--sky-soft);display:grid;place-items:center}
.safety-item .si-ic svg{width:24px;height:24px}
.safety-item h4{font-size:1rem;font-weight:800}
.safety-item p{font-size:.8rem;color:#B8CADD;margin-top:.2em;line-height:1.65}
.safety-quote{margin-top:2em;font-size:1.15rem;font-weight:700;line-height:1.7;border-left:4px solid var(--accent);padding-left:1.1em}

/* =================================================================
   RECRUIT DIVIDER + BANNER
   ================================================================= */
.recruit-banner{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(120deg,var(--navy-deep),var(--navy) 60%);
  padding-block:clamp(72px,10vw,140px);
}
.recruit-banner .rb-media{position:absolute;inset:0;z-index:0;opacity:1}
.recruit-banner .rb-media image-slot{width:100%;height:100%}
.recruit-banner .rb-media::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(7,31,58,.9),rgba(10,44,80,.55) 70%,rgba(245,166,35,.18))}
.recruit-banner .rb-glow{position:absolute;right:-5%;top:-30%;width:55vw;height:120%;background:radial-gradient(ellipse at center,rgba(245,166,35,.32),transparent 60%);z-index:1}
.rb-inner{position:relative;z-index:2}
.rb-tag{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-en);font-weight:800;letter-spacing:.18em;font-size:.82rem;text-transform:uppercase;
  color:#231400;background:var(--accent);padding:.55em 1.2em;border-radius:50px;margin-bottom:1.3em;
}
.rb-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:#231400}
.recruit-banner h2{font-weight:900;font-size:clamp(2rem,5vw,4rem);line-height:1.22;text-wrap:balance;max-width:18ch}
.recruit-banner h2 .accent{color:var(--orange)}
.rb-sub{margin-top:1.2em;font-size:clamp(1rem,1.6vw,1.2rem);color:#E4ECF4;max-width:46ch;line-height:1.8;font-weight:500}
.rb-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.2em}

/* =================================================================
   PAY NUMBERS (数字で見る待遇)
   ================================================================= */
.recruit-zone{background:#FFF7EC}
.pay-hero{
  background:linear-gradient(135deg,var(--accent),#FFB94A);
  border-radius:var(--radius-lg);padding:clamp(2.2em,4vw,3.4em);color:#231400;
  position:relative;overflow:hidden;box-shadow:0 30px 70px -34px rgba(245,166,35,.8);
}
.pay-hero::after{content:"";position:absolute;right:-30px;top:-30px;width:240px;height:240px;border-radius:50%;border:30px solid rgba(255,255,255,.18)}
.pay-hero .ph-label{font-weight:800;font-size:1.05rem;position:relative;z-index:1}
.pay-hero .ph-num{font-family:var(--ff-cond);font-weight:700;font-size:clamp(4.5rem,13vw,9rem);line-height:.82;letter-spacing:-.01em;position:relative;z-index:1;margin:.1em 0}
.pay-hero .ph-num .unit{font-size:.26em;font-weight:800}
.pay-hero .ph-note{font-weight:700;font-size:.95rem;position:relative;z-index:1;opacity:.85}
.pay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.pay-card{
  background:#fff;border:1px solid #F0DFC2;border-radius:var(--radius);
  padding:1.7em 1.6em;position:relative;transition:transform .3s,box-shadow .3s;
}
.pay-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px -22px rgba(224,138,6,.5)}
.pay-card .pc-ic{width:44px;height:44px;border-radius:11px;background:#FFF1DB;color:var(--accent-deep);display:grid;place-items:center;margin-bottom:1em}
.pay-card .pc-ic svg{width:25px;height:25px}
.pay-card .pc-num{font-family:var(--ff-cond);font-weight:700;font-size:clamp(2.2rem,4vw,3rem);line-height:.9;color:var(--navy)}
.pay-card .pc-num .unit{font-size:.36em;font-weight:700;color:var(--muted);margin-left:.2em}
.pay-card .pc-num .accent{color:var(--accent-deep)}
.pay-card .pc-label{font-weight:800;font-size:1rem;margin-top:.5em}
.pay-card .pc-desc{font-size:.82rem;color:var(--muted);margin-top:.35em;line-height:1.7}
.pay-card.span2{grid-column:span 2}
.pay-disclaimer{font-size:.78rem;color:var(--muted);margin-top:1.4em;text-align:center}

/* =================================================================
   APPEAL (働く魅力)
   ================================================================= */
.appeal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.appeal{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8em 1.6em;transition:transform .3s,box-shadow .3s}
.appeal:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.appeal .ap-no{font-family:var(--ff-cond);font-weight:700;font-size:1rem;color:var(--accent-deep);letter-spacing:.05em}
.appeal h3{font-size:1.18rem;font-weight:900;margin-top:.3em;line-height:1.4}
.appeal h3 .accent{color:var(--accent-deep)}
.appeal p{font-size:.9rem;color:var(--muted);margin-top:.6em;line-height:1.8}

/* =================================================================
   VOICES (先輩ドライバーの声)
   ================================================================= */
.voices-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.voice{
  display:grid;grid-template-columns:auto 1fr;gap:22px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.9em;align-items:start;
  transition:box-shadow .3s,transform .3s;
}
.voice:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.voice-photo{width:120px;flex:none}
.voice-photo image-slot{width:120px;height:150px}
.voice-photo .vp-meta{margin-top:.7em}
.voice-name{font-weight:900;font-size:1.05rem;line-height:1.3}
.voice-role{font-size:.74rem;color:var(--muted);font-weight:600}
.voice-years{display:inline-block;font-family:var(--ff-cond);font-weight:700;font-size:.72rem;color:#fff;background:var(--sky);padding:.2em .7em;border-radius:5px;margin-top:.4em;letter-spacing:.04em}
.voice-q{font-size:1.12rem;font-weight:800;color:var(--navy);line-height:1.5;margin-bottom:.6em;text-wrap:pretty}
.voice-body{font-size:.88rem;color:var(--muted);line-height:1.85}
.voice-highlight{margin-top:1em;display:inline-flex;align-items:center;gap:.5em;background:#FFF1DB;color:var(--accent-deep);font-weight:800;font-size:.82rem;padding:.5em .9em;border-radius:8px}

/* =================================================================
   ENVIRONMENT (労働環境)
   ================================================================= */
.env-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.env{background:var(--bg-alt);border-radius:var(--radius);padding:1.6em 1.4em;text-align:left}
.env .env-ic{width:48px;height:48px;border-radius:12px;background:#fff;color:var(--navy);display:grid;place-items:center;box-shadow:var(--shadow-sm);margin-bottom:.9em}
.env .env-ic svg{width:27px;height:27px}
.env h4{font-size:1.02rem;font-weight:800}
.env p{font-size:.82rem;color:var(--muted);margin-top:.35em;line-height:1.7}

/* =================================================================
   REQUIREMENTS + FORM (募集要項+エントリー)
   ================================================================= */
.req-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,52px);align-items:start}
.req-table{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.req-table dl{display:grid;grid-template-columns:128px 1fr}
.req-table dt{background:var(--navy);color:#fff;font-weight:700;font-size:.86rem;padding:1.05em 1.2em;border-bottom:1px solid rgba(255,255,255,.12);display:flex;align-items:center}
.req-table dd{padding:1.05em 1.3em;border-bottom:1px solid var(--line);font-size:.9rem;line-height:1.7}
.req-table dd .hl{font-family:var(--ff-cond);font-weight:700;font-size:1.5em;color:var(--accent-deep);vertical-align:-.04em}
.req-table dl:last-child dt,.req-table dl:last-child dd{border-bottom:0}

.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.8em,3vw,2.4em);box-shadow:var(--shadow)}
.form-card .fc-title{font-size:1.3rem;font-weight:900}
.form-card .fc-sub{font-size:.88rem;color:var(--muted);margin-top:.3em;margin-bottom:1.4em}
.casual-cta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.5em;padding:1.1em;background:#FFF7EC;border:1px dashed var(--accent);border-radius:12px;align-items:center}
.casual-cta .cc-txt{font-weight:800;font-size:.92rem;flex:1;min-width:140px}
.casual-cta .cc-txt small{display:block;font-weight:500;color:var(--muted);font-size:.78rem}
.field{margin-bottom:1.05em}
.field label{display:block;font-weight:700;font-size:.86rem;margin-bottom:.45em}
.field label .req{color:#D1453B;font-size:.78em;margin-left:.4em;font-weight:700}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);
  padding:.85em 1em;border:1.5px solid var(--line-strong);border-radius:10px;background:#fff;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 4px rgba(46,139,192,.14)}
.field textarea{resize:vertical;min-height:96px}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field.row2>div{margin:0}
.form-note{font-size:.74rem;color:var(--muted-soft);margin-top:.8em;line-height:1.6}
.form-success{display:none;text-align:center;padding:2em 1em}
.form-success.show{display:block}
.form-success .fs-ic{width:64px;height:64px;border-radius:50%;background:#E6F5EC;color:#1E9E5A;display:grid;place-items:center;margin:0 auto 1em}
.form-success h3{font-size:1.3rem;font-weight:900}
.form-success p{color:var(--muted);margin-top:.5em}

.input-err{border-color:#D1453B !important}
.err-msg{display:none;color:#D1453B;font-size:.76rem;font-weight:600;margin-top:.35em}
.err-msg.show{display:block}

/* =================================================================
   COMPANY (会社概要)
   ================================================================= */
.company-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,56px);align-items:start}
.company-table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{text-align:left;padding:1.05em .4em;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:top}
.company-table th{width:140px;font-weight:800;color:var(--navy)}
.company-table td{color:var(--muted)}
.company-map{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line);box-shadow:var(--shadow)}
.company-map iframe{width:100%;height:100%;border:0}
.nap-note{font-size:.74rem;color:var(--muted-soft);margin-top:1em}

/* =================================================================
   CONTACT (お問い合わせ)
   ================================================================= */
.contact{background:var(--navy-deep);color:#fff}
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:clamp(32px,4vw,48px)}
.contact-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:clamp(1.8em,3vw,2.5em)}
.contact-card.accent{background:linear-gradient(150deg,rgba(245,166,35,.16),rgba(245,166,35,.04));border-color:rgba(245,166,35,.4)}
.contact-card .cc-ic{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;margin-bottom:1em;background:var(--sky);color:#fff}
.contact-card.accent .cc-ic{background:var(--accent);color:#231400}
.contact-card .cc-ic svg{width:30px;height:30px}
.contact-card h3{font-size:1.4rem;font-weight:900}
.contact-card p{font-size:.9rem;color:#C6D6E8;margin-top:.5em;line-height:1.75}
.contact-channels{display:flex;flex-direction:column;gap:11px;margin-top:1.5em}
.channel{display:flex;align-items:center;gap:.9em;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:11px;padding:.9em 1.1em;transition:background .25s,transform .25s}
.channel:hover{background:rgba(255,255,255,.12);transform:translateX(4px)}
.channel .ch-ic{width:40px;height:40px;border-radius:9px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex:none}
.channel .ch-ic svg{width:22px;height:22px;color:#fff}
.channel .ch-label{font-size:.72rem;color:#9FB8D2;font-weight:600}
.channel .ch-val{font-family:var(--ff-cond);font-weight:700;font-size:1.3rem;letter-spacing:.01em}
.channel.line .ch-ic{background:#06C755}

/* =================================================================
   FOOTER
   ================================================================= */
.site-footer{background:var(--navy-darker);color:#fff;padding-block:clamp(48px,6vw,72px) 0}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,4vw,48px)}
.footer-brand .brand-jp{color:#fff;font-size:1.3rem}
.footer-brand .brand-en{color:rgba(255,255,255,.6)}
.footer-brand p{font-size:.84rem;color:#9FB8D2;margin-top:1em;line-height:1.8;max-width:34ch}
.footer-col h4{font-size:.78rem;font-weight:800;letter-spacing:.1em;color:var(--sky-soft);text-transform:uppercase;font-family:var(--ff-en);margin-bottom:1.1em}
.footer-col ul{display:flex;flex-direction:column;gap:.7em}
.footer-col a{font-size:.88rem;color:#C6D6E8;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-meta{font-size:.84rem;color:#9FB8D2;line-height:1.9}
.footer-meta .fm-num{font-family:var(--ff-cond);font-weight:700;font-size:1.4rem;color:#fff}
.footer-bottom{margin-top:clamp(36px,5vw,56px);border-top:1px solid rgba(255,255,255,.1);padding-block:1.6em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-bottom small{font-size:.76rem;color:#7E92A8}
.footer-license{font-size:.76rem;color:#7E92A8}

/* =================================================================
   STICKY MOBILE CTA
   ================================================================= */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  display:none;grid-template-columns:1fr 1fr 1.3fr;
  background:#fff;box-shadow:0 -8px 24px -12px rgba(7,31,58,.4);
  border-top:1px solid var(--line);
}
.sticky-cta a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2em;
  padding:.8em .4em;font-weight:800;font-size:.78rem;text-align:center;
}
.sticky-cta a svg{width:22px;height:22px}
.sticky-cta .sc-tel{color:var(--navy)}
.sticky-cta .sc-contact{color:var(--sky);border-left:1px solid var(--line);border-right:1px solid var(--line)}
.sticky-cta .sc-recruit{background:var(--accent);color:#231400}

/* =================================================================
   SECTION TAB (荷主/採用 label rail)
   ================================================================= */
.zone-tab{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-en);font-weight:700;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.5em 1.1em;border-radius:50px;margin-bottom:.4em;
}
.zone-tab.client{background:var(--bg-alt2);color:var(--navy)}
.zone-tab.recruit{background:var(--accent);color:#231400}

/* =================================================================
   FAQ (recruit page)
   ================================================================= */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:760px;margin-inline:auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.faq-item summary{
  list-style:none;cursor:pointer;font-weight:800;font-size:1.02rem;
  padding:1.15em 3em 1.15em 1.3em;position:relative;line-height:1.5;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";position:absolute;right:1.3em;top:1.5em;width:13px;height:13px;
  border-right:2.5px solid var(--sky);border-bottom:2.5px solid var(--sky);
  transform:rotate(45deg);transition:transform .3s;
}
.faq-item[open] summary::after{transform:rotate(-135deg);top:1.7em}
.faq-item p{padding:0 1.4em 1.3em;color:var(--muted);font-size:.92rem;line-height:1.85}

/* =================================================================
   REVEAL ANIMATION
   ================================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:1080px){
  .reasons-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:1fr}
  .pay-grid{grid-template-columns:repeat(2,1fr)}
  .appeal-grid{grid-template-columns:repeat(2,1fr)}
  .env-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:920px){
  .header-nav{display:none}
  .header-tel{display:none}
  .nav-toggle{display:inline-grid}
  .results-grid,.safety-grid,.req-grid,.company-grid,.contact-split{grid-template-columns:1fr}
  .voices-grid{grid-template-columns:1fr}
  .hero-strip-inner{grid-template-columns:repeat(2,1fr)}
  .hstat:nth-child(3){border-left:0}
  .hstat:nth-child(n+3){border-top:1px solid rgba(255,255,255,.1)}
  .sticky-cta{display:grid}
  body{padding-bottom:64px}
  .safety-list{grid-template-columns:1fr}
}
@media(max-width:560px){
  :root{--header-h:68px}
  .hero-entries{grid-template-columns:1fr}
  .reasons-grid,.pay-grid,.appeal-grid,.env-grid,.bigstats,.footer-top{grid-template-columns:1fr}
  .voice{grid-template-columns:1fr}
  .voice-photo{width:100%}
  .voice-photo image-slot{width:100%;height:200px}
  .field.row2{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr}
  .req-table dl{grid-template-columns:96px 1fr}
  .footer-bottom{flex-direction:column}
}

/* =================================================================
   MOBILE DRAWER
   ================================================================= */
.nav-toggle{
  width:46px;height:46px;border-radius:11px;border:1px solid var(--line);
  background:#fff;cursor:pointer;place-items:center;margin-left:auto;
}
.site-header:not(.solid) .nav-toggle{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3)}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);position:relative}
.site-header:not(.solid) .nav-toggle span{background:#fff}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:inherit;transition:transform .3s}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}
.drawer{
  position:fixed;inset:0;z-index:100;background:var(--navy-deep);color:#fff;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.1,1);
  display:flex;flex-direction:column;padding:28px var(--gutter);overflow-y:auto;
}
.drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.drawer-close{width:46px;height:46px;border-radius:11px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;font-size:1.6rem;cursor:pointer}
.drawer nav{display:flex;flex-direction:column;gap:2px}
.drawer nav a{font-size:1.3rem;font-weight:800;padding:.7em 0;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer nav a .en{font-family:var(--ff-en);font-weight:600;font-size:.7rem;letter-spacing:.16em;color:var(--sky-soft);display:block;text-transform:uppercase}
.drawer-cta{margin-top:auto;padding-top:24px;display:grid;gap:12px}

/* tweakable hero-entry layout */
.he-stack .hero-entries{grid-template-columns:1fr;max-width:460px}
