/* assets/css/base.css : shared utilities (SAITOWORKS)
   Brand base color: #ffd400
   - カラースケール + セマンティックトークンを追加
   - 既存の --ink / --surface / --line / --tint / --accent も互換維持
   - 共通リセット/可読性/安全領域/横はみ出し対策/アンカー余白 追加
*/

/* =========================
   Light Theme (default)
   ========================= */
:root{
  color-scheme: light;

  /* Brand (Yellow) scale */
  --brand-50:  #FFFBE6;
  --brand-100: #FFF7CC;
  --brand-200: #FFF0A3;
  --brand-300: #FFE775;
  --brand-400: #FFDE47;
  --brand-500: #FFD400; /* main */
  --brand-600: #E6BF00;
  --brand-700: #C9A500;
  --brand-800: #9E8000;
  --brand-900: #6E5900;

  /* Neutral (Slate-like) */
  --gray-50:  #F8FAFC;
  --gray-100: #F1F5F9;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E1;
  --gray-400: #94A3B8;
  --gray-500: #64748B;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-800: #1F2937;
  --gray-900: #0F172A;

  /* Accents (brandと相性の良い補助色) */
  --violet-600:#7C3AED; --violet-700:#6D28D9; --violet-50:#F5F3FF;
  --blue-600:  #2563EB; --blue-700:  #1D4ED8;  --blue-50:  #EFF6FF;
  --teal-600:  #0D9488; --teal-700:  #0F766E;  --teal-50:  #F0FDFA;

  /* Status */
  --success-50:#ECFDF5; --success-700:#15803D;
  --warning-50:#FFFBEB; --warning-700:#B45309;
  --danger-50: #FEF2F2; --danger-700:#B91C1C;
  --info-50:   #EFF6FF; --info-700:  #1D4ED8;

  /* ===== Semantic tokens ===== */
  --swx-main: var(--brand-500); /* 既存CSSとの互換 */

  /* Base text/bg */
  --text:       var(--gray-900);
  --text-muted: var(--gray-600);
  --bg:         #fff;
  --surface:    #fff;
  --surface-2:  var(--gray-50);
  --border:     var(--gray-200);
  --ring:       var(--brand-400);

  /* 既存変数（互換） */
  --ink:   var(--text);
  --ink-2: var(--text-muted);
  --line:  var(--border);
  --tint:  var(--brand-50);
  --accent: var(--brand-600);

  /* Buttons / Links */
  --btn-primary-bg:   var(--brand-500);
  --btn-primary-fg:   #111;                 /* Yellow上の可読色 */
  --btn-primary-hov:  var(--brand-600);

  --btn-secondary-bg: var(--gray-900);
  --btn-secondary-fg: #fff;
  --btn-secondary-hov:var(--gray-800);

  --link:       var(--blue-600);
  --link-hover: var(--blue-700);

  /* Soft surfaces */
  --surface-brand-soft:  var(--brand-100);
  --surface-info-soft:   var(--info-50);
  --surface-success-soft:var(--success-50);
  --surface-warning-soft:var(--warning-50);
  --surface-danger-soft: var(--danger-50);

  /* Component tokens */
  --option-card-bg: var(--surface-brand-soft);

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(15,23,42,.06);
  --shadow-md: 0 6px 18px rgba(15,23,42,.08);
  --shadow-lg: 0 12px 28px rgba(15,23,42,.12);

  /* === 共通レイアウトトークン（全ページ） === */
  --sec-pad-y: clamp(56px, 7vw, 96px);        /* セクション上下 */
  --pad-x:     clamp(12px, 3.2vw, 20px);      /* コンテナ左右 */
  --anchor-offset: 72px;                      /* 固定ヘッダー分のアンカー余白 */
}

/* =========================
   Dark Theme
   data-theme="dark" で有効
   ========================= */
[data-theme="dark"], .theme-dark{
  color-scheme: dark;

  --text:       #E5E7EB;
  --text-muted: #A3A3A3;
  --bg:         #0B0F1A;
  --surface:    #121A2A;
  --surface-2:  #0F1626;
  --border:     #1F2A3A;
  --ring:       var(--brand-400);

  --ink:   var(--text);
  --ink-2: var(--text-muted);
  --line:  var(--border);
  --tint:  #1A1A0A;
  --accent: var(--brand-400);

  --btn-primary-bg:  var(--brand-400);
  --btn-primary-fg:  #111;
  --btn-primary-hov: var(--brand-500);

  --btn-secondary-bg:#1F2937;
  --btn-secondary-fg:#fff;
  --btn-secondary-hov:#273042;

  --link:       #60A5FA;
  --link-hover: #93C5FD;

  --surface-brand-soft:#1A1A0A;
  --option-card-bg:    #1A1A0A;
}

/* =========================
   Base Reset & Typography
   ========================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html, body{ background:var(--bg); color:var(--ink); }
body{
  font:16px/1.8 system-ui, -apple-system, "Segoe UI", Roboto, "Hiragino Sans", "Noto Sans JP", sans-serif;
  text-wrap: pretty;
}
:where(h1,h2,h3){ line-height:1.25; text-wrap: balance; }
img,svg,video,canvas{ display:block; max-width:100%; height:auto; }

a{ color:var(--link); text-decoration:none; }
a:hover{ color:var(--link-hover); text-decoration:underline; }
::selection{ background:var(--brand-300); color:#111; }
:focus-visible{ outline:3px solid var(--ring); outline-offset:2px; }

/* 動きの配慮（ユーザー設定を尊重） */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}

/* =========================
   Spacing & Container
   ========================= */
.swx-section{ padding-block: var(--sec-pad-y); } /* ← 固定値からトークン運用に統一 */
.swx-container{
  padding-left:  var(--pad-x);
  padding-right: var(--pad-x);
  margin-left: auto;
  margin-right: auto;
  max-width: 1120px;
}
.swx-sec-title{
  font-size: clamp(20px,2.2vw,28px);
  font-weight:700; line-height:1.3; margin:0 0 1.25em;
}

/* セクション余白バリエーション（任意） */
.swx-section.-tight { --sec-pad-y: clamp(40px, 5vw, 72px); }
.swx-section.-loose { --sec-pad-y: clamp(72px, 9vw, 128px); }
.swx-section.-flush { --sec-pad-y: 0px; }

/* =========================
   Grid
   ========================= */
.swx-grid{ display:grid; gap:clamp(16px,2vw,28px); }
.grid-3{ grid-template-columns:1fr; }
.grid-2{ grid-template-columns:1fr; }
@media(min-width:720px){
  .grid-2{ grid-template-columns:repeat(2,1fr); }
  .grid-3{ grid-template-columns:repeat(2,1fr); }
}
@media(min-width:1024px){
  .grid-3{ grid-template-columns:repeat(3,1fr); }
}

/* =========================
   Card
   ========================= */
.card{
  border-radius:16px;
  padding:clamp(16px,2vw,24px);
  background:var(--surface);
  box-shadow: var(--shadow-md);
  border:1px solid var(--line);
}
.card-title{ font-size: clamp(16px,1.6vw,20px); font-weight:700; margin:0 0 .4em; }
.card-text{ margin:0; color:var(--ink-2); }

/* icon block */
.card-icon{
  width:48px; height:48px;
  display:grid; place-items:center;
  border-radius:12px;
  margin-bottom:12px;
  background:var(--tint);
  color:var(--accent);
}

/* kicker */
.kicker{
  display:inline-block; font-size:12px; letter-spacing:.08em; font-weight:700;
  padding:4px 8px; border-radius:999px; background:var(--tint); margin:0 0 .5em;
}

/* =========================
   Buttons & Badges
   ========================= */
.swx-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:12px; font-weight:700; text-decoration:none;
  border:1px solid transparent; box-shadow: var(--shadow-sm);
}
.swx-btn.primary{ background:var(--btn-primary-bg); color:var(--btn-primary-fg); }
.swx-btn.primary:hover{ background:var(--btn-primary-hov); }
.swx-btn.secondary{ background:var(--btn-secondary-bg); color:var(--btn-secondary-fg); }
.swx-btn.secondary:hover{ background:var(--btn-secondary-hov); }

/* badges (example) */
.badge{ padding:2px 8px; border-radius:999px; font-size:12px; }
.badge.-success{ background:var(--surface-success-soft); color:var(--success-700); border:1px solid rgba(22,163,74,.18); }
.badge.-warning{ background:var(--surface-warning-soft); color:var(--warning-700); border:1px solid rgba(217,119,6,.24); }
.badge.-danger{  background:var(--surface-danger-soft);  color:var(--danger-700);  border:1px solid rgba(220,38,38,.22); }
.badge.-info{    background:var(--surface-info-soft);    color:var(--info-700);    border:1px solid rgba(37,99,235,.22); }

/* ===== Buttons: mobile overflow guard (横はみ出しの予防線) ===== */
/* 汎用 .btn と .swx-btn の双方をケア */
.btn, a.btn, button.btn,
.swx-btn{
  box-sizing: border-box;
  max-width: 100%;
}
.btn > *, .swx-btn > *{ min-width: 0; }
@media (max-width: 767.98px){
  .btn, a.btn, button.btn, .swx-btn{
    white-space: normal;
    overflow-wrap: anywhere;
  }
}
.btn.-block, .swx-btn.-block{ display:block; width:100%; }

/* =========================
   Reveal (safe by default)
   ========================= */
.js-reveal{ opacity:1; transform:none; }
.has-io .js-reveal{
  opacity:0;
  transform:translateY(10px);
  transition: opacity .45s ease, transform .45s ease;
  transition-delay:var(--reveal-delay,0ms);
}
.has-io .js-reveal.is-in{ opacity:1; transform:none; }

/* =========================
   Utilities (全ページ共通)
   ========================= */
/* ビューポート高の安全な充填（モバイルの100vh問題に対応） */
.u-fill-screen{ min-height:100svh; min-height:100vh; }

/* ヒーロー等の装飾はみ出しを局所的にカット（グローバルでは隠さない） */
.u-clip-x{ overflow-x: clip; position: relative; }

/* 固定ヘッダー分のアンカー余白（#id スクロール時の被り防止） */
[id]{ scroll-margin-top: var(--anchor-offset); }

/* iOSノッチの安全領域（必要なラッパーに付与） */
.pad-safe-x{
  padding-left:  max(var(--pad-x), env(safe-area-inset-left));
  padding-right: max(var(--pad-x), env(safe-area-inset-right));
}

/* アクセシビリティ：画面外テキスト（スクリーンリーダー専用） */
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); clip-path: inset(50%); white-space:nowrap; border:0;
}

/* =========================
   Hero helpers（横だけ既定に合わせる）
   ========================= */
.swx-hero .inner,
.swx-hero.-services .inner{
  padding-left:  var(--pad-x);
  padding-right: var(--pad-x);
  /* 上下は各ヒーロー側で調整 */
}
/* ===== Breadcrumb UI ===== */
.swx-breadcrumb{
  font-size: 0.95rem;
  margin: 1.5rem 0;
  color: var(--muted, #666);
}
.swx-breadcrumb ol{
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: .4em;
  padding: 0; margin: 0;
}
.swx-breadcrumb li::after{
  content: '›';
  margin-left: .4em;
  color: var(--line, #999);
}
.swx-breadcrumb li:last-child::after{ content: none; }
.swx-breadcrumb a{
  color: var(--brand-600, #E6BF00);
  text-decoration: none;
}
.swx-breadcrumb a:hover{ text-decoration: underline; }
/* =========================
   Breadcrumb UI – 完全版
   ========================= */
.swx-breadcrumb{
  /* 見た目（淡背景・角丸ピル） */
  background: var(--brand-50, #FFFBE6);
  border: 1px solid var(--brand-100, #FFF7CC);
  border-radius: 9999px;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);

  /* 余白・文字 */
  padding: .55rem .95rem;
  color: var(--muted, #666);
  font-size: .95rem;
  line-height: 1.2;

  /* ボックス幅を中身にフィットさせつつ端に寄らない */
  display: inline-flex;
  width: fit-content;
  max-width: calc(100% - clamp(24px, 8vw, 48px));
  margin: 16px clamp(12px, 4vw, 24px) 24px;
}

.swx-breadcrumb ol{
  list-style: none;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45em;
  padding: 0;
  margin: 0;
}

/* 区切り矢印（視認性UP） */
.swx-breadcrumb li::after{
  content: '›';
  margin: 0 .5em 0 .6em;
  font-weight: 700;                 /* 太く */
  font-size: 1.1em;                 /* 少し大きく */
  color: var(--brand-700, #B38F00); /* 濃いめの黄系 */
  opacity: .95;
  transform: translateY(-.5px);
}
.swx-breadcrumb li:last-child::after{ content: none; }

/* リンク/現在地 */
.swx-breadcrumb a{
  color: var(--brand-800, #8A6A00);
  text-decoration: none;
}
.swx-breadcrumb a:hover{ text-decoration: underline; }

.swx-breadcrumb [aria-current="page"]{
  color: var(--ink, #333);
  font-weight: 600;
  white-space: nowrap;              /* 末尾は折返しにくく */
}

/* モバイル微調整 */
@media (max-width: 640px){
  .swx-breadcrumb{
    padding: .5rem .8rem;
    font-size: .92rem;
    margin: 12px clamp(10px, 5vw, 20px) 16px;
  }
}

/* （任意）ヒーローと同じ幅に揃えたい場合は以下を有効化
.swx-breadcrumb-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 24px);
}
*/
