/*
 * bootstrap-override.css
 * 松島新地求人 専用カラー（オレンジ系）
 * Bootstrap削除後の独自ベーススタイル
 */

:root {
  /* ── page-beginner / page-recruit 用変数 ── */
  --sky-50:  #FDF3EB;
  --sky-100: #F2C49B;
  --sky-200: #D4703A;
  --sky-400: #FF9900;
  --sky-500: #D4703A;
  --sky-600: #7A2900;
  --sky-700: #5C1E00;
  --sky-900: #3D1000;
  --text:        #1C2B33;
  --text-muted:  #546E7A;
  --text-light:  #8EA5B5;
  --border:      rgba(255,153,0,0.18);
  --border-med:  rgba(255,153,0,0.35);
  --accent:      #FF9900;
  --accent-dark: #7A2900;
  --nakai-main: #FF9900;
  --nakai-dark: #7A2900;
  --nakai-pale: #FDF3EB;
  --nakai-line: #F2C49B;
  --nakai-mid:  #D4703A;
  --ff-head: 'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;
  --ff-body: 'Noto Sans JP', sans-serif;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 18px;
  /* ── 松島新地 オレンジ系メインカラー ── */
  --orange-main:   #FF9900;
  --orange-deep:   #7A2900;
  --orange-medium: #D4703A;
  --orange-light:  #F2C49B;
  --orange-pale:   #FDF3EB;

  /* 旧変数エイリアス（既存CSSとの互換性） */
  --pink-main:   #FF9900;
  --pink-deep:   #7A2900;
  --pink-medium: #D4703A;
  --pink-light:  #F2C49B;
  --pink-pale:   #FDF3EB;
  --navy:        #7A2900;
  --gold:        #D4703A;
  --gold-light:  #F2C49B;
  --mint:        #D4703A;
  --mint-pale:   #FDF3EB;
  --mint-light:  #F2C49B;
  --yellow:      #FF9900;
  --yellow-pale: #FDF3EB;
  --yellow-light:#F2C49B;

  --white:      #FFFFFF;
  --gray-text:  #555;
  --gray-light: #f9f9f9;
  --max-w:      1200px;
}

html { overflow-x: hidden; }
body {
  font-family: 'Noto Sans JP', sans-serif;
  background-color: var(--white);
  color: var(--orange-deep);
  overflow-x: hidden;
  font-size: 16px;
  line-height: 1.8;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: none;
  position: relative;
}

.btn-primary {
  display: inline-block;
  background: linear-gradient(135deg, var(--orange-medium), var(--orange-main));
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  padding: 14px 36px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: transform .2s;
  line-height: 1.5;
}
.btn-primary:hover,
.btn-primary:focus {
  transform: translateY(-2px);
  color: #fff;
  background: linear-gradient(135deg, var(--orange-main), var(--orange-medium));
}

.btn-white {
  display: inline-block;
  background: #fff;
  color: var(--orange-main);
  font-size: 15px;
  font-weight: 700;
  padding: 14px 40px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: transform .2s;
}
.btn-white:hover { transform: translateY(-2px); color: var(--orange-deep); }

.btn-outline {
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent;
  color: var(--navy);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.18em;
  text-decoration: none;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--gold);
  transition: gap 0.3s, color 0.2s, border-color 0.2s;
}
.btn-outline::after { content: '→'; font-family: 'Cormorant Garamond', Georgia, serif; font-size: 16px; font-weight: 300; color: var(--gold); transition: transform 0.3s; }
.btn-outline:hover { color: var(--gold); border-color: var(--gold); gap: 16px; }
.btn-outline:hover::after { transform: translateX(4px); }

.btn-outline-w,
.btn-outline-white {
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent;
  color: rgba(255,255,255,0.85);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.18em;
  text-decoration: none;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.45);
  transition: gap 0.3s, color 0.2s, border-color 0.2s;
}
.btn-outline-w::after,
.btn-outline-white::after { content: '→'; font-family: 'Cormorant Garamond', Georgia, serif; font-size: 16px; font-weight: 300; transition: transform 0.3s; }
.btn-outline-w:hover,
.btn-outline-white:hover { color: #fff; border-color: rgba(255,255,255,0.85); gap: 16px; }
.btn-outline-w:hover::after,
.btn-outline-white:hover::after { transform: translateX(4px); }

.treatment-card, .col-card, .scol-rel-card, .strmt-rel-card,
.related-card, .ev-card, .dorm-card, .shift-card, .fi-card, .contact-info-card {
  border-radius: unset;
}

.nav-item > a { text-decoration: none; }

.section-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 24px; }

.treatment-card-desc li::marker,
.fi-card-list li::before,
.scol-content li::marker,
.strmt-content li::marker { color: var(--orange-main); }

img { max-width: 100%; height: auto; }
table { border-collapse: collapse; }
input, textarea, select, button { box-sizing: border-box; }
*, *::before, *::after { box-sizing: border-box; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 700; line-height: 1.4; }
p { margin: 0; }

/* ============================================================
   shift-grid / shift-card（1日の流れ）page-beginner/recruit用
   ============================================================ */
.shift-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin:24px 0; }
@media(max-width:640px){ .shift-grid{ grid-template-columns:1fr; } }
.shift-card { background:var(--white); border:1.5px solid var(--border); border-radius:var(--radius-md); overflow:hidden; transition:border-color .2s,box-shadow .2s; }
.shift-card:hover { border-color:var(--accent); box-shadow:0 4px 18px rgba(56,170,207,.1); }
.shift-card-head { background:var(--sky-600); color:var(--white); font-size:13px; font-weight:700; padding:12px 18px; letter-spacing:.03em; }
.shift-card-body { padding:18px; }
.shift-card-body ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.shift-card-body ul li { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--text-muted); line-height:1.6; padding-bottom:10px; border-bottom:1px solid var(--border); }
.shift-card-body ul li:last-child { border-bottom:none; padding-bottom:0; }
.shift-card-body ul li strong { flex-shrink:0; color:var(--accent-dark); font-weight:700; min-width:52px; }