/* ============ カラートークン（ダーク/ライト対応） ============ */
:root{
  --bg:#ffffff; --bg-soft:#f7f8fb;
  --panel:#ffffff; --panel-border:#e6e8f0;
  --text:#0f1222; --muted:#656c86;
  --brand:#15b46b; --accent:#6b8afd;
  --success:#22b07d; --danger:#e2566b; --warn:#f5a524;
  --focus:0 0 0 3px rgba(107,138,253,.28);
  --radius:14px; --radius-sm:10px; --gap:16px;
  --shadow:0 10px 30px rgba(15,18,34,0.06);
  --shadow-sm:0 6px 18px rgba(15,18,34,0.05);
  --font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;

  --log-bg:#0a0f1a; --log-fg:#bfffd0; --log-border:#1a2236;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0c101a; --bg-soft:#111628;
    --panel:#0f1526; --panel-border:#202844;
    --text:#ecf1ff; --muted:#92a0c0;
    --brand:#39d28c; --accent:#7c96ff;
    --success:#29cd8f; --danger:#ff6f86; --warn:#ffbe55;
    --focus:0 0 0 3px rgba(124,150,255,.35);
    --shadow:0 12px 36px rgba(0,0,0,.35);
    --shadow-sm:0 8px 22px rgba(0,0,0,.25);

    --log-bg:#04070f; --log-fg:#9cffb2; --log-border:#111a2c;
  }
}

/* ============ ベース ============ */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0; font-family:var(--font-sans); color:var(--text);
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(107,138,253,.08), transparent 60%),
    radial-gradient(1000px 500px at 100% 0, rgba(57,210,140,.06), transparent 60%),
    var(--bg);
}
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
:focus-visible{ outline:none; box-shadow:var(--focus); border-color:transparent; }
@media (prefers-reduced-motion: reduce){ *{ transition:none!important; animation:none!important } }

/* ============ スキップリンク ============ */
.skip-link{
  position:absolute; top:-40px; left:8px;
  background:var(--panel); color:var(--text);
  padding:8px 12px; border-radius:var(--radius-sm);
  border:1px solid var(--panel-border); box-shadow:var(--shadow-sm);
  transition:.2s ease; z-index:10;
}
.skip-link:focus{ top:8px; }

/* ============ ヘッダー ============ */
.app-header{
  position:sticky; top:0; z-index:20;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px;
  background:color-mix(in srgb,var(--panel) 80%, transparent);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--panel-border);
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ width:36px; height:36px; border-radius:10px; object-fit:contain; background:#fff; box-shadow:inset 0 0 0 2px rgba(255,255,255,.8); }
.brand-title{ margin:0; font-size:22px; color:var(--brand); letter-spacing:.2px; }
.sub{ margin:2px 0 0; font-size:12px; color:var(--muted); }
.header-actions{ display:flex; align-items:center; gap:10px; }
.header-meta .caption{ margin-left:6px; }

/* バッジ */
.badge{ padding:6px 10px; border-radius:999px; font-size:12px; border:1px solid transparent; font-weight:700; }
.badge-online{ color:#007a55; background:#e6f9f2; border-color:#bdebdc; }
.badge-offline{ color:#b82a3a; background:#fff1f2; border-color:#f7c6cd; }
@media (prefers-color-scheme: dark){
  .badge-online{ color:#19d39b; background:rgba(25,211,155,.16); border-color:rgba(25,211,155,.35); }
  .badge-offline{ color:#ff8da0; background:rgba(255,141,160,.16); border-color:rgba(255,141,160,.35); }
}

/* ============ レイアウト（コンテナ） ============ */
/* デフォルトはブロック。ページ固有レイアウトは下の .layout-columns で指定 */
.container{ padding:18px; }

/* ====== layout-columns（安全なFlex版） ====== */
/* 左右コラム（上2段）＋ 下段（状態／ログ） */
.container.layout-columns{
  display:flex !important;       /* 既存Gridを強制無効化 */
  flex-wrap:wrap;                /* 2列×2段（折返し） */
  gap:20px;
  align-items:flex-start;        /* 上揃えで余白ゼロ */
}

/* 左右のコラムは独立して縦積み（これが空白解消のキモ） */
.col{
  display:flex;
  flex-direction:column;
  gap:20px;
  flex:1 1 560px;               /* 2カラム化の基準幅 */
  min-width:360px;              /* 潰れ防止 */
}



/* 下段：状態／ログ（横並びで半々） */
.card-status, .card-logs{
  flex:1 1 360px;
  min-width:360px;
}

/* モバイルは縦積み */
@media (max-width:980px){
  .container.layout-columns{ display:block !important; }
  .col{ gap:20px; }
  .card-status, .card-logs{ min-width:0; }
}

/* ============ カード ============ */
.card{
  background:var(--panel); border:1px solid var(--panel-border);
  border-radius:var(--radius); box-shadow:var(--shadow); overflow:clip;
}
.card-head{ padding:14px 16px 10px; border-bottom:1px solid var(--panel-border); }
.card-head h2,.card-head h3{ margin:0; font-size:18px; letter-spacing:.2px; }
.card-head .hint{ margin:6px 0 0; color:var(--muted); font-size:12px; }
.card-body{ padding:16px; }
.card.compact .card-head{ padding:12px 14px 8px; }
.card.compact .card-body{ padding:12px 14px; }
.help{ margin-top:10px; }

/* ============ 入力/ボタン ============ */
.input-row{ display:grid; gap:8px; }
.label{ font-size:12px; color:var(--muted); }
.input{
  height:48px; padding:10px 12px; border:1px solid var(--panel-border);
  border-radius:var(--radius-sm); background:var(--bg); font-size:16px; transition:.15s ease;
}
.input::placeholder{ color:color-mix(in srgb,var(--muted) 70%, transparent); }
.input:focus{ box-shadow:var(--focus); }
.amount-readout{ margin-top:6px; }

.btn-row{
  display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:12px;
}
.btn{
  --bg:#fff; --fg:var(--text); --bd:#d7d9e0;
  min-width:160px; height:56px; padding:0 18px;
  border-radius:var(--radius-sm); border:1px solid var(--bd);
  background:var(--bg); color:var(--fg);
  font-weight:700; letter-spacing:.2px; cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.btn .btn-icon{ margin-right:6px; }
.btn:hover{ transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.btn:active{ transform:translateY(0); box-shadow:none; }
.btn:disabled{ opacity:.55; cursor:not-allowed; }
.btn-primary{ --bg:var(--accent); --fg:#fff; --bd:var(--accent); color:#fff; }
.btn-success{ --bg:var(--success); --fg:#fff; --bd:var(--success); color:#fff; }
.btn-ghost{ background:transparent; border-style:dashed; color:var(--muted); }

/* ============ リスト ============ */
.list{
  margin:10px 0 0; padding:0; list-style:none; display:grid; gap:10px;
}
.list li{
  padding:10px 12px; border:1px solid var(--panel-border); border-radius:var(--radius-sm);
  background:var(--bg-soft);
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Courier New",monospace;
  font-size:13px; color:var(--text);
}

/* ============ 状態表示（キー・バリュー） ============ */
.kv{ display:grid; gap:8px; font-size:14px; }
.kv-plain .kv-row{ border-bottom:none; padding:2px 0; }
.kv-row{
  display:flex; justify-content:space-between;
  border-bottom:1px dashed color-mix(in srgb,var(--panel-border) 80%, transparent);
  padding:6px 0;
}
.caption{ margin:6px 0 0; font-size:12px; color:var(--muted); }

/* ============ 施術行 ============ */
.grid{ display:grid; }
.gap-2{ gap:12px; }
.svc-row{ display:grid; grid-template-columns:1fr 120px; gap:10px; }
.svc-row select,.svc-row input{
  height:44px; border-radius:var(--radius-sm); border:1px solid var(--panel-border);
  background:var(--bg); font-size:15px; padding:8px 10px;
}
.svc-row input[type="number"]::-webkit-outer-spin-button,
.svc-row input[type="number"]::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.svc-row input[type="number"] {
  appearance: textfield;
  -moz-appearance: textfield; /* Firefox */
}

/* 施術カードは内側スクロールで高さを抑える（“スクロール無し決済”に寄与） */
.card-services .card-body{
  max-height: clamp(300px, 38vh, 480px);
  overflow:auto;
}

/* ============ ログ（折りたたみUI） ============ */
.logs-details{ display:block; }
.logs-details > summary{
  list-style:none; cursor:pointer; padding:12px 16px; font-weight:700; color:var(--text);
}
.logs-details > summary::marker{ display:none; }
.logs-details > summary::after{
  content:"▼"; float:right; opacity:.6; transition:transform .15s ease;
}
.logs-details[open] > summary{ border-bottom:1px solid var(--panel-border); }
.logs-details[open] > summary::after{ transform:rotate(180deg); }

.logs-wrap{ padding:0 16px 16px; }
.logs{
  background:var(--log-bg); color:var(--log-fg);
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Courier New",monospace;
  padding:14px; border-radius:8px; height:clamp(160px, 22vh, 320px);
  overflow:auto; border:1px solid var(--log-border);
}
.logs hr{ border:none; border-top:1px solid var(--log-border); margin:12px 0; }
.logs-details:not([open]) .logs{ display:none; }

/* 本番運用でログ自体を出さないモード（<body class="frontdesk">で有効） */
body.frontdesk .logs-card{ display:none !important; }

/* ============ トースト ============ */
.toast{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%) translateY(20px);
  background:#141a2a; color:#fff; padding:12px 16px; border-radius:var(--radius-sm);
  box-shadow:0 10px 30px rgba(0,0,0,.25); opacity:0; pointer-events:none; transition:.25s ease;
}
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ============ フッター ============ */
.app-footer{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; color:var(--muted); border-top:1px solid var(--panel-border);
}

/* ============ アクセシビリティ補助 ============ */
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
