/* ステーブルコイン越境決済デモ — 共通スタイル（v0.1配色を踏襲・テーマ差替対応） */
:root{
  --bg:#0b0d12; --card:#12151c; --ink:#e8eef9; --muted:#8b97a8; --line:#222838;
  --brand:#4f8cff; --brand2:#7c5cff; --ok:#27c08a; --warn:#f0a13a; --err:#ff5d6c;
  --chip:#1a1f2b;
}
[data-theme="manga"]{ --brand:#ff5d6c; --brand2:#f0a13a; }
[data-theme="anime"]{ --brand:#27c08a; --brand2:#4f8cff; }
[data-theme="trading-card"]{ --brand:#7c5cff; --brand2:#27c08a; }

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans JP",sans-serif}
a{color:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:24px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.muted{color:var(--muted)} .small{font-size:12px}

header.appbar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 0;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand .logo{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--brand),var(--brand2))}
.tag{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:3px 10px}
.toolbar{display:flex;align-items:center;gap:8px}
.toolbar select{width:auto;padding:7px 10px}

.grid{display:grid;grid-template-columns:1.3fr .9fr;gap:18px;margin-top:18px}
@media (max-width:820px){ .grid{grid-template-columns:1fr} }
.card{background:linear-gradient(180deg,#12151c,#0f1219);border:1px solid var(--line);border-radius:16px;padding:18px}
h1{font-size:20px;margin:6px 0 2px} h2{font-size:16px;margin:0 0 8px}
.sub{color:var(--muted);font-size:13px}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

.seg{display:flex;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.seg button{flex:1;padding:10px 12px;background:transparent;border:0;color:var(--muted);cursor:pointer;font-weight:600}
.seg button.active{background:var(--chip);color:var(--ink)}

.field{margin-top:12px}
.label{font-size:12px;color:var(--muted);margin-bottom:6px}
.input,select{width:100%;padding:11px 12px;background:#0d1016;border:1px solid var(--line);border-radius:10px;color:var(--ink)}

.btn{appearance:none;border:0;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn.block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}

.kv{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px dashed var(--line)}
.kv b{font-weight:700}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--line)}
.badge.ok{color:var(--ok);border-color:var(--ok)}
.badge.warn{color:var(--warn);border-color:var(--warn)}
.badge.err{color:var(--err);border-color:var(--err)}
.pill{font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:2px 8px}

.steps{display:flex;gap:8px;margin:14px 0}
.step{flex:1;height:6px;border-radius:999px;background:var(--line)}
.step.active{background:linear-gradient(90deg,var(--brand),var(--brand2))}

.notice{font-size:12px;color:var(--muted);border-top:1px solid var(--line);margin-top:16px;padding-top:12px;line-height:1.6}

table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600}
tr.clickable{cursor:pointer}
tr.clickable:hover{background:var(--chip)}

.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:16px}
.product{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#0f1219}
.product .thumb{height:120px;background:linear-gradient(135deg,var(--brand),var(--brand2));opacity:.85}
.product .body{padding:12px}
.product .price{font-weight:700;margin-top:6px}
.detail{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
