/* =========================================================
   Pros-MILOC Service Template (Minimal / Spacious)
   File: custom-pros-miloc.css
   Scope: .page-pros-miloc only
========================================================= */

.page-pros-miloc{
  /* ProsWork strategy-plan系に寄せたトーン */
  --pm-text: #1f2937;
  --pm-sub: #4b5563;
  --pm-line: rgba(31,41,55,.14);
  --pm-blue: #0B7CC2;
  --pm-blue2: #18A6D8;
  --pm-orange:#F6A623;

  --pm-bg: #F6F8FB;          /* ページ背景：ごく薄いグレー */
  --pm-card: #ffffff;        /* カード背景 */
  --pm-radius: 12px;
  --pm-shadow: 0 10px 22px rgba(2,6,23,.06); /* 控えめ */
  --pm-shadow-hover: 0 14px 30px rgba(2,6,23,.08);

  color: var(--pm-text);
  background: var(--pm-bg);
}

/* =========================================================
   Layout
========================================================= */
.page-pros-miloc .pm-container{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px 24px;
}

.page-pros-miloc .pm-section{
  padding: 56px 0;
  border-top: 1px solid var(--pm-line);
}

.page-pros-miloc .pm-section-last{
  border-bottom: 1px solid var(--pm-line);
}

/* アンカー飛び先がヘッダーに隠れにくい */
.page-pros-miloc [id]{
  scroll-margin-top: 96px;
}

/* =========================================================
   Typography (English headings / Japanese sub)
========================================================= */
.page-pros-miloc .pm-kicker{
  margin: 0 0 10px;
  color: var(--pm-blue);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.page-pros-miloc .pm-hero-title{
  margin: 0 0 12px;
  font-size: clamp(26px, 2.5vw, 40px);
  line-height: 1.22;
  font-weight: 900;
  letter-spacing: .01em;
}

.page-pros-miloc .pm-hero-lead{
  margin: 0 0 18px;
  color: var(--pm-sub);
  line-height: 1.95;
  font-size: 15px;
}

.page-pros-miloc .pm-section-title{
  margin: 0 0 6px;
  color: var(--pm-blue);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 20px;
}

.page-pros-miloc .pm-section-sub{
  margin: 0 0 18px;
  color: var(--pm-sub);
  font-weight: 700;
  font-size: 14px;
  line-height: 1.7;
}

/* 見出しの下に“短い青ライン”を出す（参照ページ風） */
.page-pros-miloc .pm-section-title::after{
  content: "";
  display: block;
  width: 56px;
  height: 2px;
  margin-top: 10px;
  background: linear-gradient(90deg, var(--pm-blue), var(--pm-blue2));
  border-radius: 999px;
  opacity: .95;
}

.page-pros-miloc .pm-text{
  color: var(--pm-sub);
  line-height: 1.95;
  font-size: 14px;
}

.page-pros-miloc .pm-note{
  margin-top: 12px;
  font-size: 13px;
  color: var(--pm-sub);
}

/* =========================================================
   Cards (thin border + subtle shadow)
========================================================= */
.page-pros-miloc .pm-card{
  background: var(--pm-card);
  border: 1px solid var(--pm-line);
  border-radius: var(--pm-radius);
  box-shadow: var(--pm-shadow);
}

.page-pros-miloc .pm-card:hover{
  box-shadow: var(--pm-shadow-hover);
}

.page-pros-miloc .pm-card-title{
  font-weight: 900;
  margin: 0 0 10px;
  font-size: 15px;
  letter-spacing: .01em;
}

.page-pros-miloc .pm-list{
  margin: 8px 0 0;
  padding-left: 1.2em;
  color: var(--pm-sub);
  line-height: 1.95;
  font-size: 14px;
}

.page-pros-miloc .pm-list-compact{
  margin-top: 6px;
  line-height: 1.8;
}

/* =========================================================
   Hero
========================================================= */
.page-pros-miloc .pm-hero{
  padding: 40px 0 12px;
  border-top: none;
}

.page-pros-miloc .pm-hero-grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items: start;
}

.page-pros-miloc .pm-hero-points{
  margin: 14px 0 0;
  padding-left: 1.2em;
  color: var(--pm-sub);
  line-height: 1.9;
  font-size: 14px;
}

.page-pros-miloc .pm-hero-panel{
  overflow: hidden;
}

.page-pros-miloc .pm-hero-figure{
  margin: 0;
}

.page-pros-miloc .pm-hero-figure img{
  width: 100%;
  height: auto;
  display: block;
}

.page-pros-miloc .pm-panel-body{
  padding: 16px 16px 18px;
}

.page-pros-miloc .pm-panel-title{
  font-weight: 900;
  margin: 0 0 8px;
  color: var(--pm-text);
}

.page-pros-miloc .pm-panel-list{
  margin: 8px 0 0;
  padding-left: 1.2em;
  color: var(--pm-sub);
  line-height: 1.9;
  font-size: 14px;
}

.page-pros-miloc .pm-panel-cta{
  margin-top: 14px;
}

/* =========================================================
   Buttons (ProsWorkっぽく：オレンジアウトライン主体)
========================================================= */
.page-pros-miloc .pm-row{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.page-pros-miloc .pm-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: 10px;
  font-weight: 900;
  text-decoration: none;
  transition: background .15s ease, transform .12s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease;
  line-height: 1;
}

.page-pros-miloc .pm-btn:hover{
  transform: translateY(-1px);
}

/* メインCTA：アウトライン（参照ページの雰囲気） */
.page-pros-miloc .pm-btn-primary{
  background: transparent;
  color: var(--pm-orange);
  border: 2px solid var(--pm-orange);
  box-shadow: none;
}

.page-pros-miloc .pm-btn-primary:hover{
  background: rgba(246,166,35,.10);
}

/* サブCTA：薄いグレー背景 */
.page-pros-miloc .pm-btn-ghost{
  background: #fff;
  color: var(--pm-blue);
  border: 1px solid var(--pm-line);
}

.page-pros-miloc .pm-btn-ghost:hover{
  background: rgba(11,124,194,.06);
  border-color: rgba(11,124,194,.20);
}

.page-pros-miloc .pm-arrow{
  font-weight: 900;
}

/* フォーカス可視化（アクセシビリティ） */
.page-pros-miloc a:focus-visible{
  outline: 3px solid rgba(11,124,194,.35);
  outline-offset: 2px;
  border-radius: 10px;
}

/* =========================================================
   Badges / Steps (薄いブルーのピル)
========================================================= */
.page-pros-miloc .pm-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.page-pros-miloc .pm-badge{
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,124,194,.22);
  background: rgba(11,124,194,.08);
  color: var(--pm-blue);
  font-size: 12px;
  font-weight: 800;
}

/* =========================================================
   Grids
========================================================= */
.page-pros-miloc .pm-grid-3{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.page-pros-miloc .pm-grid-3 > .pm-card{
  padding: 18px;
}

.page-pros-miloc .pm-flow{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.page-pros-miloc .pm-flow-card{
  padding: 18px;
}

.page-pros-miloc .pm-step{
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,124,194,.22);
  background: rgba(11,124,194,.08);
  color: var(--pm-blue);
  font-weight: 900;
  font-size: 12px;
  margin-bottom: 12px;
}

/* =========================================================
   Highlight block（薄い強調：やりすぎない）
========================================================= */
.page-pros-miloc .pm-highlight{
  background: linear-gradient(180deg, #fff, #fff);
  border-color: rgba(246,166,35,.22);
}

.page-pros-miloc .pm-highlight-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  padding: 18px;
}

/* CTA Center */
.page-pros-miloc .pm-cta-center{
  margin-top: 18px;
  display: flex;
  justify-content: center;
}

/* =========================================================
   FAQ (details) - minimal accordion
========================================================= */
.page-pros-miloc .pm-faq{
  display: grid;
  gap: 10px;
  margin-top: 8px;
}

.page-pros-miloc .pm-faq-item{
  border: 1px solid var(--pm-line);
  border-radius: var(--pm-radius);
  background: #fff;
  box-shadow: none; /* FAQはよりミニマルに */
  overflow: hidden;
}

.page-pros-miloc .pm-faq-item summary{
  cursor: pointer;
  padding: 14px 16px;
  font-weight: 900;
  list-style: none;
  position: relative;
}

.page-pros-miloc .pm-faq-item summary::-webkit-details-marker{
  display: none;
}

/* + / - っぽいUI（参照ページの“整理されたFAQ”感） */
.page-pros-miloc .pm-faq-item summary::after{
  content: "+";
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--pm-blue);
  font-weight: 900;
}

.page-pros-miloc .pm-faq-item[open] summary::after{
  content: "–";
}

.page-pros-miloc .pm-faq-body{
  padding: 0 16px 16px;
}

/* =========================================================
   Responsive
========================================================= */
@media (max-width: 980px){
  .page-pros-miloc .pm-section{
    padding: 44px 0;
  }
  .page-pros-miloc .pm-hero-grid{
    grid-template-columns: 1fr;
  }
  .page-pros-miloc .pm-grid-3,
  .page-pros-miloc .pm-flow{
    grid-template-columns: 1fr;
  }
  .page-pros-miloc .pm-highlight-grid{
    grid-template-columns: 1fr;
  }
}