#guide {
  --navy: #1a2f6e;
  --navy-dark: #0f1d4a;
  --navy-light: #2a4090;
  --accent: #f07800;
  --accent-light: #ff9520;
  --gray-bg: #f7f7f7;
  --gray-mid: #e8ecf4;
  --gray-text: #666a7a;
  --dark: #1a1a2e;
  --shadow: 0 4px 24px rgba(26,47,110,0.10);
  --shadow-hover: 0 8px 36px rgba(26,47,110,0.18);
  color: var(--dark);
  box-sizing: border-box;
}
#guide *, #guide *::before, #guide *::after { box-sizing: border-box;}

/* ============================================================ 共通セクション */

#guide .section-eyebrow {
  font-weight: var(--bold);
  letter-spacing: 0.2em;
  color: var(--accent);
  text-transform: uppercase;
  display: block;
  margin-bottom: 0.625rem;
}
#guide .section-title {
 
  font-weight: var(--bold); color: var(--navy);
  line-height: 1.35;
  margin-bottom: 0.75rem;
}
#guide .section-title.on-navy { color: var(--main-r); }
#guide .section-lead {
  color: var(--gray-text);
  margin-bottom: 3.25rem;
}
#guide .section-lead.on-navy { color: rgba(255,255,255,0.75); }
#guide .divider {
  width: 3rem; height: 0.1875rem;
  background: var(--accent);
  margin: 1rem 0 2rem;
}
	
#guide_reason{
	background:var(--main);
}

/* ============================================================ ファーストビュー */



/* ============================================================ お悩みセクション */
#guide .worries-grid {
display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}
#guide .worry-card {
  background: var(--main-r);
  border-left: 0.25rem solid var(--accent);
  padding: 1.5rem 1.75rem;
  border-radius: 0 0.25rem 0.25rem 0;
  box-shadow: var(--shadow);
  display: flex; align-items: flex-start; gap: 1rem;
  transition: box-shadow 0.2s, transform 0.2s;
width: calc(100% / 3 - 1.33333333333rem);
}
#guide .worry-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }
#guide .worry-icon {
  width: 2.75rem; height: 2.75rem; flex-shrink: 0;
  background: var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
 
}
#guide .worry-text { var(--bold); color: var(--dark); line-height: 1.5; }
#guide .worry-sub { color: var(--gray-text); margin-top: 0.25rem; }

/* ============================================================ 放置リスク */
#guide .risk-flow {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
}
#guide .risk-flow::before {
  content: '';
  position: absolute;
  top: 3.25rem; left: 10%; right: 10%; height: 0.1875rem;
  background: linear-gradient(90deg, var(--accent), var(--navy));
  z-index: 0;
}
#guide .risk-item {
  text-align: center;
  position: relative; z-index: 1;
  padding: 0 0.5rem;
}
#guide .risk-circle {
  width: 6.5rem; height: 6.5rem;
  border-radius: 50%;
  background: var(--main-r);
  border: 3px solid var(--navy);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  margin: 0 auto 1rem;
 
  box-shadow: var(--shadow);
  transition: border-color 0.2s, transform 0.2s;
}
#guide .risk-item:hover .risk-circle { border-color: var(--accent); transform: scale(1.06); }
#guide .risk-label { font-weight: var(--bold); color: var(--navy); margin-bottom: 0.375rem; }
#guide .risk-desc { color: var(--gray-text); line-height: 1.6; }

#guide .risk-warning {
  margin-top: 3rem;
  background: linear-gradient(135deg, #fff3e0, #ffe0b2);
  border: 2px solid var(--accent);
  border-radius: 0.25rem;
  padding: 1.5rem 2rem;
  display: flex; align-items: flex-start; gap: 1rem;
}
#guide .risk-warning-text { line-height: 1.8; }
#guide .risk-warning-text span { color: var(--accent); }

/* ============================================================ サインセクション */
#guide .signs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11.25rem, 1fr));
  gap: 1.25rem;
}
#guide .sign-card {
  background: var(--main-r);
  border-radius: 0.25rem;
  padding: 2rem 1.25rem;
  text-align: center;
  box-shadow: var(--shadow);
  border-top: 0.25rem solid var(--navy);
  transition: border-color 0.2s, transform 0.2s;
}
#guide .sign-card:hover { border-color: var(--accent); transform: translateY(-3px); }
#guide .sign-emoji { margin-bottom: 0.75rem; display: block; }
#guide .sign-title { font-weight: var(--bold); color: var(--navy); margin-bottom: 0.5rem; }
#guide .sign-desc { color: var(--gray-text); line-height: 1.7; }

/* ============================================================ 費用・タイミング */
#guide .cost-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
#guide .cost-card {
  background: var(--main-r);
  border-radius: 0.25rem;
  overflow: hidden;
  box-shadow: var(--shadow);
}
#guide .cost-card-head {
  background: var(--navy);
  color: var(--main-r);
  padding: 1rem 1.5rem;
  font-weight: var(--bold);
  display: flex; align-items: center; gap: 0.625rem;
}
#guide .cost-card-body { padding: 1.5rem; }
#guide .cost-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.75rem 0;
  border-bottom: 0.0625rem solid var(--gray-mid);
 
}
#guide .cost-row:last-child { border-bottom: none; }
#guide .cost-label { color: var(--gray-text); }
#guide .cost-value { font-weight: var(--bold); color: var(--navy); }
#guide .cost-note {
  margin-top: 0.75rem;
  color: var(--gray-text);
  padding: 0.625rem 0.875rem;
  background: var(--gray-bg);
  border-radius: 0.125rem;
}

/* ============================================================ 選ばれる理由 */
#guide .reason-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 0.25rem;
  transition: background 0.2s, transform 0.2s;
}
#guide .reason-first,
#guide .reason-card {
  padding: 3rem;
}
#guide .reason-card:hover { background: rgba(255,255,255,0.1); transform: translateY(-2px); }
#guide .reason-num {
  color: var(--accent);
  letter-spacing: 0.15em;
  margin-bottom: 0.75rem;
  display: block;
}
#guide .reason-title { font-weight:var(--bold); color: var(--main-r); margin-bottom: 0.625rem; }
#guide .reason-desc { color: rgba(255,255,255,0.72); line-height: 1.8; }

/* ============================================================ 施工事例 */
#guide .cases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
#guide .case-card {
  background: var(--main-r);
  border-radius: 0.25rem;
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: box-shadow 0.2s, transform 0.2s;
}
#guide .case-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-3px); }
#guide .case-img {
  height: 12.5rem;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  display: flex; align-items: center; justify-content: center;
 
  position: relative;
  overflow: hidden;
}
#guide .case-img::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,0.3));
}
#guide .case-tag {
  position: absolute; top: 0.75rem; left: 0.75rem; z-index: 1;
  background: var(--accent); color: var(--main-r);
  font-weight: var(--bold); padding: 0.1875rem 0.625rem;
  letter-spacing: 0.05em;
}
#guide .case-body { padding: 1.25rem; }
#guide .case-title { font-weight: var(--bold); color: var(--navy); margin-bottom: 0.5rem; }
#guide .case-meta { display: flex; gap: 1rem; margin-bottom: 0.625rem; }
#guide .case-meta span { color: var(--gray-text); display: flex; align-items: center; gap: 0.25rem; }
#guide .case-desc { color: var(--gray-text); line-height: 1.7; }

/* ============================================================
   services-nav｜OUR SERVICES 施工メニュー導線セクション
   BEM設計：既存サイトCSSと競合しない専用クラスのみを使用
============================================================ */

.services-nav {
  background: #f5f6f8;
}

.services-nav__inner {
  margin: 0 auto;
  text-align: center;
}

.services-nav__eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: var(--bold);
  letter-spacing: 0.22em;
  color: var(--accent);
  margin-bottom: 14px;
}

.services-nav__heading {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: var(--bold);
  line-height: 1.55;
  color: var(--main);
  margin: 0 0 24px;
}

.services-nav__divider {
  width: 48px;
  height: 3px;
  background: var(--accent);
  margin: 0 auto 32px;
  border-radius: 2px;
}

.services-nav__lead {
  font-size: 15px;
  line-height: 1.9;
  color: #5b6270;
  margin: 0 auto 10px;
}

/* ---- カードグリッド ---- */
.services-nav__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: 56px;
  text-align: left;
}

@media (min-width: 641px) {
  .services-nav__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1025px) {
  .services-nav__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }
}

/* ---- カード本体 ---- */
.services-nav__card {
  display: flex;
  flex-direction: column;
  background: #ffffff;
  border-radius: 18px;
  padding: 44px 34px;
  box-shadow: 0 4px 18px rgba(15, 35, 60, 0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.services-nav__card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 30px rgba(15, 35, 60, 0.1);
}

.services-nav__icon {
  font-size: 32px;
  line-height: 1;
  margin: 0 0 18px;
}

.services-nav__en {
  display: block;
  font-size: 11px;
  font-weight: var(--bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9aa3b1;
  margin-bottom: 10px;
}

.services-nav__title {
  font-size: 19px;
  font-weight: 700;
  color: var(--main);
  line-height: 1.5;
  margin: 0 0 16px;
}

.services-nav__text {
  font-size: 14px;
  line-height: 1.9;
  color: #5b6270;
  flex-grow: 1;
  margin: 0 0 28px;
}

.services-nav__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  align-self: flex-start;
  font-size: 14px;
  text-decoration: none;
  border-bottom: 1px solid #0f2440;
  padding-bottom: 3px;
  transition: opacity 0.2s ease;
}

.services-nav__btn:hover {
  opacity: 0.6;
}


/* ============================================================ 施工の流れ */
#guide .flow-steps {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  position: relative;
}
#guide .flow-steps::before {
  content: '';
  position: absolute;
  top: 3.25rem; left: 8%; right: 8%; height: 0.125rem;
  background: linear-gradient(90deg, var(--navy), var(--accent));
}
#guide .flow-step {
  text-align: center;
  position: relative; z-index: 1;
  padding: 0 2rem;
}
#guide .flow-circle {
  width: 6.5rem; height: 6.5rem;
  border-radius: 50%;
  background: var(--navy);
  color: var(--main-r);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  margin: 0 auto 1rem;
 
  box-shadow: var(--shadow);
  border: 3px solid var(--main-r);
  transition: background 0.2s, transform 0.2s;
}
#guide .flow-step:hover .flow-circle { background: var(--accent); transform: scale(1.08); }
#guide .flow-step-num {
font-weight: var(--bold);
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 0.125rem;
    line-height: 1;
}
#guide .flow-label { font-weight: var(--bold); color: var(--navy); margin-bottom: 0.25rem; }
#guide .flow-desc { color: var(--gray-text); line-height: 1.6; }

/* ============================================================ 安心保証 */
#guide .guarantee-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
#guide .guarantee-card {
  background: var(--main-r);
  border-radius: 0.25rem;
  padding: 2.5rem 2.25rem;
  box-shadow: var(--shadow);
  text-align: center;
  border-bottom: 0.25rem solid var(--navy);
  transition: border-color 0.2s;
}
#guide .guarantee-card:hover { border-color: var(--accent); }
#guide .guarantee-badge {
  width: 7.25rem; height: 7.25rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--navy), var(--navy-light));
  color: var(--main-r);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  margin: 0 auto 1.25rem;
  font-weight: var(--bold);
  line-height: 1.3;
  box-shadow: var(--shadow);
}
#guide .guarantee-badge p{
	color:var(--main-r);
		}
#guide .guarantee-badge .big { font-weight: var(--bold); color: var(--accent); }
#guide .guarantee-title { font-weight: var(--bold); color: var(--navy); margin-bottom: 0.75rem; }
#guide .guarantee-desc { color: var(--gray-text); line-height: 1.85; }

/* ============================================================ FAQ */


/* ---------- 1024px以下：タブレット ---------- */
@media (max-width: 1024px) {
 
  #guide .worry-card { width: calc(50% - 1rem); }
 
  #guide .risk-flow {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 2.5rem;
  }
  #guide .risk-flow::before { display: none; }
 
  #guide .cases-grid { grid-template-columns: repeat(2, 1fr); }
 
  #guide .flow-steps {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 3rem;
  }
  #guide .flow-steps::before { display: none; }
  #guide .flow-step { padding: 0 1rem; }
}
 
/* ---------- 768px以下：タブレット縦／大きめスマホ ---------- */
@media (max-width: 768px) {
 
  #guide .section-lead { margin-bottom: 2rem; }
 
  #guide .cost-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  #guide .guarantee-grid { grid-template-columns: 1fr; gap: 1.5rem; }
 
  #guide .reason-first,
  #guide .reason-card { padding: 2rem; }
 
  #guide .case-img { height: 10rem; }

.services-nav__card{
    padding: 3rem;
	}

.services-nav__main{
	display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 2rem;
	}
}
 
/* ---------- 600px以下：スマートフォン ---------- */
@media (max-width: 600px) {
 
  #guide .worries-grid { gap: 1.25rem; }
  #guide .worry-card { width: 100%; }
 
  #guide .risk-flow { grid-template-columns: 1fr; row-gap: 2rem; }
  #guide .risk-item:not(:last-child)::after {
    content: '↓';
    display: block;
    margin-top: 0.5rem;
    color: var(--accent);
    font-weight: var(--bold);
  }
 
  #guide .cases-grid { grid-template-columns: 1fr; }
 
  #guide .flow-steps { grid-template-columns: 1fr; row-gap: 2.5rem; }
  #guide .flow-step { padding: 0 1rem; }
  #guide .flow-step:not(:last-child)::after {
    content: '↓';
    display: block;
    margin-top: 0.5rem;
    color: var(--accent);
    font-weight: var(--bold);
  }

#guide .sign-title {
    font-size: 15px;
}
}
 
/* ---------- 480px以下：小型スマートフォン ---------- */
@media (max-width: 480px) {
 
  #guide .reason-first,
  #guide .reason-card { padding: 1.5rem; }
 
  #guide .cost-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }

 
  #guide .guarantee-card { padding: 2rem 1.5rem; }
  #guide .case-body { padding: 1rem; }
}