@import url('./fonts.css');

/* 真似元: 株式会社ノースサンド northsand.co.jp/
   観察結果:
   - 全ページ共通: 方眼紙風グリッド背景(クリーム #fff8eb 上に細グリッド)
   - 左に縦帯3色カラーバンド(青 + オレンジ + グレー)
   - 「Thursday, June DD, YYYY」新聞風日付(左上に細字)
   - 右に縦ページネーション(1〜N + SCROLL ラベル)
   - 右上に「CAREERS」「YOUTUBE CHANNEL」縦タブ
   - 黒帯横スクロール マーキー(英文キャッチが流れる)
   - 下部固定ナビ: COMPANY / PHILOSOPHY / SERVICE / RECRUIT / IR / NEWS
   - 右下に大型「+JOIN US」雲型ボタン
   - 大型タイトル「RECRUIT」+ 日本語キャッチ「愛嬌、素直さ、しつこさ」
   - NORTHSAND 独自タイポ(明朝ベース、N がブラケット風)
   - 手描き風フラットイラスト(街風景、人物、温かい色味)
   主色: クリーム #fff8eb / インク #231f20 / 群青 #1c3a7a / オレンジ #e87a3a / 鉛筆 #c6c6c2 */
:root{
  --p51-paper:#fff8eb;
  --p51-paper-deep:#f7eed8;
  --p51-ink:#231f20;
  --p51-ink-soft:#3a3a3a;
  --p51-mute:#8a8478;
  --p51-line:#e7dec4;
  --p51-grid:#e8dfc6;
  --p51-blue:#1c3a7a;
  --p51-blue-deep:#142a5c;
  --p51-orange:#e87a3a;
  --p51-pencil:#c6c6c2;
  --p51-red:#c84a3a;
  --p51-green:#5a8a5a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{
  background:var(--p51-paper);
  color:var(--p51-ink);
  font-family:var(--p51-font-body);
  font-weight:400;
  font-size:14px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  /* 方眼紙グリッド(20px間隔の細線+50ごとに少し濃い線) */
  background-image:
    linear-gradient(to right, rgba(180,160,110,.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(180,160,110,.08) 1px, transparent 1px),
    linear-gradient(to right, rgba(180,160,110,.16) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(180,160,110,.16) 1px, transparent 1px);
  background-size:20px 20px, 20px 20px, 100px 100px, 100px 100px;
  background-position:0 0;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* ===== 左縦帯3色カラーバンド ===== */
.p51-sidebar{
  position:fixed;left:0;top:0;bottom:0;width:36px;z-index:40;
  display:grid;grid-template-rows:1fr 1fr 1fr;
}
.p51-sidebar__a{background:var(--p51-blue)}
.p51-sidebar__b{background:var(--p51-orange)}
.p51-sidebar__c{background:#3a3530}

/* ===== 右上縦タブ(CAREERS / YOUTUBE CHANNEL) ===== */
.p51-rtabs{position:fixed;right:0;top:20%;z-index:35;display:flex;flex-direction:column;gap:8px}
.p51-rtabs a{
  writing-mode:vertical-rl;
  background:var(--p51-ink);color:var(--p51-paper);
  padding:18px 8px;
  font-family:var(--p51-font-mono);font-weight:600;font-size:11px;
  letter-spacing:.18em;
  border-radius:6px 0 0 6px;
}
.p51-rtabs a.is-blue{background:var(--p51-blue)}

/* ===== 新聞風日付(左上) ===== */
.p51-date{
  position:fixed;top:18px;left:54px;z-index:35;
  font-family:var(--p51-font-display);font-style:italic;
  font-weight:500;font-size:13px;color:var(--p51-ink-soft);
  letter-spacing:.02em;
}
.p51-date small{
  display:block;font-family:var(--p51-font-mono);font-style:normal;
  font-size:9.5px;letter-spacing:.18em;color:var(--p51-mute);
  margin-top:2px;text-transform:uppercase;
}

/* ===== 右縦ページネーション ===== */
.p51-paging{
  position:fixed;right:14px;bottom:140px;z-index:30;
  display:flex;flex-direction:column;gap:10px;align-items:center;
}
.p51-paging__n{
  font-family:var(--p51-font-mono);font-size:10.5px;color:var(--p51-ink-soft);
  letter-spacing:.1em;
}
.p51-paging__n.is-on{color:var(--p51-blue);font-weight:700}
.p51-paging__bar{width:1px;height:30px;background:var(--p51-pencil);margin:2px auto}
.p51-paging__scroll{
  writing-mode:vertical-rl;
  font-family:var(--p51-font-mono);font-size:9.5px;letter-spacing:.32em;
  color:var(--p51-mute);margin-top:8px;
}

/* ===== ヘッダー(上部、ロゴのみ) ===== */
.p51-header{
  position:relative;z-index:25;
  padding:24px 80px 0 80px;
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:24px;
}
.p51-skip{position:absolute;left:-9999px}
.p51-skip:focus{left:60px;top:8px;background:var(--p51-blue);color:#fff;padding:6px 12px;z-index:50}

.p51-logo{
  font-family:var(--p51-font-display);
  font-weight:700;font-size:28px;letter-spacing:.16em;
  color:var(--p51-ink);line-height:1;
  display:inline-block;
}
.p51-logo b{ /* N のブラケット風(両端を強調) */
  display:inline-block;position:relative;
}
.p51-logo b::before,.p51-logo b::after{
  content:"";position:absolute;width:6px;height:8px;
  border:1.5px solid var(--p51-ink);
}
.p51-logo b::before{left:-1px;top:-3px;border-right:0;border-bottom:0}
.p51-logo b::after{right:-1px;bottom:-3px;border-left:0;border-top:0}
.p51-logo small{
  display:block;font-family:var(--p51-font-mono);font-weight:500;
  font-size:9.5px;letter-spacing:.22em;color:var(--p51-mute);
  margin-top:6px;
}

.p51-utop{display:flex;gap:14px;font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.16em;color:var(--p51-ink-soft);align-items:center}
.p51-utop a{padding:6px 10px;border:1px solid var(--p51-ink);border-radius:20px}

/* ===== HERO(トップ) ===== */
.p51-hero{
  position:relative;
  padding:60px 90px 100px 90px;
  min-height:calc(100vh - 120px);
  display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center;
}
.p51-hero__left{position:relative}
.p51-hero__eyebrow{
  font-family:var(--p51-font-mono);font-size:11px;letter-spacing:.22em;
  color:var(--p51-blue);font-weight:600;margin:0 0 18px;
  display:flex;align-items:center;gap:10px;
}
.p51-hero__eyebrow::before{content:"";width:36px;height:1px;background:var(--p51-blue);display:inline-block}
.p51-hero__title{
  font-family:var(--p51-font-display);font-weight:700;
  font-size:clamp(72px,11vw,160px);
  line-height:.92;letter-spacing:.02em;color:var(--p51-ink);
  margin:0 0 18px;
}
.p51-hero__jp{
  font-family:var(--p51-font-jp-display);font-weight:700;
  font-size:clamp(22px,2.6vw,32px);
  letter-spacing:.18em;color:var(--p51-ink);
  line-height:1.6;margin:0 0 22px;
}
.p51-hero__jp em{font-style:normal;color:var(--p51-orange);border-bottom:3px solid var(--p51-orange);padding-bottom:2px}
.p51-hero__lead{
  font-size:14.5px;line-height:1.95;color:var(--p51-ink-soft);
  max-width:46ch;margin:0 0 24px;
}
.p51-hero__meta{
  font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.16em;
  color:var(--p51-mute);
}
.p51-hero__meta b{color:var(--p51-ink);font-weight:600}

/* 手描き風イラストプレート(右側) */
.p51-hero__illust{
  position:relative;aspect-ratio:4/5;background:var(--p51-paper-deep);
  border:1px solid var(--p51-line);
  overflow:hidden;
  display:grid;place-items:center;
}
.p51-hero__illust img{
  width:100%;height:100%;object-fit:cover;
  filter:sepia(.18) saturate(.85) contrast(.95);
  mix-blend-mode:multiply;opacity:.92;
}
.p51-hero__illust::after{
  /* 手描き風の枠 */
  content:"";position:absolute;inset:14px;border:1.5px solid var(--p51-ink);
  pointer-events:none;
}
.p51-hero__illust__tag{
  position:absolute;left:24px;bottom:24px;z-index:2;
  background:var(--p51-paper);padding:8px 14px;
  font-family:var(--p51-font-mono);font-size:10px;letter-spacing:.2em;
  color:var(--p51-ink);border:1px solid var(--p51-ink);
}

/* ===== 黒帯横スクロール マーキー ===== */
.p51-marquee{
  background:var(--p51-ink);color:var(--p51-paper);
  overflow:hidden;padding:18px 0;position:relative;
  border-top:1px solid var(--p51-ink);
}
.p51-marquee__track{
  display:flex;gap:60px;white-space:nowrap;
  animation:p51marq 30s linear infinite;
  width:max-content;
  font-family:var(--p51-font-display);font-style:italic;
  font-weight:600;font-size:clamp(28px,4vw,56px);
  letter-spacing:.04em;
}
.p51-marquee__track span{display:inline-block;padding-right:0}
.p51-marquee__track span::after{content:"✦";margin-left:60px;color:var(--p51-orange);font-size:.6em;vertical-align:middle}
@keyframes p51marq{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ===== 数字セクション ===== */
.p51-numbers{padding:80px 90px;position:relative}
.p51-numbers__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin:0 0 36px;border-bottom:1px solid var(--p51-line);padding-bottom:16px;
}
.p51-numbers__head h2{
  font-family:var(--p51-font-display);font-weight:700;
  font-size:clamp(40px,5vw,64px);letter-spacing:.04em;margin:0;line-height:1;
}
.p51-numbers__head small{
  font-family:var(--p51-font-mono);font-size:11px;letter-spacing:.2em;
  color:var(--p51-mute);
}
.p51-numbers__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-left:1px solid var(--p51-line)}
.p51-num{padding:30px 26px;border-right:1px solid var(--p51-line);border-bottom:1px solid var(--p51-line);border-top:1px solid var(--p51-line);background:var(--p51-paper)}
.p51-num__label{font-family:var(--p51-font-mono);font-size:10px;letter-spacing:.18em;color:var(--p51-mute);margin:0 0 12px}
.p51-num__v{font-family:var(--p51-font-display);font-weight:700;font-size:clamp(40px,5vw,68px);color:var(--p51-blue);line-height:1;letter-spacing:.02em}
.p51-num__u{font-family:var(--p51-font-mono);font-size:14px;color:var(--p51-ink);margin-left:6px}
.p51-num__t{font-size:13px;color:var(--p51-ink);margin:8px 0 4px;font-weight:700}
.p51-num__note{font-size:11px;color:var(--p51-mute);margin:0}

/* ===== ジョブカード一覧(トップ用 + 一覧ページ用) ===== */
.p51-jobs__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  padding:0 90px 80px;
}
.p51-jobcard{
  display:flex;flex-direction:column;
  background:var(--p51-paper);
  border:1px solid var(--p51-ink);
  text-decoration:none;color:var(--p51-ink);
  transition:transform .25s ease, box-shadow .25s ease;
  position:relative;
  padding:0;
  overflow:hidden;
}
.p51-jobcard:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--p51-ink)}
.p51-jobcard__plate{aspect-ratio:4/3;background:var(--p51-paper-deep);overflow:hidden;position:relative;border-bottom:1px solid var(--p51-ink)}
.p51-jobcard__plate img{width:100%;height:100%;object-fit:cover;filter:sepia(.15) saturate(.85);mix-blend-mode:multiply}
.p51-jobcard__plate::after{
  content:attr(data-code);position:absolute;left:14px;top:14px;
  background:var(--p51-paper);border:1px solid var(--p51-ink);
  padding:4px 10px;font-family:var(--p51-font-mono);font-size:10.5px;
  letter-spacing:.16em;font-weight:600;
}
.p51-jobcard__body{padding:22px 22px 24px}
.p51-jobcard__title{font-family:var(--p51-font-jp-display);font-weight:700;font-size:20px;margin:0 0 6px;line-height:1.4}
.p51-jobcard__sub{font-size:12.5px;color:var(--p51-ink-soft);margin:0 0 14px;line-height:1.7}
.p51-jobcard__meta{display:flex;flex-wrap:wrap;gap:10px;font-family:var(--p51-font-mono);font-size:10.5px;color:var(--p51-ink-soft);padding-top:12px;border-top:1px dashed var(--p51-pencil)}
.p51-jobcard__meta b{color:var(--p51-blue);font-weight:600}

/* トップ「JOBS」セクション枠 */
.p51-section{padding:60px 90px}
.p51-section__head{display:flex;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--p51-line);padding-bottom:14px;margin:0 0 36px}
.p51-section__head h2{font-family:var(--p51-font-display);font-weight:700;font-size:clamp(40px,5vw,64px);letter-spacing:.04em;margin:0;line-height:1}
.p51-section__head h2 em{font-style:italic;color:var(--p51-orange)}
.p51-section__head small{font-family:var(--p51-font-mono);font-size:11px;letter-spacing:.2em;color:var(--p51-mute)}
.p51-section__lead{font-family:var(--p51-font-jp-display);font-weight:500;font-size:17px;line-height:1.85;color:var(--p51-ink);max-width:60ch;margin:0 0 36px}

/* voices(社員の声) */
.p51-voices{display:grid;grid-template-columns:1fr 1fr;gap:36px;padding:0 90px 80px}
.p51-voice{
  background:var(--p51-paper);border:1px solid var(--p51-ink);
  padding:30px 28px;display:grid;grid-template-columns:120px 1fr;gap:20px;
  position:relative;
}
.p51-voice::before{
  content:"“";position:absolute;right:14px;top:-22px;
  font-family:var(--p51-font-display);font-size:96px;color:var(--p51-orange);
  line-height:1;
}
.p51-voice__photo{width:120px;height:120px;border-radius:50%;overflow:hidden;border:2px solid var(--p51-ink)}
.p51-voice__photo img{width:100%;height:100%;object-fit:cover;filter:sepia(.12) saturate(.9)}
.p51-voice__quote{font-family:var(--p51-font-jp-display);font-weight:500;font-size:15px;line-height:1.85;color:var(--p51-ink);margin:0 0 14px}
.p51-voice__name{font-family:var(--p51-font-jp-display);font-weight:700;font-size:15px;color:var(--p51-ink)}
.p51-voice__attr{font-family:var(--p51-font-mono);font-size:10.5px;color:var(--p51-mute);letter-spacing:.1em;margin-top:2px}

/* ===== 下部固定ナビ ===== */
.p51-fnav{
  position:fixed;left:36px;bottom:0;right:0;z-index:40;
  background:var(--p51-paper);
  border-top:1px solid var(--p51-ink);
  display:grid;grid-template-columns:repeat(6,1fr) auto;
  align-items:stretch;
  padding-right:140px; /* JOIN US ぶん */
}
.p51-fnav a{
  padding:18px 14px;border-right:1px solid var(--p51-line);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  font-family:var(--p51-font-display);font-weight:700;font-size:14px;
  letter-spacing:.14em;color:var(--p51-ink);
  text-align:center;
}
.p51-fnav a small{
  display:block;font-family:var(--p51-font-body);font-weight:400;
  font-size:10px;letter-spacing:.04em;color:var(--p51-mute);
  margin-top:4px;
}
.p51-fnav a:hover{background:var(--p51-paper-deep);color:var(--p51-blue)}

/* ===== 雲型 JOIN US ボタン(右下) ===== */
.p51-join{
  position:fixed;right:24px;bottom:18px;z-index:50;
  width:120px;height:120px;
  display:grid;place-items:center;
  background:var(--p51-orange);
  color:#fff;font-family:var(--p51-font-display);font-style:italic;font-weight:700;
  font-size:18px;letter-spacing:.04em;text-align:center;line-height:1.1;
  /* 雲型 borderRadius */
  border-radius:62% 38% 55% 45% / 50% 60% 40% 50%;
  box-shadow:0 6px 20px rgba(0,0,0,.18);
  animation:p51wobble 8s ease-in-out infinite;
}
.p51-join span{display:block;font-size:11px;font-style:normal;font-family:var(--p51-font-mono);letter-spacing:.18em;font-weight:500;margin-top:4px;opacity:.92}
@keyframes p51wobble{
  0%,100%{border-radius:62% 38% 55% 45% / 50% 60% 40% 50%;transform:translateY(0) rotate(-2deg)}
  33%{border-radius:48% 52% 38% 62% / 60% 42% 58% 40%;transform:translateY(-4px) rotate(1deg)}
  66%{border-radius:55% 45% 62% 38% / 42% 58% 50% 50%;transform:translateY(2px) rotate(-1deg)}
}

/* ===== フッター(下部固定ナビの下に来る通常領域) ===== */
.p51-foot{
  padding:60px 90px 200px 90px;
  border-top:1px solid var(--p51-line);
  background:var(--p51-paper);
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:36px;
}
.p51-foot__brand h3{
  font-family:var(--p51-font-display);font-weight:700;font-size:24px;
  letter-spacing:.14em;margin:0 0 8px;color:var(--p51-ink);
}
.p51-foot__brand small{font-family:var(--p51-font-mono);font-size:10px;letter-spacing:.2em;color:var(--p51-mute)}
.p51-foot__brand p{font-size:12.5px;line-height:1.85;color:var(--p51-ink-soft);margin:14px 0 0;max-width:38ch}
.p51-foot__col h4{font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.2em;color:var(--p51-blue);margin:0 0 12px;text-transform:uppercase}
.p51-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.p51-foot__col a{font-size:12.5px;color:var(--p51-ink-soft)}
.p51-foot__col a:hover{color:var(--p51-orange)}
.p51-foot__copyright{
  grid-column:1 / -1;border-top:1px solid var(--p51-line);
  padding-top:18px;margin-top:14px;
  font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.14em;color:var(--p51-mute);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
}

/* ============================================================
   下層ページ共通
   ============================================================ */
.p51-page{padding-top:24px}
.p51-page__hero{
  padding:60px 90px 40px 90px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:flex-end;
  border-bottom:1px solid var(--p51-line);
}
.p51-page__hero__title{
  font-family:var(--p51-font-display);font-weight:700;
  font-size:clamp(64px,9vw,140px);letter-spacing:.02em;
  line-height:.95;color:var(--p51-ink);margin:0;
}
.p51-page__hero__jp{
  font-family:var(--p51-font-jp-display);font-weight:700;font-size:20px;
  color:var(--p51-blue);letter-spacing:.14em;margin:12px 0 0;
}
.p51-page__hero__lead{font-size:14px;line-height:1.95;color:var(--p51-ink-soft);max-width:48ch;margin:0}
.p51-page__crumb{
  padding:18px 90px 0;
  font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.1em;
  color:var(--p51-mute);
}
.p51-page__crumb a{color:var(--p51-mute)}
.p51-page__inner{padding:50px 90px 80px;max-width:1200px}

/* JOBS index lead */
.p51-jobs__lead{padding:32px 90px 0;font-size:14.5px;line-height:1.95;color:var(--p51-ink-soft);max-width:64ch}

/* JOB detail */
.p51-job__hero{
  padding:60px 90px 36px;
  border-bottom:1px solid var(--p51-line);
}
.p51-job__hero__code{font-family:var(--p51-font-mono);font-size:11px;letter-spacing:.22em;color:var(--p51-blue);font-weight:600;margin:0 0 12px}
.p51-job__hero__title{font-family:var(--p51-font-jp-display);font-weight:700;font-size:clamp(36px,5vw,56px);letter-spacing:.06em;margin:0;line-height:1.2;color:var(--p51-ink)}
.p51-job__hero__sub{font-family:var(--p51-font-display);font-style:italic;font-weight:600;font-size:20px;color:var(--p51-orange);margin:8px 0 0}
.p51-job__hero__lead{font-size:14.5px;line-height:1.95;color:var(--p51-ink);max-width:58ch;margin:18px 0 0}
.p51-job__hero__photo{margin-top:30px;border:1px solid var(--p51-ink);overflow:hidden;aspect-ratio:21/9}
.p51-job__hero__photo img{width:100%;height:100%;object-fit:cover;filter:sepia(.12) saturate(.9)}
.p51-job__hero__meta{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:28px;border-left:1px solid var(--p51-line);
}
.p51-job__hero__meta > div{padding:16px 18px;border-right:1px solid var(--p51-line);border-top:1px solid var(--p51-line);border-bottom:1px solid var(--p51-line)}
.p51-job__hero__meta dt{font-family:var(--p51-font-mono);font-size:10px;letter-spacing:.18em;color:var(--p51-mute);margin:0 0 6px;font-weight:600}
.p51-job__hero__meta dd{margin:0;font-family:var(--p51-font-jp-display);font-weight:700;font-size:15px;color:var(--p51-ink)}

.p51-job__sec{padding:50px 90px 0;max-width:1100px}
.p51-job__sec__head{
  display:flex;align-items:baseline;gap:18px;margin:0 0 22px;
  border-bottom:1px solid var(--p51-line);padding-bottom:10px;
}
.p51-job__sec__head h3{font-family:var(--p51-font-display);font-weight:700;font-size:32px;letter-spacing:.04em;margin:0;color:var(--p51-ink);line-height:1}
.p51-job__sec__head small{font-family:var(--p51-font-mono);font-size:10.5px;letter-spacing:.2em;color:var(--p51-mute)}
.p51-job__sec p{font-size:14.5px;line-height:1.95;color:var(--p51-ink);margin:0 0 14px}
.p51-job__sec ul{padding-left:0;margin:0;font-size:14.5px;line-height:1.95;list-style:none}
.p51-job__sec ul li{padding-left:22px;position:relative;margin:0 0 8px}
.p51-job__sec ul li::before{content:"✦";color:var(--p51-orange);position:absolute;left:0;top:0}

/* 1日の流れ */
.p51-day{display:grid;grid-template-columns:120px 1fr;gap:0;border-top:1px solid var(--p51-ink)}
.p51-day__row{display:contents}
.p51-day__time{
  padding:22px 18px;border-bottom:1px solid var(--p51-line);
  border-right:1px solid var(--p51-ink);background:var(--p51-paper-deep);
  font-family:var(--p51-font-display);font-weight:700;font-size:22px;
  color:var(--p51-blue);letter-spacing:.02em;display:flex;align-items:center;justify-content:center;
}
.p51-day__body{padding:22px 24px;border-bottom:1px solid var(--p51-line);background:var(--p51-paper)}
.p51-day__body h4{font-family:var(--p51-font-jp-display);font-weight:700;font-size:15px;margin:0 0 6px;color:var(--p51-ink)}
.p51-day__body p{font-size:13.5px;color:var(--p51-ink-soft);margin:0;line-height:1.85}

/* requirements table */
.p51-reqtable{width:100%;border-collapse:collapse;font-size:14px;border-top:2px solid var(--p51-ink)}
.p51-reqtable tr{border-bottom:1px solid var(--p51-line)}
.p51-reqtable th{
  font-family:var(--p51-font-jp-display);font-weight:700;font-size:13px;
  color:var(--p51-blue);text-align:left;padding:20px 22px 20px 0;width:200px;vertical-align:top;
  background:transparent;
}
.p51-reqtable td{padding:20px 0;color:var(--p51-ink);line-height:1.95}

/* faq */
.p51-faqlist{border-top:2px solid var(--p51-ink);max-width:880px}
.p51-faqitem{border-bottom:1px solid var(--p51-line);background:transparent}
.p51-faqitem summary{
  font-family:var(--p51-font-jp-display);font-weight:700;font-size:15.5px;
  color:var(--p51-ink);cursor:pointer;list-style:none;padding:22px 0;
  display:flex;gap:18px;align-items:flex-start;
}
.p51-faqitem summary::-webkit-details-marker{display:none}
.p51-faqitem summary::before{
  content:"Q.";font-family:var(--p51-font-display);font-weight:700;
  color:var(--p51-blue);font-size:22px;line-height:1;flex-shrink:0;
}
.p51-faqitem summary::after{
  content:"+";margin-left:auto;color:var(--p51-orange);font-size:22px;font-weight:300;
}
.p51-faqitem[open] summary::after{content:"−"}
.p51-faqitem div{padding:0 0 22px 40px;font-size:14px;color:var(--p51-ink-soft);line-height:1.95;display:flex;gap:18px}
.p51-faqitem div::before{
  content:"A.";font-family:var(--p51-font-display);font-weight:700;
  color:var(--p51-orange);font-size:22px;line-height:1;flex-shrink:0;
}

/* apply form */
.p51-form{display:grid;gap:22px;max-width:680px}
.p51-form__note{
  font-size:12.5px;color:var(--p51-ink-soft);background:var(--p51-paper-deep);
  padding:16px 22px;border-left:3px solid var(--p51-orange);max-width:680px;
  margin:0 0 24px;line-height:1.85;
}
.p51-form label{display:block;font-family:var(--p51-font-jp-display);font-weight:700;font-size:13px;color:var(--p51-ink);margin:0 0 8px;letter-spacing:.04em}
.p51-form label small{font-weight:500;color:var(--p51-red);margin-left:6px;font-size:10.5px;font-family:var(--p51-font-mono);letter-spacing:.1em}
.p51-form input,.p51-form select,.p51-form textarea{
  width:100%;font:inherit;padding:14px 16px;
  border:1px solid var(--p51-ink);background:var(--p51-paper);
  color:var(--p51-ink);border-radius:0;font-size:14px;
}
.p51-form input:focus,.p51-form select:focus,.p51-form textarea:focus{
  outline:none;border-color:var(--p51-blue);box-shadow:0 0 0 3px rgba(28,58,122,.12);
}
.p51-form button{
  background:var(--p51-ink);color:var(--p51-paper);padding:18px 52px;
  font-family:var(--p51-font-display);font-weight:700;font-style:italic;font-size:18px;
  letter-spacing:.06em;border:0;cursor:pointer;justify-self:start;margin-top:6px;
  border-radius:42% 58% 50% 50% / 50% 50% 50% 50%;
}
.p51-form button:hover{background:var(--p51-blue)}

/* history */
.p51-history{border-top:2px solid var(--p51-ink);max-width:880px}
.p51-history__row{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--p51-line)}
.p51-history__year{font-family:var(--p51-font-display);font-weight:700;font-size:24px;color:var(--p51-blue);letter-spacing:.04em;font-style:italic}
.p51-history__event{font-size:14px;color:var(--p51-ink);line-height:1.85}

/* message */
.p51-message{padding:60px 90px;border-top:1px solid var(--p51-line);position:relative}
.p51-message__inner{display:grid;grid-template-columns:260px 1fr;gap:48px;align-items:flex-start;max-width:1100px}
.p51-message__photo{aspect-ratio:1/1;overflow:hidden;border:1px solid var(--p51-ink)}
.p51-message__photo img{width:100%;height:100%;object-fit:cover;filter:sepia(.15) saturate(.9)}
.p51-message__title{font-family:var(--p51-font-jp-display);font-weight:700;font-size:clamp(24px,3vw,34px);line-height:1.5;color:var(--p51-ink);margin:0 0 22px}
.p51-message__body{font-size:14.5px;line-height:2;color:var(--p51-ink-soft);white-space:pre-line;margin:0 0 22px}
.p51-message__sign{font-family:var(--p51-font-jp-display);font-size:13px;color:var(--p51-blue);text-align:right;border-top:1px solid var(--p51-line);padding-top:14px}
.p51-message__sign b{color:var(--p51-ink);font-size:16px;font-weight:700}

/* ===== responsive ===== */
@media (max-width:1100px){
  .p51-hero,.p51-page__hero{grid-template-columns:1fr;padding-left:60px;padding-right:60px}
  .p51-numbers,.p51-section,.p51-jobs__grid,.p51-voices,.p51-job__hero,.p51-job__sec,.p51-page__inner,.p51-message{padding-left:60px;padding-right:60px}
  .p51-foot{padding-left:60px;padding-right:60px}
  .p51-page__crumb,.p51-jobs__lead{padding-left:60px;padding-right:60px}
}
@media (max-width:880px){
  .p51-sidebar{width:24px}
  .p51-date{left:36px;font-size:11px}
  .p51-rtabs{display:none}
  .p51-paging{display:none}
  .p51-header{padding:18px 30px 0}
  .p51-utop{display:none}
  .p51-hero{padding:30px 24px 40px;min-height:auto}
  .p51-hero__title{font-size:72px}
  .p51-numbers__grid{grid-template-columns:repeat(2,1fr)}
  .p51-jobs__grid{grid-template-columns:1fr;padding:0 24px 60px}
  .p51-voices{grid-template-columns:1fr;padding:0 24px 60px}
  .p51-section,.p51-numbers,.p51-foot,.p51-job__hero,.p51-job__sec,.p51-page__inner,.p51-message{padding-left:24px;padding-right:24px}
  .p51-page__crumb,.p51-jobs__lead{padding-left:24px;padding-right:24px}
  .p51-page__hero{padding:30px 24px}
  .p51-page__hero__title{font-size:56px}
  .p51-foot{grid-template-columns:1fr;padding-bottom:240px}
  .p51-fnav{grid-template-columns:repeat(3,1fr);padding-right:0;left:24px}
  .p51-fnav a{padding:12px 6px;font-size:11px}
  .p51-fnav a small{display:none}
  .p51-join{width:80px;height:80px;font-size:13px;right:12px;bottom:120px}
  .p51-join span{font-size:9px}
  .p51-job__hero__meta{grid-template-columns:1fr 1fr}
  .p51-message__inner{grid-template-columns:1fr}
  .p51-day{grid-template-columns:90px 1fr}
}

/* ===== motion reveal ===== */
html.p51-motion-ready .p51-reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease var(--p51-delay,0ms),transform .8s ease var(--p51-delay,0ms)}
html.p51-motion-ready .p51-reveal.p51-in{opacity:1;transform:none}
