/* MintSpark セキュリティ診断 ダッシュボード（L2）
   frontend.css と同じ視覚言語：機能美・上品な余白・読みやすい階層。
   経営者が後から「どこが良くなり、どこが弱いか」を一目で比較できることを最優先。 */

.mssc-dash {
	--mssc-teal: #0F9B8E;
	--mssc-teal-dark: #0a7a6f;
	--mssc-navy: #2B2D42;
	--mssc-bg: #F8F9FA;
	--mssc-panel: #ffffff;
	--mssc-panel-2: #f5f6f8;
	--mssc-line: #e4e7eb;
	--mssc-line-strong: #c8cdd4;
	--mssc-ink: #2B2D42;
	--mssc-ink-dim: #2f3540;
	--mssc-ink-soft: #4b5563;
	--mssc-green: #1a9e6f;
	--mssc-yellow: #d99a00;
	--mssc-red: #d64545;
	--mssc-shadow-sm: 0 1px 2px rgba(43,45,66,.04);
	--mssc-shadow-md: 0 1px 3px rgba(43,45,66,.05), 0 4px 14px rgba(43,45,66,.04);

	max-width: 860px;
	margin: 0 auto;
	color: var(--mssc-ink);
	line-height: 1.75;
	font-family: inherit;
	-webkit-font-smoothing: antialiased;
}
.mssc-dash *, .mssc-dash *::before, .mssc-dash *::after { box-sizing: border-box; }

/* ========== ヘッダ ========== */
.mssc-dash .mssc-header { margin-bottom: 34px; }
.mssc-dash .mssc-header-top {
	display: flex; justify-content: space-between; align-items: center;
	gap: 12px; flex-wrap: wrap; margin-bottom: 22px;
}
.mssc-dash .mssc-badge {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 13px; font-weight: 600; letter-spacing: .08em;
	color: var(--mssc-ink-dim);
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	padding: 7px 14px; border-radius: 999px;
}
.mssc-dash .mssc-badge-dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--mssc-teal);
	box-shadow: 0 0 0 3px rgba(15,155,142,.12);
}
.mssc-dash .mssc-save-toplink {
	display: inline-block;
	background: transparent; color: var(--mssc-ink); text-decoration: none;
	font-weight: 600; font-size: 14px; padding: 9px 18px; border-radius: 8px;
	border: 1px solid var(--mssc-line);
	transition: border-color .15s, color .15s; white-space: nowrap;
}
.mssc-dash .mssc-save-toplink:hover { border-color: var(--mssc-teal); color: var(--mssc-teal); }

.mssc-dash .mssc-hero-title {
	font-size: 36px; font-weight: 800; line-height: 1.4;
	letter-spacing: -0.02em;
	margin: 0 0 14px !important; padding: 0 !important;
	color: var(--mssc-navy) !important;
	background: none !important; border: 0 !important;
}
.mssc-dash .mssc-lead {
	color: var(--mssc-ink-dim); font-size: 16px; font-weight: 400;
	line-height: 1.85; margin: 0;
}

/* SWELL装飾打ち消し */
.mssc-dash h1, .mssc-dash h2, .mssc-dash h3, .mssc-dash h4 {
	border: 0 !important; background: none !important; box-shadow: none !important;
	margin-top: 0 !important; padding-left: 0 !important; padding-right: 0 !important;
}
.mssc-dash h1::before, .mssc-dash h1::after,
.mssc-dash h2::before, .mssc-dash h2::after,
.mssc-dash h3::before, .mssc-dash h3::after,
.mssc-dash h4::before, .mssc-dash h4::after { display: none !important; content: none !important; }

/* ========== 認証カード ========== */
.mssc-dash .mssc-card {
	background: var(--mssc-panel); border: 1px solid var(--mssc-line);
	border-radius: 12px; padding: 28px; margin-bottom: 22px;
	box-shadow: var(--mssc-shadow-sm);
}
.mssc-dash .mssc-field-label { font-size: 14px; font-weight: 700; margin-bottom: 10px; display: block; }
.mssc-dash .mssc-input-row { display: flex; gap: 10px; }
.mssc-dash .mssc-input {
	flex: 1; min-width: 0; background: var(--mssc-bg); border: 1px solid var(--mssc-line);
	border-radius: 8px; color: var(--mssc-ink); font-size: 16px; font-weight: 500;
	padding: 14px 16px; outline: none;
	transition: border-color .15s, background .15s, box-shadow .15s;
}
.mssc-dash .mssc-input:focus {
	border-color: var(--mssc-teal); background: #fff;
	box-shadow: 0 0 0 3px rgba(15,155,142,.12);
}
.mssc-dash .mssc-run {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--mssc-navy); color: #fff; border: none; border-radius: 8px;
	font-family: inherit; font-weight: 700; font-size: 15px;
	padding: 0 24px; cursor: pointer; white-space: nowrap;
	transition: background .15s, transform .05s;
}
.mssc-dash .mssc-run:hover { background: #1a1c30; }
.mssc-dash .mssc-run:active { transform: scale(.98); }
.mssc-dash .mssc-run:disabled { opacity: .45; cursor: not-allowed; }
.mssc-dash .mssc-run-arrow { font-size: 16px; line-height: 1; transition: transform .15s; }
.mssc-dash .mssc-run:hover .mssc-run-arrow { transform: translateX(3px); }
.mssc-dash .mssc-note { font-size: 13px; color: var(--mssc-ink-dim); margin-top: 14px; line-height: 1.85; }
.mssc-dash .mssc-note a { color: var(--mssc-teal); font-weight: 600; }
.mssc-dash .mssc-err { color: var(--mssc-red); font-size: 14px; font-weight: 500; margin-top: 12px; display: none; }
.mssc-dash .mssc-ok { color: var(--mssc-green); font-size: 14px; font-weight: 500; margin-top: 12px; display: none; }

/* ========== ログイン後のバー ========== */
.mssc-dash-bar {
	display: flex; align-items: center; justify-content: space-between;
	margin-bottom: 18px; gap: 12px; flex-wrap: wrap;
}
.mssc-dash-user { font-size: 14px; color: var(--mssc-ink-dim); font-weight: 500; }
.mssc-logout {
	background: transparent; border: 1px solid var(--mssc-line); color: var(--mssc-ink-dim);
	border-radius: 8px; padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer;
	transition: border-color .15s, color .15s;
}
.mssc-logout:hover { border-color: var(--mssc-teal); color: var(--mssc-teal); }

/* ========== 「新しいサイトを診断」ボタン ========== */
.mssc-dash-actions { margin-bottom: 18px; }
.mssc-newscan {
	display: inline-block;
	background: transparent;
	border: 1.5px dashed var(--mssc-teal);
	color: var(--mssc-teal); text-decoration: none;
	font-weight: 700; font-size: 15px;
	padding: 13px 26px; border-radius: 10px;
	transition: background .15s, color .15s;
}
.mssc-newscan:hover { background: var(--mssc-teal); color: #fff; }

/* ========== L3：改善計画セクション ============================
   経営者向け本丸 UI。MintSpark の提言と顧客の実施状況を一覧する。
   サイトカードと差別化するため Teal-tint のパネルで囲んで目立たせる。 */
.mssc-reco-section {
	background: linear-gradient(180deg, rgba(15,155,142,.07) 0%, rgba(15,155,142,.04) 100%);
	border: 1px solid rgba(15,155,142,.28);
	border-radius: 16px;
	padding: 22px 24px;
	margin-bottom: 38px;
	box-shadow: 0 2px 10px rgba(15,155,142,.06);
}
.mssc-reco-head {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 16px; flex-wrap: wrap;
}
.mssc-reco-head::before {
	content: ''; width: 6px; height: 24px; border-radius: 3px;
	background: var(--mssc-teal); display: block; flex-shrink: 0;
}
.mssc-reco-head h2 {
	font-size: 22px; font-weight: 800; letter-spacing: -0.01em;
	margin: 0 !important;
	color: var(--mssc-navy) !important;
	background: none !important;
	-webkit-text-fill-color: var(--mssc-navy);
}
.mssc-reco-head p {
	width: 100%;
	font-size: 13px; color: var(--mssc-ink-dim);
	font-weight: 500; line-height: 1.85; margin: 0;
}
.mssc-reco-empty {
	background: var(--mssc-panel); border: 1px dashed rgba(15,155,142,.4);
	border-radius: 12px; padding: 24px; text-align: center;
	color: var(--mssc-ink-dim); font-size: 14px;
}

.mssc-dash .mssc-section-title {
	font-size: 18px; font-weight: 800; letter-spacing: -0.01em;
	margin: 0 0 12px !important;
	color: var(--mssc-navy) !important;
	background: none !important;
	-webkit-text-fill-color: var(--mssc-navy);
}

/* メーラー風リスト：行をクリックで展開して詳細を表示 */
#mssc-reco-list {
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line-strong);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 2px 4px rgba(43,45,66,.06), 0 8px 24px rgba(43,45,66,.06);
}
.mssc-reco-row {
	border-bottom: 1px solid var(--mssc-line);
}
.mssc-reco-row:last-child { border-bottom: 0; }
.mssc-reco-row[open] {
	background: #fff;
}
.mssc-reco-row[open] .mssc-reco-summary-row {
	background: rgba(15,155,142,.12);
	border-bottom: 2px solid var(--mssc-teal);
}

.mssc-reco-summary-row {
	cursor: pointer; list-style: none;
	display: grid;
	grid-template-columns: 78px 88px minmax(120px, 1fr) 108px minmax(180px, 1.8fr) 44px;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	transition: background .12s ease;
}
.mssc-reco-summary-row::-webkit-details-marker { display: none; }
.mssc-reco-row:hover .mssc-reco-summary-row {
	background: rgba(15,155,142,.08);
}

.mssc-reco-col { min-width: 0; }
.mssc-reco-col-date {
	font-size: 12.5px; color: var(--mssc-ink-soft);
	font-feature-settings: "tnum" 1; letter-spacing: .01em;
}
.mssc-reco-col-host {
	font-family: ui-monospace, SFMono-Regular, monospace;
	font-size: 12.5px; color: var(--mssc-ink-dim);
	overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mssc-reco-col-cat {
	font-size: 12px; font-weight: 600;
	color: var(--mssc-ink-dim);
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	padding: 3px 9px; border-radius: 4px;
	display: inline-block;
	text-align: center;
	letter-spacing: .02em;
	max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mssc-reco-row[open] .mssc-reco-col-cat { background: #fff; }
.mssc-reco-col-title {
	font-size: 14px; font-weight: 700; color: var(--mssc-navy);
	letter-spacing: -0.005em; line-height: 1.5;
	overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mssc-reco-col-toggle {
	width: 34px; height: 34px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
	background: rgba(15,155,142,.10);
	color: var(--mssc-teal);
	justify-self: center;
	transition: background-color .15s ease, color .12s ease, transform .12s ease;
}
.mssc-toggle-svg { display: block; }
.mssc-toggle-up { display: none; }
.mssc-reco-row[open] .mssc-toggle-down { display: none; }
.mssc-reco-row[open] .mssc-toggle-up   { display: inline; }
.mssc-reco-row:hover .mssc-reco-col-toggle {
	background: rgba(15,155,142,.20);
	transform: translateY(-1px);
}
.mssc-reco-row[open] .mssc-reco-col-toggle {
	background: var(--mssc-teal);
	color: #fff;
}
.mssc-reco-row[open]:hover .mssc-reco-col-toggle {
	background: var(--mssc-teal-dark);
	transform: translateY(0);
}

.mssc-reco-status {
	display: inline-block; padding: 3px 11px; border-radius: 999px;
	font-weight: 700; font-size: 11.5px; letter-spacing: .04em;
	text-align: center;
}
.mssc-reco-status-pending     { background: var(--mssc-panel-2); color: var(--mssc-ink-soft); }
.mssc-reco-status-in_progress { background: rgba(217,154,0,.12);  color: var(--mssc-yellow); }
.mssc-reco-status-done        { background: rgba(26,158,111,.12); color: var(--mssc-green); }
.mssc-reco-row[open] .mssc-reco-status-pending { background: #fff; }

/* 展開された詳細 */
.mssc-reco-detail {
	padding: 6px 22px 22px 22px;
	border-top: 1px dashed var(--mssc-line);
	background: var(--mssc-panel-2);
}
.mssc-reco-detail-meta {
	font-size: 12.5px; color: var(--mssc-ink-soft); font-weight: 500;
	margin: 14px 0 10px;
}
.mssc-reco-detail-meta strong { color: var(--mssc-ink); }
.mssc-reco-body {
	font-size: 14px; color: var(--mssc-ink); font-weight: 500;
	line-height: 1.9; margin: 0 0 16px;
	white-space: pre-wrap;
}
.mssc-reco-score-line {
	display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
	font-size: 13px; color: var(--mssc-ink-dim);
	background: #fff;
	border: 1px solid var(--mssc-line);
	border-radius: 8px;
	padding: 12px 14px; margin: 0 0 16px;
}
.mssc-reco-score-line strong {
	color: var(--mssc-navy); font-size: 18px; font-weight: 800;
	font-feature-settings: "tnum" 1;
	margin: 0 2px;
}
.mssc-reco-score-label {
	font-size: 12px; color: var(--mssc-ink-soft); font-weight: 600;
}
.mssc-reco-score-arrow { color: var(--mssc-ink-soft); font-weight: 700; }
.mssc-reco-score-pair { display: inline-flex; align-items: baseline; gap: 4px; }
.mssc-reco-score-note {
	font-size: 11.5px; color: var(--mssc-ink-soft); font-weight: 500;
}

.mssc-reco-actions {
	display: flex; justify-content: flex-end; gap: 10px; flex-wrap: wrap;
}
.mssc-reco-done {
	background: var(--mssc-teal); color: #fff; border: none;
	font-weight: 700; font-size: 14px; padding: 10px 24px;
	border-radius: 8px; cursor: pointer;
	transition: background .15s, transform .05s;
}
.mssc-reco-done:hover { background: var(--mssc-teal-dark); }
.mssc-reco-done:active { transform: scale(.98); }
.mssc-reco-done:disabled { opacity: .5; cursor: not-allowed; }
.mssc-reco-reopen {
	background: transparent; color: var(--mssc-ink-dim);
	border: 1px solid var(--mssc-line);
	font-weight: 600; font-size: 13px; padding: 8px 18px;
	border-radius: 8px; cursor: pointer;
	transition: border-color .15s, color .15s;
}
.mssc-reco-reopen:hover { border-color: var(--mssc-teal); color: var(--mssc-teal); }

/* 完了済み行：セクション枠と同じ Teal で塗って白文字反転（外側との色相を統一） */
.mssc-reco-row.mssc-reco-done .mssc-reco-summary-row,
.mssc-reco-row.mssc-reco-done:hover .mssc-reco-summary-row {
	background: var(--mssc-teal);
	color: #fff;
}
.mssc-reco-row.mssc-reco-done[open] .mssc-reco-summary-row {
	background: var(--mssc-teal);
	border-bottom-color: var(--mssc-teal-dark);
}
.mssc-reco-row.mssc-reco-done .mssc-reco-col-date,
.mssc-reco-row.mssc-reco-done .mssc-reco-col-host,
.mssc-reco-row.mssc-reco-done .mssc-reco-col-title {
	color: #fff;
}
.mssc-reco-row.mssc-reco-done .mssc-reco-col-host {
	background: rgba(255,255,255,.15); padding: 2px 8px; border-radius: 4px;
}
.mssc-reco-row.mssc-reco-done .mssc-reco-col-cat {
	background: #fff; color: var(--mssc-teal-dark);
	border-color: #fff; font-weight: 700;
}
/* 完了行：円形トグルを白反転で目立たせる */
.mssc-reco-row.mssc-reco-done .mssc-reco-col-toggle {
	background: rgba(255,255,255,.25);
	color: #fff;
}
.mssc-reco-row.mssc-reco-done:hover .mssc-reco-col-toggle {
	background: rgba(255,255,255,.4);
	transform: translateY(-1px);
}
.mssc-reco-row.mssc-reco-done[open] .mssc-reco-col-toggle {
	background: #fff;
	color: var(--mssc-teal-dark);
	box-shadow: 0 0 0 2px rgba(255,255,255,.5);
}
.mssc-reco-row.mssc-reco-done[open]:hover .mssc-reco-col-toggle {
	background: #fff;
	transform: translateY(0);
}
/* 完了行で open 中の本文部分（白背景）にも対応：トグルは summary 内にいるので problem ではないが念のため */
/* 完了行内のステータスバッジは白文字＋半透明バックに */
.mssc-reco-row.mssc-reco-done .mssc-reco-status-done {
	background: rgba(255,255,255,.22);
	color: #fff;
}

@media (max-width: 880px) {
	.mssc-reco-summary-row {
		grid-template-columns: auto 1fr;
		grid-template-areas:
			"status title"
			"meta meta";
		gap: 8px 12px;
		padding: 14px 16px;
	}
	.mssc-reco-col-status { grid-area: status; }
	.mssc-reco-col-title  { grid-area: title; white-space: normal; }
	.mssc-reco-col-date,
	.mssc-reco-col-host,
	.mssc-reco-col-cat {
		grid-area: meta;
		display: inline-block; margin-right: 8px;
	}
	.mssc-reco-col-toggle { display: none; }
	.mssc-reco-detail { padding: 4px 18px 18px; }
}

/* ========== サイトカード（メイン） ============================
   グリッドレイアウト：
   - 上段：スコア＋メタ ｜ レーダー
   - 下段：アクション（右下）
   PC: スコア＋メタが左、レーダーが右。下に再診断＋詳細トグル。
   モバイル: 縦に積む。 */
.mssc-site-wrap { margin-bottom: 16px; }
.mssc-site-card {
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 14px;
	padding: 24px 26px;
	box-shadow: var(--mssc-shadow-sm);
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-areas:
		"summary radar"
		"actions actions";
	gap: 18px 28px;
	align-items: center;
	transition: box-shadow .18s ease, border-color .18s ease;
}
.mssc-site-card:hover {
	box-shadow: var(--mssc-shadow-md);
	border-color: var(--mssc-line-strong);
}
.mssc-site-summary {
	grid-area: summary;
	display: flex; align-items: center; gap: 22px;
	min-width: 0;
}
.mssc-site-score {
	width: 104px; height: 104px; flex-shrink: 0; border-radius: 50%;
	display: grid; place-items: center;       /* 外枠：縦横とも完全中央寄せ */
	color: #fff; font-feature-settings: "tnum" 1;
	line-height: 1;
	padding: 0 6px;            /* 3桁の100が縁に当たらないよう内側に余白 */
	overflow: hidden;          /* 保険 */
}
.mssc-site-score.mssc-ring-green  { background: var(--mssc-green); }
.mssc-site-score.mssc-ring-yellow { background: var(--mssc-yellow); }
.mssc-site-score.mssc-ring-red    { background: var(--mssc-red); }
.mssc-site-score-inner {
	display: inline-flex; align-items: baseline;  /* 数字と /100 はベースライン揃え */
	letter-spacing: -0.05em;
	line-height: 1;
}
.mssc-site-score-num  { font-size: 30px; font-weight: 800; }
.mssc-site-score-unit { font-size: 11.5px; font-weight: 500; opacity: .85; margin-left: 2px; letter-spacing: 0; }

.mssc-site-meta { flex: 1; min-width: 0; }
.mssc-site-host {
	font-size: 18px; font-weight: 800; color: var(--mssc-navy);
	word-break: break-all; line-height: 1.4;
	letter-spacing: -0.01em;
}
.mssc-site-verdict {
	font-size: 14.5px; color: var(--mssc-ink); font-weight: 600;
	margin-top: 6px; line-height: 1.6;
	display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.mssc-site-sub {
	font-size: 13px; color: var(--mssc-ink-soft); font-weight: 500;
	margin-top: 6px;
}

/* 前回比デルタ（推移バッジ） */
.mssc-delta {
	font-size: 12px; font-weight: 700; letter-spacing: .04em;
	padding: 3px 9px; border-radius: 999px;
	display: inline-flex; align-items: center;
}
.mssc-delta-up   { color: var(--mssc-green);  background: rgba(26,158,111,.10); }
.mssc-delta-down { color: var(--mssc-red);    background: rgba(214,69,69,.10); }
.mssc-delta-zero { color: var(--mssc-ink-soft); background: var(--mssc-panel-2); }

/* レーダー（カード右側）：右ラベルがカード端を越えないよう少し左寄せ */
.mssc-site-radar {
	grid-area: radar;
	width: 200px;
	margin-right: 18px;
}
.mssc-site-radar .mssc-radar-svg { width: 100%; height: auto; display: block; overflow: visible; }
.mssc-site-radar .mssc-radar-label { font-size: 11px; font-weight: 600; }

/* アクション行（下段） */
.mssc-site-actions {
	grid-area: actions;
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; flex-wrap: wrap;
	padding-top: 16px; border-top: 1px solid var(--mssc-line);
}
.mssc-rescan {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--mssc-teal); color: #fff; text-decoration: none;
	font-weight: 700; font-size: 14px;
	padding: 10px 22px; border-radius: 8px;
	transition: background .15s, transform .05s;
}
.mssc-rescan:hover { background: var(--mssc-teal-dark); color: #fff; }
.mssc-rescan:active { transform: scale(.98); }
.mssc-rescan .mssc-arrow { font-size: 15px; line-height: 1; transition: transform .15s; }
.mssc-rescan:hover .mssc-arrow { transform: translateX(3px); }
.mssc-detail-btn {
	margin: 0; background: transparent; border: 0; padding: 4px 0;
	color: var(--mssc-teal); font-size: 13px; font-weight: 700; cursor: pointer;
	transition: color .15s;
}
.mssc-detail-btn:hover { color: var(--mssc-teal-dark); text-decoration: underline; }

/* ========== 過去診断の詳細（時系列） ============================
   各スキャンに「スコア・日時・前回比・チェック一覧・小型レーダー」を表示。
   下に積み重なるほど古くなる。 */
.mssc-detail {
	margin-top: 12px;
	background: var(--mssc-panel-2);
	border: 1px solid var(--mssc-line);
	border-radius: 12px;
	padding: 6px 22px;
}
.mssc-d-scan {
	padding: 18px 0;
	border-bottom: 1px solid var(--mssc-line);
}
.mssc-d-scan:last-child { border-bottom: 0; }

.mssc-d-head {
	display: flex; align-items: center; gap: 14px;
	margin-bottom: 14px;
}
.mssc-d-score {
	width: 44px; height: 44px; border-radius: 50%;
	display: grid; place-items: center;
	color: #fff; font-size: 15px; font-weight: 800; flex-shrink: 0;
	background: #b4bcc5;
	font-feature-settings: "tnum" 1;
}
.mssc-d-score.mssc-ring-green  { background: var(--mssc-green); }
.mssc-d-score.mssc-ring-yellow { background: var(--mssc-yellow); }
.mssc-d-score.mssc-ring-red    { background: var(--mssc-red); }
.mssc-d-head-text { flex: 1; min-width: 0; }
.mssc-d-date {
	font-size: 14px; font-weight: 700; color: var(--mssc-navy);
	font-feature-settings: "tnum" 1;
}
.mssc-d-verdict {
	font-size: 13px; color: var(--mssc-ink-dim); font-weight: 500;
	margin-top: 4px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}

.mssc-d-body {
	display: grid; grid-template-columns: 1fr auto; gap: 18px;
	align-items: start;
}
.mssc-d-checks { list-style: none; margin: 0; padding: 0; min-width: 0; }
.mssc-d-check {
	display: flex; align-items: center; gap: 9px;
	font-size: 13.5px; color: var(--mssc-ink); font-weight: 500;
	padding: 4px 0; line-height: 1.55;
}
.mssc-d-check .mssc-light { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.mssc-d-check .mssc-green  { background: var(--mssc-green); box-shadow: 0 0 0 3px rgba(26,158,111,.10); }
.mssc-d-check .mssc-yellow { background: var(--mssc-yellow); box-shadow: 0 0 0 3px rgba(217,154,0,.10); }
.mssc-d-check .mssc-red    { background: var(--mssc-red); box-shadow: 0 0 0 3px rgba(214,69,69,.10); }
.mssc-d-check .mssc-skip   { background: #b4bcc5; }
.mssc-d-empty { font-size: 14px; color: var(--mssc-ink-dim); padding: 16px 0; }

/* 過去診断の小型レーダー（ラベル無し・形だけで比較） */
.mssc-d-radar {
	width: 150px; flex-shrink: 0;
}
.mssc-d-radar .mssc-radar-svg { width: 100%; height: auto; display: block; }

/* ========== 空状態 ========== */
.mssc-dash-empty {
	text-align: center; padding: 40px 20px;
	color: var(--mssc-ink-dim); font-size: 14px;
	background: var(--mssc-panel);
	border: 1px dashed var(--mssc-line);
	border-radius: 12px;
}

/* ========== 退会エリア（控えめ） ========== */
.mssc-dash-danger {
	margin-top: 36px; padding-top: 22px;
	border-top: 1px dashed var(--mssc-line); text-align: center;
}
.mssc-delete-account {
	background: none; border: 1px solid var(--mssc-line); color: var(--mssc-ink-soft);
	font-size: 13px; font-weight: 600; padding: 9px 20px; border-radius: 8px; cursor: pointer;
	transition: border-color .15s, color .15s;
}
.mssc-delete-account:hover { border-color: var(--mssc-red); color: var(--mssc-red); }
.mssc-delete-account:disabled { opacity: .5; cursor: not-allowed; }

/* ========== 退会確認モーダル ========== */
.mssc-modal-overlay {
	position: fixed; inset: 0; background: rgba(0,0,0,.5);
	display: flex; align-items: center; justify-content: center;
	z-index: 99999; padding: 20px;
}
.mssc-modal {
	background: #fff; border-radius: 14px; padding: 30px;
	max-width: 460px; width: 100%; box-shadow: 0 12px 44px rgba(0,0,0,.25);
	max-height: 90vh; overflow-y: auto;
}
.mssc-modal-title { font-size: 20px; font-weight: 800; color: var(--mssc-navy); margin: 0 0 14px; letter-spacing: -0.01em; }
.mssc-modal-text { font-size: 14px; color: var(--mssc-ink); margin: 0 0 20px; line-height: 1.8; }
.mssc-reason-heading { font-size: 13px; color: var(--mssc-ink-dim); font-weight: 500; margin: 0 0 12px; }
.mssc-reason-list { display: flex; flex-direction: column; gap: 9px; margin: 0 0 4px; }
.mssc-reason-item { font-size: 14px; color: var(--mssc-ink); display: flex; align-items: center; gap: 9px; cursor: pointer; }
.mssc-reason-item input { accent-color: var(--mssc-teal); width: 16px; height: 16px; cursor: pointer; }
.mssc-modal-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 24px; }
.mssc-modal-cancel {
	background: none; border: 1px solid var(--mssc-line); color: var(--mssc-ink-dim);
	font-weight: 700; font-size: 14px; padding: 11px 22px; border-radius: 8px; cursor: pointer;
}
.mssc-modal-cancel:hover { border-color: var(--mssc-ink-dim); }
.mssc-modal-confirm {
	background: var(--mssc-red); border: none; color: #fff;
	font-weight: 700; font-size: 14px; padding: 11px 22px; border-radius: 8px; cursor: pointer;
}
.mssc-modal-confirm:hover { opacity: .9; }
.mssc-modal-confirm:disabled { opacity: .5; cursor: not-allowed; }

/* ========== フッタ・補足 ========== */
.mssc-dash .mssc-legal {
	font-size: 13px; color: var(--mssc-ink-dim);
	font-weight: 500; text-align: center;
	margin: 26px 0 0; line-height: 1.9;
}
.mssc-dash .mssc-legal a { color: var(--mssc-teal); font-weight: 600; }
.mssc-dash .mssc-foot {
	margin-top: 18px; padding-top: 18px;
	border-top: 1px solid var(--mssc-line);
	font-size: 12px; color: var(--mssc-ink-soft);
	letter-spacing: .04em;
}

/* reCAPTCHA バッジ代替開示文（Google 規約必須。バッジを CSS で隠す設定時のみ出力） */
.mssc-dash .mssc-recaptcha-notice {
	font-size: 11px;
	color: var(--mssc-ink-soft);
	text-align: center;
	line-height: 1.8;
	margin: 24px 0 0;
}
.mssc-dash .mssc-recaptcha-notice a {
	color: var(--mssc-teal);
	text-decoration: underline;
}

/* ========== 「上へ戻る」フローティング ========== */
.mssc-dash .mssc-back-top {
	position: fixed; right: 22px; bottom: 22px;
	width: 46px; height: 46px; border-radius: 50%;
	background: var(--mssc-navy); color: #fff; border: none;
	cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
	box-shadow: 0 6px 18px rgba(43,45,66,.22), 0 1px 3px rgba(43,45,66,.18);
	opacity: 0; pointer-events: none; transform: translateY(10px);
	transition: opacity .22s ease, transform .22s ease, background .15s ease;
	z-index: 9999; padding: 0;
}
.mssc-dash .mssc-back-top.mssc-show {
	opacity: 1; pointer-events: auto; transform: translateY(0);
}
.mssc-dash .mssc-back-top:hover {
	background: var(--mssc-teal); transform: translateY(-3px);
}
.mssc-dash .mssc-back-top-icon { width: 18px; height: 18px; display: block; }

/* ========== スマホ対応 ========== */
@media (max-width: 720px) {
	.mssc-dash .mssc-hero-title { font-size: 26px; line-height: 1.4; }
	.mssc-dash .mssc-hero-br { display: none; }
	.mssc-dash .mssc-card { padding: 22px 20px; }
	.mssc-dash .mssc-input-row { flex-direction: column; }
	.mssc-dash .mssc-run { padding: 14px 22px; justify-content: center; }

	.mssc-site-card {
		grid-template-columns: 1fr;
		grid-template-areas:
			"summary"
			"radar"
			"actions";
		padding: 20px 18px;
	}
	.mssc-site-summary { gap: 16px; }
	.mssc-site-score { width: 88px; height: 88px; padding: 0 4px; }
	.mssc-site-score-num { font-size: 26px; }
	.mssc-site-score-unit { font-size: 10.5px; }
	.mssc-site-host { font-size: 16px; }
	.mssc-site-radar { width: 100%; max-width: 240px; margin: 0 auto; }
	.mssc-site-actions { padding-top: 14px; }
	.mssc-rescan { width: 100%; justify-content: center; }

	.mssc-detail { padding: 6px 16px; }
	.mssc-d-body {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.mssc-d-radar { width: 130px; margin: 0 auto; }

	.mssc-dash .mssc-back-top { right: 14px; bottom: 14px; width: 42px; height: 42px; }
}
