/* ===================================================================
 * DADS Components — Phase 1.5.0 配備版
 *
 * 全 component は .dads-* prefix で scope 化。
 * primitive は dads-primitive.css、semantic は dads-semantic.css を参照。
 * 詳細仕様: docs/phase1.5/plan.md §4
 *
 * 1.5.0 時点ではこのファイルが load されても class 未適用のため
 * 既存 HTML の見た目には影響なし。1.5.1〜1.5.5 で順次 class 化。
 * =================================================================== */

/* ===== Container ================================================== */
.dads-container {
  max-width: var(--cw-xl);
  margin-inline: auto;
  padding-inline: var(--sp-4);
}
.dads-container--lg { max-width: var(--cw-lg); }
.dads-container--md { max-width: var(--cw-md); }
.dads-container--sm { max-width: var(--cw-sm); }
@media (min-width: 768px) {
  .dads-container { padding-inline: var(--sp-5); }
}

/* ===== Page Header ================================================ */
.dads-page-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  align-items: flex-end;
  justify-content: space-between;
  padding-block: var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--c-border-subtle);
  margin-bottom: var(--sp-5);
}
.dads-page-header__title { font: var(--t-h1); }
.dads-page-header__subtitle { font: var(--t-body-sm); color: var(--c-text-muted); margin-top: var(--sp-1); }
.dads-page-header__actions { display: flex; gap: var(--sp-2); }

/* ===== Top Nav ==================================================== */
.dads-topnav {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  height: 56px;
  padding-inline: var(--sp-4);
  background: var(--c-bg-surface);
  border-bottom: 1px solid var(--c-border-subtle);
  position: sticky; top: 0; z-index: var(--z-fixed);
}
.dads-topnav__brand {
  font: var(--t-h4);
  color: var(--c-text-strong);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.dads-topnav__menu {
  display: flex; gap: var(--sp-3); list-style: none; padding: 0; margin: 0;
}
.dads-topnav__link {
  display: inline-flex; align-items: center;
  height: 40px; padding-inline: var(--sp-3);
  font: var(--t-body-sm); font-weight: 500;
  color: var(--c-text-body); text-decoration: none;
  border-radius: var(--border-radius-6);
}
.dads-topnav__link:hover { background: var(--c-brand-tint); color: var(--c-text-link); }
.dads-topnav__link--current {
  color: var(--c-text-link);
  box-shadow: inset 0 -2px 0 var(--c-brand);
  border-radius: 0;
}
.dads-topnav__user {
  margin-inline-start: auto;
  display: flex; gap: var(--sp-2); align-items: center;
  font: var(--t-body-sm); color: var(--c-text-muted);
}

/* ===== Button ===================================================== */
.dads-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-2);
  height: var(--h-control);
  padding-inline: var(--sp-4);
  font: var(--t-body); font-weight: 700;
  border: 1px solid transparent;
  border-radius: var(--border-radius-6);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--motion-fast) var(--motion-ease),
              color    var(--motion-fast) var(--motion-ease),
              box-shadow var(--motion-fast) var(--motion-ease);
  user-select: none;
}
.dads-btn--sm { height: var(--h-control-sm); padding-inline: var(--sp-3); font-size: var(--font-size-14); }
.dads-btn--lg { height: var(--h-control-lg); padding-inline: var(--sp-5); font-size: var(--font-size-18); }
.dads-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.dads-btn:disabled, .dads-btn[aria-disabled="true"] { opacity: 0.4; cursor: not-allowed; }

/* primary */
.dads-btn--primary {
  background: var(--c-brand); color: var(--c-text-on-fill);
  border-color: var(--c-brand);
}
.dads-btn--primary:hover:not(:disabled) { background: var(--c-brand-hover); border-color: var(--c-brand-hover); }
.dads-btn--primary:active:not(:disabled) { background: var(--c-brand-active); }

/* secondary (outlined) */
.dads-btn--secondary {
  background: var(--c-bg-surface); color: var(--c-brand);
  border-color: var(--c-border);
}
.dads-btn--secondary:hover:not(:disabled) { background: var(--c-brand-tint); border-color: var(--c-brand); }

/* tertiary (text) */
.dads-btn--tertiary {
  background: transparent; color: var(--c-brand); border: 0; padding-inline: var(--sp-3);
}
.dads-btn--tertiary:hover:not(:disabled) { background: var(--c-brand-tint); }

/* danger */
.dads-btn--danger {
  background: var(--c-error); color: var(--c-text-on-fill); border-color: var(--c-error);
}
.dads-btn--danger:hover:not(:disabled) { background: var(--color-primitive-red-900); border-color: var(--color-primitive-red-900); }

/* loading state */
.dads-btn[aria-busy="true"]::after {
  content: ""; width: 16px; height: 16px;
  border: 2px solid currentColor; border-right-color: transparent;
  border-radius: 50%;
  animation: dads-spin 0.7s linear infinite;
}
@keyframes dads-spin { to { transform: rotate(360deg); } }

/* ===== Form ======================================================= */
.dads-field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.dads-field__label {
  font: var(--t-body-sm); font-weight: 700;
  color: var(--c-text-strong);
}
.dads-field__required {
  color: var(--c-error);
  margin-inline-start: var(--sp-1);
}
.dads-field__helper { font: var(--t-caption); color: var(--c-text-muted); }
.dads-field__error  { font: var(--t-caption); color: var(--c-error); }

.dads-input,
.dads-select,
.dads-textarea {
  width: 100%;
  height: var(--h-control);
  padding: var(--sp-2) var(--sp-3);
  font: var(--t-body); /* iOS auto-zoom 防止のため 16px */
  color: var(--c-text-strong);
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--border-radius-6);
  box-sizing: border-box;
  transition: border-color var(--motion-fast), box-shadow var(--motion-fast);
}
.dads-textarea { height: auto; min-height: 96px; padding: var(--sp-3); resize: vertical; }
.dads-input:focus-visible,
.dads-select:focus-visible,
.dads-textarea:focus-visible {
  outline: none;
  border-color: var(--c-border-focus);
  box-shadow: 0 0 0 3px var(--c-brand-tint);
}
.dads-field--invalid .dads-input,
.dads-field--invalid .dads-select,
.dads-field--invalid .dads-textarea { border-color: var(--c-error); }
.dads-input:disabled,
.dads-select:disabled,
.dads-textarea:disabled {
  background: var(--c-bg-subtle);
  color: var(--c-text-disabled);
  cursor: not-allowed;
}

/* ===== Card ======================================================= */
.dads-card {
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border-subtle);
  border-radius: var(--border-radius-8);
  overflow: hidden;
}
.dads-card--elevated { border: 0; box-shadow: var(--elevation-1); }
.dads-card__header {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-border-subtle);
}
.dads-card__title { font: var(--t-h4); }
.dads-card__body { padding: var(--sp-5); }
.dads-card__footer {
  padding: var(--sp-3) var(--sp-5);
  border-top: 1px solid var(--c-border-subtle);
  display: flex; gap: var(--sp-2); justify-content: flex-end;
}

/* ===== Table ====================================================== */
.dads-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.dads-table {
  width: 100%; min-width: 600px;
  border-collapse: collapse;
  font: var(--t-body-sm);
  background: var(--c-bg-surface);
}
.dads-table th, .dads-table td {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-border-subtle);
  vertical-align: middle;
}
.dads-table thead th {
  background: var(--c-bg-subtle);
  font-weight: 700;
  color: var(--c-text-strong);
  white-space: nowrap;
  position: sticky; top: 0; z-index: 1;
}
.dads-table tbody tr:hover { background: var(--c-brand-tint); }
.dads-table .dads-code { font: var(--t-mono); }

/* Phase 2 (B): sortable header */
.dads-table th[data-sort] {
  cursor: pointer;
  user-select: none;
  position: relative;
}
.dads-table th[data-sort]:hover { background: var(--c-bg-page); }
.dads-table th[data-sort]::after {
  content: '⇅';
  margin-left: var(--sp-2);
  opacity: 0.35;
  font-size: 0.85em;
}
.dads-table th[data-sort][aria-sort="ascending"]::after {
  content: '▲'; opacity: 1; color: var(--c-brand);
}
.dads-table th[data-sort][aria-sort="descending"]::after {
  content: '▼'; opacity: 1; color: var(--c-brand);
}

/* ===== Pagination (Phase 2 B) ===================================== */
.dads-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  flex-wrap: wrap;
}
.dads-pagination__info {
  font: var(--t-body-sm);
  color: var(--c-text-muted);
  font-variant-numeric: tabular-nums;
}
.dads-pagination__controls {
  display: flex; gap: var(--sp-2); align-items: center;
}
.dads-pagination__btn {
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border);
  color: var(--c-text-body);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--border-radius-6);
  font: var(--t-body-sm);
  cursor: pointer;
  min-width: 36px;
  text-align: center;
}
.dads-pagination__btn:hover:not(:disabled) {
  background: var(--c-brand-tint);
  border-color: var(--c-brand);
}
.dads-pagination__btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.dads-pagination__btn--current {
  background: var(--c-brand);
  color: var(--c-text-on-fill, #fff);
  border-color: var(--c-brand);
  font-weight: 700;
}
.dads-pagination__btn--current:hover { background: var(--c-brand) !important; }
.dads-pagination__size {
  display: flex; align-items: center; gap: var(--sp-2);
  font: var(--t-body-sm); color: var(--c-text-muted);
}
.dads-pagination__size select {
  padding: 2px var(--sp-2);
  border: 1px solid var(--c-border);
  border-radius: var(--border-radius-6);
  background: var(--c-bg-surface);
  color: var(--c-text-body);
  font: var(--t-body-sm);
}

/* ===== Badge ====================================================== */
.dads-badge {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  height: 22px;
  padding-inline: var(--sp-2);
  border-radius: var(--border-radius-full);
  font: var(--t-caption); font-weight: 700;
  white-space: nowrap;
}
.dads-badge--gray    { background: var(--color-neutral-solid-gray-50);    color: var(--c-text-body); border: 1px solid var(--c-border); }
.dads-badge--blue    { background: var(--c-brand-tint);                   color: var(--c-brand); }
.dads-badge--success { background: var(--c-success-bg);                   color: var(--color-primitive-green-800); }
.dads-badge--warning { background: var(--c-warning-bg);                   color: var(--color-primitive-orange-800); }
.dads-badge--error   { background: var(--c-error-bg);                     color: var(--color-primitive-red-900); }

/* ===== Alert ====================================================== */
.dads-alert {
  display: flex; gap: var(--sp-3); align-items: flex-start;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--border-radius-6);
  border: 1px solid var(--c-border);
  background: var(--c-bg-subtle);
  font: var(--t-body-sm);
}
.dads-alert__icon { flex-shrink: 0; width: 20px; height: 20px; }
.dads-alert--info    { background: var(--c-info-bg);    border-color: var(--c-info-border);    color: var(--c-info); }
.dads-alert--success { background: var(--c-success-bg); border-color: var(--c-success-border); color: var(--color-primitive-green-800); }
.dads-alert--warning { background: var(--c-warning-bg); border-color: var(--c-warning-border); color: var(--color-primitive-orange-800); }
.dads-alert--error   { background: var(--c-error-bg);   border-color: var(--c-error-border);   color: var(--color-primitive-red-900); }

/* ===== KPI Card =================================================== */
.dads-kpi {
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border-subtle);
  border-radius: var(--border-radius-8);
  padding: var(--sp-4) var(--sp-5);
  display: grid; gap: var(--sp-1);
}
.dads-kpi__label { font: var(--t-body-sm); color: var(--c-text-muted); }
.dads-kpi__value {
  font: 700 var(--font-size-32)/1.2 var(--font-family-sans);
  color: var(--c-text-strong);
  font-variant-numeric: tabular-nums; /* 数字幅統一でレイアウトずれ防止 */
}
.dads-kpi__delta { font: var(--t-caption); }
.dads-kpi__delta--up { color: var(--c-success); }
.dads-kpi__delta--down { color: var(--c-error); }
.dads-kpi--warn   { background: var(--c-warning-bg); border-color: var(--c-warning-border); }
.dads-kpi--danger { background: var(--c-error-bg);   border-color: var(--c-error-border); }

.dads-kpi-grid {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* ===== Empty State ================================================ */
.dads-empty {
  text-align: center; padding: var(--sp-8) var(--sp-4);
  color: var(--c-text-muted);
}
.dads-empty__icon { width: 48px; height: 48px; margin: 0 auto var(--sp-3); color: var(--c-text-disabled); }
.dads-empty__title { font: var(--t-h4); color: var(--c-text-strong); margin-bottom: var(--sp-2); }
.dads-empty__hint { font: var(--t-body-sm); margin-bottom: var(--sp-4); }

/* ===== Inline message (toast / form msg) ========================== */
.dads-msg { min-height: 1.4em; font: var(--t-body-sm); margin-top: var(--sp-2); }
.dads-msg .ok  { color: var(--c-success); }
.dads-msg .err { color: var(--c-error); }

/* ===== Helpers / Utilities ======================================== */
.dads-stack-1 > * + * { margin-top: var(--sp-1); }
.dads-stack-2 > * + * { margin-top: var(--sp-2); }
.dads-stack-3 > * + * { margin-top: var(--sp-3); }
.dads-stack-4 > * + * { margin-top: var(--sp-4); }
.dads-stack-5 > * + * { margin-top: var(--sp-5); }
.dads-stack-6 > * + * { margin-top: var(--sp-6); }

.dads-row { display: flex; gap: var(--sp-3); flex-wrap: wrap; align-items: center; }
.dads-row--end { justify-content: flex-end; }
.dads-row--between { justify-content: space-between; }

.dads-text-muted { color: var(--c-text-muted); }
.dads-text-strong { color: var(--c-text-strong); }
.dads-text-mono { font: var(--t-mono); }

.dads-sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ===== Mobile responsiveness for tables ========================== */
@media (max-width: 640px) {
  .dads-page-header { flex-direction: column; align-items: flex-start; }
  .dads-card__header { flex-wrap: wrap; }
}

/* ====================================================================
 * v2 追加コンポーネント (Track B/C/D)
 * ==================================================================== */

/* ===== App Shell (Track B) ======================================= */
/* 全画面共通: 左 sidebar + メイン. 1024px 未満は drawer */
.dads-shell { display: grid; min-height: 100dvh; }
@media (min-width: 1024px) {
  .dads-shell { grid-template-columns: 240px 1fr; }
}
.dads-sidebar {
  background: var(--c-bg-surface);
  border-inline-end: 1px solid var(--c-border-subtle);
  display: flex; flex-direction: column; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-3);
  position: sticky; top: 0; height: 100dvh; overflow-y: auto;
  z-index: var(--z-fixed);
}
.dads-sidebar__brand { font: var(--t-h4); padding-inline: var(--sp-2); }
.dads-sidebar__group {
  display: flex; flex-direction: column; gap: var(--sp-1);
  margin-top: var(--sp-3);
}
.dads-sidebar__group-label {
  font: var(--t-caption); font-weight: 700;
  color: var(--c-text-muted);
  padding: var(--sp-1) var(--sp-2); text-transform: uppercase; letter-spacing: 0.04em;
}
.dads-sidebar__link {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3); border-radius: var(--border-radius-6);
  color: var(--c-text-body); text-decoration: none;
  font: var(--t-body-sm); font-weight: 500;
}
.dads-sidebar__link:hover { background: var(--c-brand-tint); color: var(--c-text-link); }
.dads-sidebar__link--current {
  background: var(--c-brand-tint); color: var(--c-text-link);
  box-shadow: inset 3px 0 0 var(--c-brand);
}
.dads-sidebar__user {
  margin-top: auto; padding: var(--sp-3) var(--sp-2);
  border-top: 1px solid var(--c-border-subtle);
  font: var(--t-caption); color: var(--c-text-muted);
}
.dads-shell__main {
  display: flex; flex-direction: column;
  background: var(--c-bg-page);
  min-width: 0; /* prevent overflow */
}
@media (max-width: 1023px) {
  .dads-sidebar {
    position: fixed; inset: 0 auto 0 0; width: 280px;
    transform: translateX(-100%); transition: transform var(--motion-base) var(--motion-ease);
  }
  .dads-sidebar[aria-expanded="true"] { transform: translateX(0); }
  .dads-shell__main-header {
    /* mobile: hamburger 表示用 */
    display: flex; align-items: center; gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-4);
    background: var(--c-bg-surface); border-bottom: 1px solid var(--c-border-subtle);
  }
}

/* ===== Brand Picker (Track B) ==================================== */
.dads-brand-picker {
  display: flex; flex-direction: column; gap: var(--sp-1);
  padding: var(--sp-2);
  background: var(--c-bg-subtle); border-radius: var(--border-radius-6);
}
.dads-brand-picker__label { font: var(--t-caption); color: var(--c-text-muted); }
.dads-brand-picker__select {
  width: 100%; padding: var(--sp-2);
  font: var(--t-body-sm); font-weight: 700;
  border: 1px solid var(--c-border); border-radius: var(--border-radius-4);
  background: var(--c-bg-surface);
}

/* ===== Breadcrumbs (Track B) ===================================== */
.dads-breadcrumbs { font: var(--t-caption); color: var(--c-text-muted); }
.dads-breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.dads-breadcrumbs li::before { content: "›"; margin-inline-end: var(--sp-2); color: var(--c-text-disabled); }
.dads-breadcrumbs li:first-child::before { content: ""; margin: 0; }
.dads-breadcrumbs a { color: var(--c-text-muted); }
.dads-breadcrumbs [aria-current="page"] { color: var(--c-text-strong); font-weight: 700; }

/* ===== Tabs (Track C) ============================================ */
.dads-tabs {
  display: flex; gap: var(--sp-1);
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--sp-4);
}
.dads-tab {
  padding: var(--sp-2) var(--sp-4); margin-bottom: -1px;
  font: var(--t-body); font-weight: 700; color: var(--c-text-muted);
  background: transparent; border: 0; border-bottom: 2px solid transparent;
  cursor: pointer;
}
.dads-tab[aria-selected="true"] {
  color: var(--c-text-link);
  border-bottom-color: var(--c-brand);
}
.dads-tab:hover { color: var(--c-text-strong); }
.dads-tab:focus-visible { outline: 2px solid var(--c-border-focus); outline-offset: 2px; }
.dads-tabpanel { padding-block: var(--sp-3); }
.dads-tabpanel[hidden] { display: none; }

/* ===== Status Stepper (Track C) ================================== */
.dads-stepper { padding: var(--sp-3) 0; }
.dads-stepper ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 0; align-items: center;
  overflow-x: auto;
}
.dads-stepper__step {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-3);
  font: var(--t-body-sm); font-weight: 500;
  color: var(--c-text-muted);
  white-space: nowrap;
}
.dads-stepper__step::before {
  content: ""; width: 12px; height: 12px; border-radius: 50%;
  background: var(--c-border); flex-shrink: 0;
}
.dads-stepper__step::after {
  content: ""; width: var(--sp-5); height: 1px;
  background: var(--c-border);
  margin-inline-start: var(--sp-2);
}
.dads-stepper__step:last-child::after { display: none; }
.dads-stepper__step.is-done {
  color: var(--c-success);
}
.dads-stepper__step.is-done::before {
  background: var(--c-success);
}
.dads-stepper__step.is-current {
  color: var(--c-brand); font-weight: 700;
}
.dads-stepper__step.is-current::before {
  background: var(--c-brand); box-shadow: 0 0 0 4px var(--c-brand-tint);
}

/* ===== Tooltip (Track C) ========================================= */
.dads-tooltip {
  position: relative; display: inline-flex; align-items: center;
  cursor: help;
}
.dads-tooltip__trigger {
  width: 16px; height: 16px; margin-inline-start: var(--sp-1);
  color: var(--c-text-muted);
}
.dads-tooltip__bubble {
  visibility: hidden; opacity: 0;
  position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  padding: var(--sp-2) var(--sp-3);
  background: var(--color-neutral-solid-gray-900); color: var(--c-text-on-fill);
  font: var(--t-caption); white-space: normal; max-width: 280px;
  border-radius: var(--border-radius-6); box-shadow: var(--elevation-2);
  z-index: var(--z-overlay);
  transition: opacity var(--motion-fast);
}
.dads-tooltip:hover .dads-tooltip__bubble,
.dads-tooltip:focus-within .dads-tooltip__bubble {
  visibility: visible; opacity: 1;
}

/* ===== Toast (Track D) =========================================== */
.dads-toast-stack {
  position: fixed; bottom: var(--sp-4); right: var(--sp-4);
  display: flex; flex-direction: column-reverse; gap: var(--sp-2);
  z-index: var(--z-toast);
  pointer-events: none;
  max-width: calc(100vw - 2 * var(--sp-4));
}
.dads-toast {
  pointer-events: auto;
  display: flex; gap: var(--sp-2); align-items: flex-start;
  padding: var(--sp-3) var(--sp-4);
  min-width: 280px; max-width: 420px;
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border-subtle);
  border-left: 4px solid var(--c-text-muted);
  border-radius: var(--border-radius-6);
  box-shadow: var(--elevation-3);
  font: var(--t-body-sm);
  animation: dads-toast-in var(--motion-base) var(--motion-ease-out);
}
@keyframes dads-toast-in {
  from { transform: translateX(20px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
.dads-toast--success { border-left-color: var(--c-success); }
.dads-toast--info    { border-left-color: var(--c-info); }
.dads-toast--warning { border-left-color: var(--c-warning); }
.dads-toast--error   { border-left-color: var(--c-error); }
.dads-toast__icon { flex-shrink: 0; width: 20px; height: 20px; }
.dads-toast__body { flex: 1; }
.dads-toast__action {
  background: transparent; border: 0;
  color: var(--c-text-link); font-weight: 700; padding: 0;
  cursor: pointer; font-size: inherit;
}
.dads-toast__close {
  background: transparent; border: 0;
  color: var(--c-text-muted); cursor: pointer; padding: var(--sp-1);
  font-size: 18px; line-height: 1;
}

/* ===== Skeleton (Track D) ======================================== */
.dads-skeleton {
  display: block;
  background: linear-gradient(90deg,
    var(--c-bg-subtle) 25%,
    var(--color-neutral-solid-gray-100) 37%,
    var(--c-bg-subtle) 63%);
  background-size: 400% 100%;
  border-radius: var(--border-radius-4);
  animation: dads-shimmer 1.4s ease infinite;
}
@keyframes dads-shimmer {
  0% { background-position: 100% 50%; }
  100% { background-position: 0 50%; }
}
.dads-skeleton--text { height: 14px; margin-bottom: var(--sp-2); }
.dads-skeleton--title { height: 24px; width: 60%; margin-bottom: var(--sp-3); }
.dads-skeleton--card { height: 120px; }
.dads-skeleton--avatar { width: 40px; height: 40px; border-radius: 50%; }
@media (prefers-reduced-motion: reduce) {
  .dads-skeleton { animation: none; opacity: 0.6; }
}

/* ===== Modal (Track C/D) ========================================= */
.dads-modal {
  position: fixed; inset: 0; z-index: var(--z-modal);
  display: flex; align-items: center; justify-content: center;
  padding: var(--sp-4);
}
.dads-modal[hidden] { display: none; }
.dads-modal__overlay {
  position: absolute; inset: 0;
  background: var(--c-bg-overlay);
  animation: dads-fade-in var(--motion-fast) var(--motion-ease-out);
}
.dads-modal__panel {
  position: relative; z-index: 1;
  background: var(--c-bg-surface);
  border-radius: var(--border-radius-12);
  padding: var(--sp-5);
  max-width: 480px; width: 100%;
  box-shadow: var(--elevation-5);
  animation: dads-modal-in var(--motion-base) var(--motion-ease);
}
@keyframes dads-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes dads-modal-in {
  from { transform: scale(0.96) translateY(8px); opacity: 0; }
  to   { transform: scale(1) translateY(0);     opacity: 1; }
}
.dads-modal__title { font: var(--t-h3); margin-bottom: var(--sp-3); }
.dads-modal__body { margin-bottom: var(--sp-5); color: var(--c-text-body); }
.dads-modal__actions {
  display: flex; gap: var(--sp-2); justify-content: flex-end;
}
@media (prefers-reduced-motion: reduce) {
  .dads-modal__overlay,
  .dads-modal__panel { animation: none; }
}

/* ===== Filter Bar (Track B) ====================================== */
.dads-filter-bar {
  display: flex; gap: var(--sp-3); flex-wrap: wrap; align-items: end;
  padding: var(--sp-3) var(--sp-4);
  background: var(--c-bg-surface);
  border: 1px solid var(--c-border-subtle); border-radius: var(--border-radius-6);
  margin-bottom: var(--sp-4);
}
.dads-filter-bar .dads-field { margin: 0; min-width: 160px; }
.dads-filter-bar__count {
  margin-inline-start: auto; font: var(--t-body-sm); color: var(--c-text-muted);
}

/* ===== Recent Items (Track B) ==================================== */
.dads-recent {
  display: grid; gap: var(--sp-2);
  padding: var(--sp-3); background: var(--c-bg-surface);
  border: 1px solid var(--c-border-subtle); border-radius: var(--border-radius-6);
}
.dads-recent__title { font: var(--t-h4); margin-bottom: var(--sp-2); }
.dads-recent__item {
  display: flex; gap: var(--sp-2); padding: var(--sp-2);
  border-radius: var(--border-radius-4);
  text-decoration: none; color: var(--c-text-body);
}
.dads-recent__item:hover { background: var(--c-brand-tint); color: var(--c-text-link); }
.dads-recent__type {
  display: inline-flex; align-items: center; padding: 0 var(--sp-2);
  background: var(--c-brand-tint); color: var(--c-brand);
  font: var(--t-caption); font-weight: 700; border-radius: var(--border-radius-4);
}

/* ===== Search (Track B) ========================================== */
.dads-search {
  position: relative; max-width: 480px; flex: 1;
}
.dads-search__input {
  width: 100%; height: 36px; padding: var(--sp-2) var(--sp-3) var(--sp-2) calc(var(--sp-3) * 2 + 16px);
  font: var(--t-body-sm);
  border: 1px solid var(--c-border); border-radius: var(--border-radius-6);
  background: var(--c-bg-subtle);
}
.dads-search__icon {
  position: absolute; left: var(--sp-3); top: 50%; transform: translateY(-50%);
  color: var(--c-text-muted); width: 16px; height: 16px;
}
.dads-search__input:focus-visible { outline: 2px solid var(--c-border-focus); outline-offset: 2px; background: var(--c-bg-surface); }

/* ===== Reduced Motion: 全 transition / animation を無効化 ========= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0ms !important;
    transition-duration: 0ms !important;
  }
}
