@charset "UTF-8";

/* =========================================
   robo_adjust 追加スタイル（最終上書き）
   既存の page.css / page_att.css を崩さず上品に強化
   影響範囲は .page-frame 配下中心
========================================= */

:root {
	--brand: #00b4d8;
	--brand-dark: #0096c7;
	--ink: #222;
	--muted: #666;
	--line: #e9ecef;
	--card: #ffffff;
	--soft: #f8fafc;
	--shadow-sm: 0 6px 16px rgba(0,0,0,0.05);
	--shadow-md: 0 12px 30px rgba(0,0,0,0.08);
	--radius: 14px;
}

/* ---------- タブ（見出し）強化 ---------- */
.page-frame .tab-group:first-of-type {
	padding: 14px 16px;
	background: linear-gradient(180deg, #fff 0%, #f6f9fc 100%);
	border-bottom: 1px solid var(--line);
}
.page-frame .tab-group:first-of-type .tabTool {
	flex: 0 0 auto;
	min-width: 160px;
	padding: 8px 14px;
	border-radius: 999px;
	border: 1px solid #d7eef6;
	background: #eef7fb;
	color: var(--brand-dark);
	font-weight: 800;
	letter-spacing: .02em;
	transition: transform .06s ease, box-shadow .2s ease;
	box-shadow: var(--shadow-sm);
}
.page-frame .tab-group:first-of-type .tabTool:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 24px rgba(0,180,216,.15);
}
.page-frame .tab-group:first-of-type .tabTool.is-active {
	background: var(--brand);
	border-color: var(--brand);
	color: #fff;
	box-shadow: 0 12px 28px rgba(0,180,216,.25);
}

/* ---------- ステータス + 接続ボタンの帯 ---------- */
.page-frame .status-actions {
	background: #fff;
	backdrop-filter: none;
	border: 1px solid var(--line);
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
	max-width: none;
	width: calc(100% - 40px); /* panel-groupの左右20pxに合わせる */
	margin-left: 20px;
	margin-right: 20px;
	display: flex;
	align-items: center;
	justify-content: space-between; /* 左:状態, 中:テキスト, 右:ボタン群 */
	gap: 12px;
	margin-top: 8px;
	margin-bottom: 16px;
}
.page-frame .status-box {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	border-radius: 999px;
	padding: 10px 16px;
	border: 1px solid var(--line);
	box-shadow: none;
	background: #fff;
	flex-wrap: nowrap;
	width: auto; /* 既存 .box の width:60% を打ち消し */
}
.page-frame .status-text {
	font-family: 'Roboto Mono', monospace;
	color: var(--ink);
	min-width: 140px;
	text-align: center;
}
.page-frame .status-actions .status-label {
	color: var(--ink);
	font-weight: 800;
	letter-spacing: .05em;
}
.page-frame .status-box .actions-inside {
	display: flex;
	align-items: center;
	gap: 10px;
}
.page-frame .actions-right,
.page-frame .status-box .actions-inside {
	display: flex;
	align-items: center;
	gap: 10px;
}
.page-frame .actions-right .btn-disconnect,
.page-frame .status-box .btn-disconnect {
	background: #fff;
	color: #d90429;
	border: 1px solid #f1b3b8;
	box-shadow: var(--shadow-sm);
}
.page-frame .actions-right .btn-disconnect:hover,
.page-frame .status-box .btn-disconnect:hover {
	background: #fff5f6;
	border-color: #e63946;
}
.page-frame .actions-right .btn-disconnect:active,
.page-frame .status-box .btn-disconnect:active {
	transform: translateY(1px);
}
.page-frame .status-actions .actions .tool_conn {
	border-radius: 999px;
	padding: 12px 22px;
}

/* ---------- 調整テーブル（カード行） ---------- */
.page-frame .panel-group {
	color: var(--ink);
}
.page-frame .tool_item_table {
	border-collapse: separate;
	border-spacing: 0 10px;
}
.page-frame .tool_item_table tr {
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
}
.page-frame .tool_item_table tr > td:first-child {
	border-radius: 12px 0 0 12px;
}
.page-frame .tool_item_table tr > td:last-child {
	border-radius: 0 12px 12px 0;
}
.page-frame .tool_item_table tr.row-all90 {
	background: transparent;
	border: none;
	box-shadow: none;
}
.page-frame .tool_item_title {
	font-weight: 800;
	color: var(--ink);
	width: 220px;
	border-right: 1px dashed #edf2f7;
}
.page-frame .tool_item_num_data {
	width: 210px;
}
.page-frame .adjust_edit {
	max-width: 140px;
	border-radius: 10px;
	border: 1px solid var(--line);
	background: #fff;
	padding: 8px 10px;
	font-family: 'Roboto Mono', monospace;
}
.page-frame .adjust_edit:focus {
	outline: 2px solid rgba(0,180,216,.22);
	border-color: var(--brand);
}

/* ---------- ボタンの最終トーン ---------- */
.page-frame .tool_move_button {
	border-radius: 10px;
	padding: 10px 16px;
	min-width: 150px;
	background: #fff;
	border: 1px solid var(--line);
	color: var(--ink);
	box-shadow: var(--shadow-sm);
}
.page-frame .cta-all90 {
	display: block;
	width: 100%;
	padding: 16px 20px;
	border-radius: 12px;
	border: 1px solid #cfeaf4;
	background: #ffffff;
	color: var(--brand-dark);
	font-weight: 800;
	letter-spacing: .02em;
	text-align: center;
	box-shadow: var(--shadow-sm);
	cursor: pointer;
	transition: transform .05s ease, background-color .2s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease;
}
.page-frame .cta-all90:hover {
	background-color: rgba(0,180,216,.06);
	border-color: var(--brand);
	color: var(--brand-dark);
	box-shadow: 0 12px 26px rgba(0,180,216,.12);
}
.page-frame .cta-all90:active {
	transform: translateY(1px);
}
.page-frame .cta-all90:focus-visible {
	outline: 3px solid rgba(0,180,216,.35);
	outline-offset: 2px;
}
.page-frame .tool_move_button:hover {
	border-color: var(--brand);
	color: var(--brand-dark);
	box-shadow: 0 10px 22px rgba(0,180,216,.14);
}
.page-frame .tool_conn {
	min-width: 150px;
	font-weight: 800;
}

/* ---------- 使い方（リスト） ---------- */
.page-frame ol {
	counter-reset: steps;
	list-style: none;
	padding-left: 0;
}
.page-frame ol > li {
	counter-increment: steps;
	margin: 6px 0;
}
.page-frame ol > li .tool_content {
	position: relative;
	padding-left: 42px;
}
.page-frame ol > li .tool_content::before {
	content: counter(steps, decimal-leading-zero);
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	font-family: 'Roboto Mono', monospace;
	font-weight: 800;
	color: var(--brand-dark);
	opacity: .9;
}

/* ---------- 区切り線 ---------- */
.page-frame hr {
	border: none;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--line), transparent);
}

/* ---------- レスポンシブ ---------- */
@media (max-width: 900px) {
	.page-frame .tool_item_title { width: 160px; }
	.page-frame .tool_item_num_data { width: 160px; }
	.page-frame .status-actions {
		padding: 8px 12px;
		width: calc(100% - 24px); /* 左右12pxに合わせる */
		margin-left: 12px;
		margin-right: 12px;
	}
}

/* ---------- 情報ボックス（機種/バージョン/ID/ライセンス）を状態ボックス風に ---------- */
.page-frame .boxes {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: calc(100% - 40px);
	margin: 8px 20px;
	padding: 10px 16px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
}
.page-frame .boxes .box-a {
	flex: 0 0 40%;
	text-align: right;
	color: var(--muted);
	font-weight: 700;
	padding-right: 12px;
}
.page-frame .boxes .box-b {
	flex: 1;
	text-align: center;
	font-family: 'Roboto Mono', monospace;
	color: var(--ink);
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px; /* 状態テキストと同じピル形状 */
	padding: 8px 12px;
}

@media (max-width: 900px) {
	.page-frame .boxes {
		width: calc(100% - 24px);
		margin-left: 12px;
		margin-right: 12px;
		flex-wrap: wrap;
		gap: 8px;
	}
	.page-frame .boxes .box-a { flex: 1 1 100%; text-align: left; padding-right: 0; }
	.page-frame .boxes .box-b { flex: 1 1 100%; }
}
/* ---------- 動くボタン（ラベル一致でグレー化） ---------- */
.page-frame .tool_move_button[value="動く"],
.page-frame input.tool_move_button[value="動く"] {
	background: #f2f4f7;
	border: 1px solid #d5d9e0;
	color: #444;
	box-shadow: var(--shadow-sm);
}
.page-frame .tool_move_button[value="動く"]:hover,
.page-frame input.tool_move_button[value="動く"]:hover {
	background: #e9edf3;
	border-color: #c8ced8;
	color: #333;
}
.page-frame .tool_move_button[value="動く"]:active,
.page-frame input.tool_move_button[value="動く"]:active {
	transform: translateY(1px);
}
.page-frame .tool_move_button[value="動く"]:focus-visible,
.page-frame input.tool_move_button[value="動く"]:focus-visible {
	outline: 3px solid rgba(0,0,0,.08);
	outline-offset: 2px;
}

/* 右足で立つ・左足で立つ・まっすぐにする・保存する もグレー化 */
.page-frame .tool_move_button[value="右足で立つ"],
.page-frame input.tool_move_button[value="右足で立つ"],
.page-frame .tool_move_button[value="左足で立つ"],
.page-frame input.tool_move_button[value="左足で立つ"],
.page-frame .tool_move_button[value="まっすぐにする"],
.page-frame input.tool_move_button[value="まっすぐにする"],
.page-frame .tool_move_button[value="保存する"],
.page-frame input.tool_move_button[value="保存する"] {
	background: #f2f4f7;
	border: 1px solid #d5d9e0;
	color: #444;
	box-shadow: var(--shadow-sm);
}
.page-frame .tool_move_button[value="右足で立つ"]:hover,
.page-frame input.tool_move_button[value="右足で立つ"]:hover,
.page-frame .tool_move_button[value="左足で立つ"]:hover,
.page-frame input.tool_move_button[value="左足で立つ"]:hover,
.page-frame .tool_move_button[value="まっすぐにする"]:hover,
.page-frame input.tool_move_button[value="まっすぐにする"]:hover,
.page-frame .tool_move_button[value="保存する"]:hover,
.page-frame input.tool_move_button[value="保存する"]:hover {
	background: #e9edf3;
	border-color: #c8ced8;
	color: #333;
}
.page-frame .tool_move_button[value="右足で立つ"]:active,
.page-frame input.tool_move_button[value="右足で立つ"]:active,
.page-frame .tool_move_button[value="左足で立つ"]:active,
.page-frame input.tool_move_button[value="左足で立つ"]:active,
.page-frame .tool_move_button[value="まっすぐにする"]:active,
.page-frame input.tool_move_button[value="まっすぐにする"]:active,
.page-frame .tool_move_button[value="保存する"]:active,
.page-frame input.tool_move_button[value="保存する"]:active {
	transform: translateY(1px);
}
.page-frame .tool_move_button[value="右足で立つ"]:focus-visible,
.page-frame input.tool_move_button[value="右足で立つ"]:focus-visible,
.page-frame .tool_move_button[value="左足で立つ"]:focus-visible,
.page-frame input.tool_move_button[value="左足で立つ"]:focus-visible,
.page-frame .tool_move_button[value="まっすぐにする"]:focus-visible,
.page-frame input.tool_move_button[value="まっすぐにする"]:focus-visible,
.page-frame .tool_move_button[value="保存する"]:focus-visible,
.page-frame input.tool_move_button[value="保存する"]:focus-visible {
	outline: 3px solid rgba(0,0,0,.08);
	outline-offset: 2px;
}
/* ---------- メインタイトル（ロボット調整）リデザイン ---------- */
.page-frame .tab-group:first-of-type .tabTool.tabAdjust {
	position: relative;
	overflow: hidden;
	isolation: isolate;
	border: 1px solid var(--line);
	background: #ffffff;
	color: var(--ink);
	font-weight: 800;
	letter-spacing: .05em;
	font-size: 1.15rem;
	padding: 12px 20px;
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
	text-transform: none;
}
.page-frame .tab-group:first-of-type .tabTool.tabAdjust.is-active {
	background: #f8fbff;
	border-color: #cfeaf4;
}
.page-frame .tab-group:first-of-type .tabTool.tabAdjust::before {
	content: none;
}
.page-frame .tab-group:first-of-type .tabTool.tabAdjust::after {
	content: none;
}
.page-frame .tab-group:first-of-type .tabTool.tabAdjust:hover {
	transform: none;
	box-shadow: 0 12px 22px rgba(0,0,0,.05);
	border-color: #cfeaf4;
	background: #f9fcff;
}
@media (max-width: 900px) {
	.page-frame .tab-group:first-of-type .tabTool.tabAdjust {
		font-size: 1.0rem;
		padding: 10px 16px;
	}
}

