/* =========================================================
   モノづくり製作所 -RECRUIT-  — 制作サンプル
   型: 製造業 採用特設サイト（力強い／ストーリー叙述／スクロール）
   配色: 濃紺 #16243a × 白 × 鮮青 #2f7de0 × オレンジ #f0883a
   フォント: Zen Kaku Gothic New(極太見出し) + Space Mono(数値アクセント)
   ========================================================= */

:root{
  --navy:#16243a;
  --navy-2:#1d3050;
  --navy-3:#26426d;
  --blue:#2f7de0;
  --blue-lt:#5b9cf0;
  --orange:#f0883a;
  --orange-lt:#f7a463;
  --ink:#16243a;
  --muted:#6b7a90;
  --line:#dde3ec;
  --bg:#ffffff;
  --bg-2:#f3f6fb;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;
  color:var(--ink);background:var(--bg);
  line-height:1.85;font-weight:500;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.mono{font-family:"Space Mono",monospace;font-weight:700;letter-spacing:.02em}
h1,h2,h3,h4{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;line-height:1.25;letter-spacing:.01em}
.wrap{width:min(1120px,90vw);margin-inline:auto}

/* reveal */
.rv{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* nav (top offset clears the sample frame bar) */
.nav{position:fixed;top:42px;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;transition:.4s;color:#fff}
@media(max-width:600px){.nav{top:34px;padding:12px 5vw}}
.nav.solid{background:rgba(22,36,58,.93);backdrop-filter:blur(10px);padding-top:14px;padding-bottom:14px;box-shadow:0 2px 24px rgba(0,0,0,.25)}
.nav .logo{display:flex;align-items:center;gap:.55em;font-size:1.15rem;font-weight:900;letter-spacing:.04em}
.nav .logo .mark{width:14px;height:14px;background:var(--orange);transform:rotate(45deg);display:inline-block;border-radius:2px}
.nav .logo em{font-family:"Space Mono",monospace;font-style:normal;font-size:.62rem;letter-spacing:.28em;opacity:.7;align-self:flex-end;padding-bottom:.25em}
.nav-links{display:flex;gap:2em;font-size:.86rem;letter-spacing:.06em;font-weight:700}
.nav-links a{opacity:.85;transition:.2s}.nav-links a:hover{opacity:1;color:var(--orange-lt)}
.entry-btn{background:var(--orange);color:#fff;padding:.7em 1.5em;border-radius:999px;font-size:.85rem;font-weight:900;letter-spacing:.06em;transition:.25s;box-shadow:0 6px 18px rgba(240,136,58,.35)}
.entry-btn:hover{background:var(--orange-lt);transform:translateY(-2px)}
@media(max-width:860px){.nav-links{display:none}}

/* hero */
.hero{min-height:100vh;background-size:cover;background-position:center;display:flex;align-items:center;
  position:relative;color:#fff;padding:120px 6vw 90px}
.hero-inner{max-width:840px}
.hero .ey{font-size:.82rem;letter-spacing:.22em;font-weight:700;color:var(--orange-lt);margin-bottom:1.4em}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);line-height:1.12;letter-spacing:.02em;text-shadow:0 4px 40px rgba(0,0,0,.4)}
.hero h1 .accent{color:var(--orange);position:relative}
.hero h1 .accent::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.12em;background:var(--blue);opacity:.9}
.hero .sub{margin-top:1.6em;font-size:clamp(.98rem,1.7vw,1.18rem);font-weight:500;line-height:2;max-width:34em;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.hero-cta{margin-top:2.6em;display:flex;gap:1em;flex-wrap:wrap}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);font-size:.66rem;letter-spacing:.3em;opacity:.7}
.scroll-cue::after{content:"";display:block;width:1px;height:34px;background:#fff;margin:10px auto 0;animation:cue 2s infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* buttons */
.btn-pri,.btn-sec{display:inline-block;padding:.95em 2.1em;border-radius:999px;font-weight:900;font-size:.95rem;letter-spacing:.04em;transition:.25s}
.btn-pri{background:var(--orange);color:#fff;box-shadow:0 10px 26px rgba(240,136,58,.4)}
.btn-pri:hover{background:var(--orange-lt);transform:translateY(-3px)}
.btn-sec{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn-sec:hover{background:#fff;color:var(--navy)}
.btn-pri.lg,.btn-sec.lg{padding:1.1em 2.6em;font-size:1.02rem}

/* section eyebrow */
.sec-ey{font-size:.8rem;letter-spacing:.18em;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:.7em;margin-bottom:1.1em}
.sec-ey .mono{color:var(--orange);font-size:.95rem}
.sec-ey.light{color:var(--blue-lt)}
.sec-ey.light .mono{color:var(--orange-lt)}

/* about */
.about{padding:130px 0 110px;background:var(--bg)}
.about h2{font-size:clamp(1.8rem,4vw,3rem)}
.about .lead{margin-top:1.4em;font-size:1.08rem;line-height:2.1;max-width:40em;color:#34435c}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:64px}
.vcard{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:38px 32px 34px;position:relative;overflow:hidden;transition:.3s}
.vcard::before{content:"";position:absolute;left:0;top:0;width:6px;height:100%;background:linear-gradient(var(--blue),var(--orange))}
.vcard:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(22,36,58,.1);border-color:transparent}
.vnum{display:inline-block;font-size:1.1rem;color:#fff;background:var(--navy);width:2.4em;height:2.4em;line-height:2.4em;text-align:center;border-radius:10px;margin-bottom:1.2em}
.vcard h3{font-size:1.32rem;line-height:1.4}
.vcard p{margin-top:1em;font-size:.96rem;color:#4a5870;line-height:1.95;font-weight:500}
@media(max-width:860px){.value-grid{grid-template-columns:1fr}}

/* work */
.work{padding:0 0 30px;background:var(--bg)}
.work-row{display:grid;grid-template-columns:1.05fr 1fr;align-items:center}
.work-row.reverse{grid-template-columns:1fr 1.05fr}
.work-ph{min-height:560px;background-size:cover;background-position:center}
.work-tx{padding:90px clamp(40px,6vw,96px)}
.work-row.reverse .work-ph{order:2}
.work-row.reverse .work-tx{order:1}
.work-tx h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
.work-tx p{margin-top:1.2em;font-size:1.02rem;color:#42526c;line-height:2.05;max-width:30em}
.tag-list{display:flex;flex-wrap:wrap;gap:.6em;margin-top:1.8em;list-style:none}
.tag-list li{font-family:"Space Mono",monospace;font-size:.78rem;font-weight:700;letter-spacing:.03em;
  border:1.5px solid var(--blue);color:var(--blue);padding:.4em 1em;border-radius:999px}
@media(max-width:860px){
  .work-row,.work-row.reverse{grid-template-columns:1fr}
  .work-row.reverse .work-ph{order:0}
  .work-ph{min-height:340px}
  .work-tx{padding:54px 8vw}
}

/* figure / numbers (no big-number grid; table form) */
.figure{padding:110px 0;background:var(--bg-2)}
.figure h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
.fig-table{width:min(720px,100%);margin-top:40px;border-collapse:collapse}
.fig-table th,.fig-table td{padding:18px 20px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.fig-table th{width:36%;font-weight:900;color:var(--navy);font-size:1rem}
.fig-table td{font-size:1.06rem;color:#34435c}
.fig-table .mono{color:var(--orange);font-size:1.25rem}
.figure .note{margin-top:1.6em;font-size:.78rem;color:var(--muted)}

/* voices */
.voice{padding:120px 0;background-size:cover;background-position:center;color:#fff}
.voice h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:54px}
.v-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.v-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:40px 32px 32px;
  backdrop-filter:blur(4px);position:relative}
.v-quote{position:absolute;top:8px;left:24px;font-size:4.4rem;color:var(--orange);opacity:.85;line-height:1}
.v-body{position:relative;font-size:1rem;line-height:2;font-weight:500;padding-top:18px}
.v-meta{margin-top:1.8em;padding-top:1.2em;border-top:1px solid rgba(255,255,255,.18)}
.v-role{display:block;font-weight:900;font-size:1.08rem;color:var(--orange-lt)}
.v-info{display:block;margin-top:.3em;font-size:.78rem;color:#b9c6dc}
@media(max-width:860px){.v-grid{grid-template-columns:1fr}}

/* requirements */
.require{padding:120px 0;background:var(--bg)}
.require h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:8px}
.req-table{width:100%;margin-top:36px;border-collapse:collapse;border-top:3px solid var(--navy)}
.req-table th,.req-table td{padding:20px 22px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top;font-size:1rem;line-height:1.9}
.req-table th{width:22%;background:var(--bg-2);font-weight:900;color:var(--navy);white-space:nowrap}
.req-table td{color:#34435c}
.req-table .mono{color:var(--orange)}
@media(max-width:600px){
  .req-table,.req-table tbody,.req-table tr,.req-table th,.req-table td{display:block;width:100%}
  .req-table th{border-bottom:none;padding-bottom:6px}
  .req-table td{padding-top:6px}
}

/* benefits */
.benefit{padding:120px 0;background:var(--bg-2)}
.benefit h2{font-size:clamp(1.8rem,4vw,2.8rem)}
.b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.b-item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 30px;transition:.3s}
.b-item:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(22,36,58,.09);border-color:var(--blue-lt)}
.b-no{display:block;font-size:1.4rem;color:var(--blue);margin-bottom:.5em}
.b-item h4{font-size:1.16rem;color:var(--navy)}
.b-item p{margin-top:.7em;font-size:.92rem;color:#4a5870;line-height:1.9;font-weight:500}
@media(max-width:860px){.b-grid{grid-template-columns:1fr}}

/* product visual band */
.product{min-height:62vh;background-size:cover;background-position:center;display:flex;align-items:flex-end;
  position:relative}
.product::before{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(22,36,58,.85),rgba(22,36,58,.05) 55%)}
.product-cap{position:relative;padding:0 6vw 70px;color:#fff;max-width:760px}
.product-cap .small{font-size:.74rem;letter-spacing:.22em;color:var(--orange-lt);margin-bottom:.8em}
.product-cap h3{font-size:clamp(1.8rem,4.5vw,3.2rem);line-height:1.2}

/* entry band */
.entry{padding:130px 0;background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff;text-align:center;position:relative;overflow:hidden}
.entry::before{content:"";position:absolute;width:520px;height:520px;background:var(--blue);opacity:.18;border-radius:50%;top:-180px;right:-120px;filter:blur(20px)}
.entry::after{content:"";position:absolute;width:420px;height:420px;background:var(--orange);opacity:.16;border-radius:50%;bottom:-160px;left:-100px;filter:blur(20px)}
.entry .wrap{position:relative}
.entry .ey{font-size:.85rem;letter-spacing:.18em;font-weight:700;color:var(--orange-lt);margin-bottom:1.2em}
.entry .ey .mono{color:#fff}
.entry h2{font-size:clamp(2rem,5vw,3.4rem);line-height:1.2}
.entry-lead{margin-top:1.5em;font-size:1.05rem;line-height:2;color:#cdd8ea;font-weight:500}
.entry-cta{margin-top:2.6em;display:flex;gap:1em;justify-content:center;flex-wrap:wrap}
.entry-info{margin-top:2.6em;font-size:.92rem;color:#aebcd2;line-height:1.9}
.entry-info .mono{color:#fff}

/* footer */
.foot{background:#0f1a2c;color:#aebcd2;padding:60px 0 70px;text-align:center}
.foot .logo{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:1.2rem;color:#fff;letter-spacing:.05em}
.foot .logo .mono{font-size:.7rem;letter-spacing:.22em;color:var(--orange-lt);margin-left:.5em}
.foot-addr{margin-top:.8em;font-size:.88rem}
.disc{margin-top:1.8em;font-size:.74rem;line-height:1.9;color:#6f7e96;max-width:62em;margin-inline:auto}
.disc a{color:var(--blue-lt);text-decoration:underline}
.disc a:hover{color:var(--orange-lt)}
