/* ===================================================================
   ecoledefx.xyz Design Tokens
   FX会社詳細ページ共通トークン
   Based on ecoledefx.xyz visual language
   =================================================================== */

:root {
  /* ---------- Brand Colors (ecoledefx base) ---------- */
  --ex-ink: #1a1f2e;              /* 見出し色（濃紺） */
  --ex-ink-2: #2c3444;            /* 本文 */
  --ex-muted: #5b6578;            /* キャプション */
  --ex-line: #e5e8ef;             /* 罫線 */
  --ex-line-soft: #f1f3f7;
  --ex-bg: #ffffff;
  --ex-bg-soft: #f8f9fb;          /* セクション交互背景 */
  --ex-bg-warm: #fdfbf5;          /* 温かみ背景（ヒーロー補助） */

  /* ---------- ecoledefx accent ---------- */
  --ex-blue: #1e5aa8;             /* メインアクセント（ecoledefx系） */
  --ex-blue-deep: #143d75;
  --ex-blue-soft: #e8f0fb;
  --ex-crown: #d4a72c;            /* 👑 バッジ用ゴールド */
  --ex-crown-deep: #a47e15;
  --ex-good: #1f8a5c;             /* ◎ */
  --ex-warn: #c9630b;             /* △ */
  --ex-bad: #b53131;
  --ex-pr: #e76d2f;               /* PRタグ */

  /* ---------- FX会社固有カラー（外為どっとコム） ---------- */
  /* テンプレート化のため、会社ごとに上書き可 */
  --co-primary: #c8102e;          /* 外為どっとコム バーガンディレッド */
  --co-primary-deep: #8b0000;
  --co-primary-soft: #fceff1;
  --co-accent: #1a3a6e;           /* ディープブルー(サブ) */
  --co-tint: #fff8f0;             /* ヒーロー背景用 */

  /* ---------- Typography ---------- */
  --ex-font-sans: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Yu Gothic Medium", "Meiryo", sans-serif;
  --ex-font-serif: "Hiragino Mincho ProN", "Yu Mincho", "Noto Serif JP", serif;
  --ex-font-num: "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* Sizes — デスクトップ基準 */
  --ex-fs-hero: clamp(28px, 4.2vw, 48px);
  --ex-fs-h2: clamp(22px, 2.6vw, 32px);
  --ex-fs-h3: clamp(18px, 1.8vw, 22px);
  --ex-fs-lead: clamp(15px, 1.3vw, 17px);
  --ex-fs-body: 15px;
  --ex-fs-small: 13px;
  --ex-fs-xs: 12px;

  /* Spacing */
  --ex-sp-1: 4px;
  --ex-sp-2: 8px;
  --ex-sp-3: 12px;
  --ex-sp-4: 16px;
  --ex-sp-5: 24px;
  --ex-sp-6: 32px;
  --ex-sp-7: 48px;
  --ex-sp-8: 64px;
  --ex-sp-9: 96px;

  /* Radius */
  --ex-r-sm: 4px;
  --ex-r-md: 8px;
  --ex-r-lg: 14px;
  --ex-r-xl: 20px;

  /* Shadow */
  --ex-sh-sm: 0 1px 2px rgba(26, 31, 46, 0.06);
  --ex-sh-md: 0 4px 14px rgba(26, 31, 46, 0.08);
  --ex-sh-lg: 0 12px 32px rgba(26, 31, 46, 0.10);

  /* Content width */
  --ex-max: 1080px;
  --ex-max-narrow: 820px;
}

/* ---------- Reset-ish ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--ex-font-sans);
  font-size: var(--ex-fs-body);
  line-height: 1.75;
  color: var(--ex-ink-2);
  background: var(--ex-bg);
  font-feature-settings: "palt";
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ex-blue); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { color: var(--ex-ink); line-height: 1.35; font-weight: 700; letter-spacing: 0.01em; }
p { margin: 0 0 1em; text-wrap: pretty; }

/* ---------- Utilities ---------- */
.ex-container { max-width: var(--ex-max); margin-inline: auto; padding-inline: 20px; }
.ex-narrow { max-width: var(--ex-max-narrow); margin-inline: auto; padding-inline: 20px; }

.ex-section { padding-block: var(--ex-sp-8); }
.ex-section--alt { background: var(--ex-bg-soft); }
.ex-section--tint { background: var(--co-tint); }

@media (max-width: 720px) {
  .ex-section { padding-block: var(--ex-sp-7); }
}

/* ---------- Section header ---------- */
.ex-sec-head { margin-bottom: var(--ex-sp-6); }
.ex-sec-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--ex-fs-small);
  color: var(--co-primary);
  letter-spacing: 0.12em;
  font-weight: 700;
  margin-bottom: 6px;
}
.ex-sec-kicker::before { content: ""; width: 24px; height: 1px; background: var(--co-primary); }
.ex-sec-title {
  font-size: var(--ex-fs-h2);
  margin: 0 0 8px;
}
.ex-sec-lead { color: var(--ex-muted); font-size: var(--ex-fs-lead); margin: 0; }

/* ---------- CTA button ---------- */
.ex-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 28px;
  font-size: 16px;
  font-weight: 700;
  background: linear-gradient(180deg, #e85a6b 0%, var(--co-primary) 100%);
  color: #fff !important;
  border-radius: 999px;
  text-decoration: none !important;
  box-shadow: 0 6px 18px rgba(200, 16, 46, 0.28), inset 0 1px 0 rgba(255,255,255,0.25);
  transition: transform .15s ease, box-shadow .15s ease;
  border: none;
  cursor: pointer;
  min-height: 56px;
  letter-spacing: 0.02em;
}
.ex-cta:hover { transform: translateY(-1px); box-shadow: 0 10px 26px rgba(200, 16, 46, 0.35); }
.ex-cta:active { transform: translateY(0); }
.ex-cta--ghost {
  background: #fff;
  color: var(--co-primary) !important;
  border: 2px solid var(--co-primary);
  box-shadow: none;
}
.ex-cta--lg { padding: 20px 36px; font-size: 17px; min-height: 64px; }

/* ---------- Badges ---------- */
.ex-badge-crown {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px;
  background: linear-gradient(180deg, #f5d25f 0%, var(--ex-crown) 100%);
  color: #5a420a;
  font-size: var(--ex-fs-small); font-weight: 700;
  border-radius: 999px;
  border: 1px solid var(--ex-crown-deep);
}
.ex-badge-pr {
  display: inline-block; font-size: 11px;
  background: var(--ex-pr); color: #fff;
  padding: 1px 6px; border-radius: 3px; font-weight: 700;
  letter-spacing: 0.05em;
}
.ex-badge-tag {
  display: inline-block; font-size: 11px;
  background: var(--ex-blue-soft); color: var(--ex-blue-deep);
  padding: 2px 8px; border-radius: 3px; font-weight: 600;
}

/* ---------- Card ---------- */
.ex-card {
  background: #fff;
  border: 1px solid var(--ex-line);
  border-radius: var(--ex-r-lg);
  padding: var(--ex-sp-5);
}
.ex-card--lift { box-shadow: var(--ex-sh-md); border-color: transparent; }

/* ---------- Spec stat (ecoledefx style: 0.2銭 etc.) ---------- */
.ex-stat { display: flex; flex-direction: column; gap: 2px; }
.ex-stat__label { font-size: var(--ex-fs-xs); color: var(--ex-muted); }
.ex-stat__val {
  font-family: var(--ex-font-num);
  font-size: 28px; font-weight: 700; color: var(--ex-ink);
  line-height: 1;
}
.ex-stat__unit {
  font-size: 12px; font-style: italic; color: var(--ex-muted);
  font-weight: 600; margin-left: 2px;
}

/* ---------- Star rating ---------- */
.ex-stars { color: var(--ex-crown); font-size: 18px; letter-spacing: 1px; }
.ex-stars--sm { font-size: 14px; }

/* ---------- Divider ---------- */
.ex-div { height: 1px; background: var(--ex-line); margin: var(--ex-sp-6) 0; border: 0; }

/* ---------- Print-like note box ---------- */
.ex-note {
  background: var(--ex-bg-soft);
  border-left: 3px solid var(--ex-blue);
  padding: 12px 16px;
  font-size: var(--ex-fs-small);
  color: var(--ex-muted);
  border-radius: 0 var(--ex-r-md) var(--ex-r-md) 0;
}

/* ---------- Reveal on scroll (optional) ---------- */
.ex-reveal { opacity: 0; transform: translateY(12px); transition: opacity .5s ease, transform .5s ease; }
.ex-reveal.is-in { opacity: 1; transform: translateY(0); }
