/* =============================================================
   careers.css — Careers Page 専用スタイルシート
   配置先: wp-content/themes/kakehashi-realty/assets/css/careers.css
   
   デザインテーマ: ライト（クリーム / ネイビー / ゴールド）
   main.css と完全独立。.cr- プレフィックスでスコープ。
   ============================================================= */

/* ----- Token (careers独自、main.cssのnnavy変数を上書きしない) ----- */
:root {
  --cr-bg:      #FAF7F2;
  --cr-paper:   #F5F0E6;
  --cr-paper-2: #EDE8DA;
  --cr-ink:     #0A1628;
  --cr-ink-2:   #1a2438;
  --cr-gray:    #6B7280;
  --cr-line:    rgba(10,22,40,.12);
  --cr-gold:    #C9A84C;
  --cr-gold-d:  #8B7838;
  --cr-serif:   "Cormorant Garamond", "Noto Serif JP", serif;
  --cr-jp:      "Noto Serif JP", serif;
  --cr-mono:    "JetBrains Mono", "IBM Plex Mono", monospace;
}

/* =============================================
   PAGE BASE
   ============================================= */
body.page-careers {
  background: var(--cr-bg) !important;
  color: var(--cr-ink) !important;
}

.careers-wrap {
  font-family: var(--cr-jp);
  font-weight: 300;
  line-height: 1.8;
  font-size: 15px;
  letter-spacing: .02em;
  color: var(--cr-ink);
  background: var(--cr-bg);
  min-height: 100vh;
}
.careers-wrap h1,
.careers-wrap h2,
.careers-wrap h3,
.careers-wrap h4 {
  font-family: var(--cr-serif);
  font-weight: 300;
  letter-spacing: .01em;
}
.careers-wrap h1 { font-size: clamp(36px, 6vw, 64px); line-height: 1.1; }
.careers-wrap h2 { font-size: clamp(26px, 4vw, 40px); line-height: 1.2; }
.careers-wrap h3 { font-size: clamp(20px, 2.5vw, 26px); line-height: 1.3; }
.careers-wrap em { font-style: italic; color: var(--cr-gold); font-family: var(--cr-serif); }
.careers-wrap strong { font-weight: 600; color: var(--cr-ink); }

/* =============================================
   HEADER — header-careers.php
   ============================================= */
.cr-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 20px 48px;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(250,247,242,.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, padding .3s;
}
.cr-header.scrolled {
  padding: 14px 48px;
  border-bottom-color: var(--cr-line);
}
.cr-header-logo {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--cr-mono); font-size: 10px;
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--cr-ink); text-decoration: none;
}
.logo-bridge {
  display: flex; flex-direction: column; gap: 5px;
}
.logo-bridge span {
  display: block; height: 1px;
}
.logo-bridge span:nth-child(1) { width: 28px; background: var(--cr-gold); }
.logo-bridge span:nth-child(2) { width: 36px; background: var(--cr-ink); }
.logo-bridge span:nth-child(3) { width: 20px; background: var(--cr-ink); }
.logo-text { line-height: 1.5; }
.logo-text strong {
  display: block; font-size: 13px; letter-spacing: .22em;
  color: var(--cr-ink); font-weight: 500;
}
.logo-text small {
  display: block; font-size: 9px; letter-spacing: .3em; color: var(--cr-gold);
}
.cr-header-right {
  display: flex; align-items: center; gap: 20px;
}
.cr-back-link {
  font-family: var(--cr-mono); font-size: 10px;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--cr-gray); text-decoration: none;
  transition: color .2s;
  display: flex; align-items: center; gap: 8px;
}
.cr-back-link:hover { color: var(--cr-ink); }
.cr-back-link::before { content: "←"; font-family: var(--cr-serif); font-style: italic; font-size: 14px; }

/* =============================================
   LANG SWITCHER — inc/careers-lang-switcher.php
   ============================================= */
.cr-lang-switch {
  display: flex; gap: 2px;
  font-family: var(--cr-mono); font-size: 10px; letter-spacing: .15em;
}
.cr-lang-switch a {
  display: inline-block;
  padding: 6px 12px;
  border: 1px solid var(--cr-line);
  color: var(--cr-gray);
  text-decoration: none;
  transition: all .2s;
}
.cr-lang-switch a.active,
.cr-lang-switch a[aria-current="page"] {
  border-color: var(--cr-gold);
  color: var(--cr-gold);
  background: rgba(201,168,76,.08);
}
.cr-lang-switch a:hover:not(.active):not([aria-current="page"]) {
  border-color: var(--cr-ink);
  color: var(--cr-ink);
}

/* =============================================
   FOOTER — footer-careers.php
   ============================================= */
.cr-footer {
  background: var(--cr-ink);
  color: rgba(245,240,230,.6);
  padding: 48px;
  border-top: 1px solid rgba(201,168,76,.2);
}
.cr-footer-inner {
  max-width: 1080px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: flex-start;
  flex-wrap: wrap; gap: 24px;
}
.cr-footer-brand {
  font-family: var(--cr-mono); font-size: 11px;
  letter-spacing: .15em; line-height: 2; color: rgba(245,240,230,.45);
}
.cr-footer-brand strong {
  display: block; font-size: 13px; letter-spacing: .2em;
  color: rgba(245,240,230,.8); font-weight: 400; margin-bottom: 6px;
}
.cr-footer-brand a { color: rgba(201,168,76,.7); text-decoration: none; }
.cr-footer-links {
  display: flex; gap: 24px; flex-wrap: wrap; align-items: center;
  font-family: var(--cr-mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase;
}
.cr-footer-links a {
  color: rgba(245,240,230,.4); text-decoration: none; transition: color .2s;
}
.cr-footer-links a:hover { color: var(--cr-gold); }
.cr-footer-copy {
  width: 100%; padding-top: 24px; margin-top: 24px;
  border-top: 1px solid rgba(245,240,230,.07);
  font-family: var(--cr-mono); font-size: 10px;
  letter-spacing: .15em; color: rgba(245,240,230,.25);
}

/* =============================================
   LAYOUT
   ============================================= */
.cr-container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 48px;
}
.cr-section {
  padding: 70px 0;
  border-top: 1px solid var(--cr-line);
}
.cr-section:first-of-type { border-top: none; }
.cr-section-alt { background: var(--cr-paper); }
.cr-section-num {
  color: var(--cr-gold);
  font-family: var(--cr-mono);
  font-size: 11px; letter-spacing: .3em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

/* =============================================
   COVER
   ============================================= */
.cr-cover {
  padding: 160px 0 100px;
  background: linear-gradient(to bottom, var(--cr-bg) 0%, var(--cr-paper) 100%);
  position: relative; overflow: hidden;
}
.cr-cover::before {
  content: '';
  position: absolute; top: 0; right: -10%; width: 60%; height: 100%;
  background: radial-gradient(ellipse at center, rgba(201,168,76,.08) 0%, transparent 70%);
  pointer-events: none;
}
.cr-cover-eyebrow {
  font-family: var(--cr-mono); font-size: 11px;
  letter-spacing: .4em; text-transform: uppercase;
  color: var(--cr-gold); margin-bottom: 24px;
}
.cr-cover h1 em { color: var(--cr-gold); font-weight: 400; }
.cr-cover-tag {
  font-family: var(--cr-jp); font-size: 20px;
  color: var(--cr-gray); margin-top: 24px; line-height: 1.85;
}
.cr-cover-tag em { color: var(--cr-gold-d); font-style: italic; }

/* =============================================
   POSITION CARDS
   ============================================= */
.cr-position-card {
  background: var(--cr-paper);
  border: 1px solid var(--cr-line);
  padding: 40px;
  margin-bottom: 30px;
  position: relative;
}
.cr-position-card::before {
  content: '';
  position: absolute; top: 0; left: 0;
  width: 60px; height: 3px;
  background: var(--cr-gold);
}
.cr-position-id {
  font-family: var(--cr-mono); font-size: 10px;
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--cr-gold); margin-bottom: 12px;
}
.cr-position-card h3 {
  font-family: var(--cr-jp); font-size: 26px;
  font-weight: 400; margin-bottom: 16px; color: var(--cr-ink);
}
.cr-position-card > p {
  font-size: 14px; color: var(--cr-ink-2); line-height: 1.85;
}
.cr-position-meta {
  display: flex; flex-wrap: wrap; gap: 16px;
  margin: 20px 0; padding: 16px 0;
  border-top: 1px solid var(--cr-line);
  border-bottom: 1px solid var(--cr-line);
}
.cr-meta-item { font-size: 13px; }
.cr-meta-label {
  font-family: var(--cr-mono); font-size: 10px;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--cr-gold); display: block; margin-bottom: 4px;
}
.cr-meta-value {
  color: var(--cr-ink); font-weight: 500;
  font-family: var(--cr-jp);
}
.cr-position-section { margin-top: 24px; }
.cr-position-section h4 {
  font-size: 15px; color: var(--cr-gold); margin-bottom: 10px;
  font-family: var(--cr-jp); font-weight: 500; letter-spacing: .04em;
}
.cr-position-section ul { list-style: none; padding-left: 0; }
.cr-position-section li {
  padding: 6px 0 6px 22px;
  position: relative; font-size: 14px;
  color: var(--cr-ink-2); line-height: 1.75;
}
.cr-position-section li::before {
  content: '─'; position: absolute; left: 0; color: var(--cr-gold);
}

/* =============================================
   WHY US
   ============================================= */
.cr-why-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 30px; margin-top: 40px;
}
.cr-why-item {
  border-left: 2px solid var(--cr-gold);
  padding-left: 24px;
}
.cr-why-item h4 {
  font-family: var(--cr-jp); font-size: 20px;
  font-weight: 400; margin-bottom: 12px; color: var(--cr-ink);
}
.cr-why-item p { color: var(--cr-ink-2); line-height: 1.85; font-size: 14px; }

/* =============================================
   CTA
   ============================================= */
.cr-cta {
  background: var(--cr-ink); color: var(--cr-paper);
  padding: 80px 0; text-align: center;
}
.cr-cta .cr-section-num { color: var(--cr-gold); }
.cr-cta h2 { color: var(--cr-paper); margin-bottom: 24px; }
.cr-cta h2 em { color: var(--cr-gold); }
.cr-cta p {
  max-width: 640px; margin: 0 auto 32px;
  color: rgba(245,240,230,.8); font-size: 16px; line-height: 1.9;
}
.cr-cta-buttons {
  display: inline-flex; gap: 16px; flex-wrap: wrap; justify-content: center;
}
.cr-btn {
  display: inline-block; padding: 16px 36px;
  font-family: var(--cr-mono); font-size: 12px; letter-spacing: .25em;
  text-decoration: none;
  background: var(--cr-gold); color: var(--cr-ink);
  border: 1px solid var(--cr-gold); transition: all .3s;
}
.cr-btn:hover { background: transparent; color: var(--cr-gold); }
.cr-btn-outline { background: transparent; color: var(--cr-gold); }
.cr-btn-outline:hover { background: var(--cr-gold); color: var(--cr-ink); }
.cr-contact-info {
  margin-top: 30px; font-family: var(--cr-mono); font-size: 12px;
  color: rgba(245,240,230,.45); line-height: 2.2; letter-spacing: .08em;
}

/* =============================================
   HEADER SCROLL JS HOOK
   ============================================= */
/* main.js の scrolled クラスに対応 */
#cr-header.scrolled {
  padding: 14px 48px;
  border-bottom-color: var(--cr-line);
}

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 768px) {
  .cr-header { padding: 16px 24px; }
  .cr-header.scrolled, #cr-header.scrolled { padding: 12px 24px; }
  .cr-back-link span { display: none; }
  .cr-container { padding: 0 24px; }
  .cr-section { padding: 50px 0; }
  .cr-cover { padding: 120px 0 60px; }
  .cr-why-grid { grid-template-columns: 1fr; }
  .cr-position-meta { gap: 12px; }
  .cr-position-card { padding: 28px 20px; }
  .cr-footer { padding: 40px 24px; }
  .cr-footer-inner { flex-direction: column; gap: 16px; }
}