/* MintSpark セキュリティ診断 フロントエンド
   ブランドカラー：Teal #0F9B8E / Navy #2B2D42 / SoftWhite #F8F9FA
   設計方針：機能美と上品な余白。AIっぽい派手な装飾は避け、データの可読性を最優先。
   全クラスに mssc- プレフィックス。SWELLスタイルと干渉しない。 */

.mssc-wrap {
	--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;  /* 最も控えめなテキスト：以前より2段濃く（読める濃さに統一） */
	--mssc-green: #1a9e6f;
	--mssc-yellow: #d99a00;
	--mssc-red: #d64545;
	--mssc-green-bg: rgba(26,158,111,.07);
	--mssc-yellow-bg: rgba(217,154,0,.07);
	--mssc-red-bg: rgba(214,69,69,.07);
	--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.7;
	font-family: inherit;
	-webkit-font-smoothing: antialiased;
}
.mssc-wrap *, .mssc-wrap *::before, .mssc-wrap *::after { box-sizing: border-box; }

/* ========== ヘッダ ========== */
.mssc-header { margin-bottom: 34px; }
.mssc-header-top {
	display: flex; justify-content: space-between; align-items: center;
	gap: 12px; flex-wrap: wrap; margin-bottom: 22px;
}
.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-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-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-save-toplink:hover { border-color: var(--mssc-teal); color: var(--mssc-teal); }

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

/* SWELL装飾の打ち消し（プラグイン領域に限定） */
.mssc-wrap h1, .mssc-wrap h2, .mssc-wrap h3 {
	border: 0 !important;
	background: none !important;
	box-shadow: none !important;
	margin-top: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.mssc-wrap h1::before, .mssc-wrap h1::after,
.mssc-wrap h2::before, .mssc-wrap h2::after,
.mssc-wrap h3::before, .mssc-wrap h3::after {
	display: none !important;
	content: none !important;
	border: 0 !important;
	background: none !important;
}

/* ========== 入力カード ========== */
.mssc-card {
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 12px;
	padding: 28px 28px 24px;
	margin-bottom: 22px;
	box-shadow: var(--mssc-shadow-sm);
}
.mssc-field-label {
	font-size: 14px; font-weight: 700; letter-spacing: .02em;
	margin-bottom: 10px; display: block; color: var(--mssc-ink);
}
.mssc-input-row { display: flex; gap: 10px; }
.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; /* iOSズーム抑止 */
	font-weight: 500;
	padding: 14px 16px; outline: none;
	transition: border-color .15s, box-shadow .15s, background .15s;
}
.mssc-input:focus {
	border-color: var(--mssc-teal);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(15,155,142,.12);
}
.mssc-input::placeholder { color: #a5acb5; font-weight: 400; }

.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 26px; cursor: pointer; white-space: nowrap;
	transition: background .15s, transform .05s;
}
.mssc-run:hover { background: #1a1c30; }
.mssc-run:active { transform: scale(.98); }
.mssc-run:disabled { opacity: .45; cursor: not-allowed; }
.mssc-run-arrow {
	font-size: 16px; line-height: 1; transition: transform .15s;
}
.mssc-run:hover .mssc-run-arrow { transform: translateX(3px); }

/* 同意 */
.mssc-consent {
	display: flex; gap: 12px; align-items: flex-start;
	margin-top: 20px; padding: 14px 16px;
	background: var(--mssc-panel-2);
	border: 1px solid var(--mssc-line);
	border-radius: 8px;
	font-size: 13.5px; color: var(--mssc-ink-dim);
	font-weight: 500; line-height: 1.8;
}
.mssc-consent input {
	margin-top: 3px; accent-color: var(--mssc-teal); cursor: pointer;
	width: 18px; height: 18px; flex-shrink: 0;
}
.mssc-consent label { cursor: pointer; }
.mssc-consent strong { color: var(--mssc-ink); font-weight: 700; }
.mssc-consent a { color: var(--mssc-teal); }

.mssc-err {
	color: var(--mssc-red); font-size: 13.5px; font-weight: 500;
	margin-top: 12px; display: none;
}

/* ========== ローディング ========== */
.mssc-loading { display: none; text-align: center; padding: 40px 0 20px; }
.mssc-loading.mssc-show { display: block; }
.mssc-scan-line {
	font-size: 13.5px; color: var(--mssc-ink-dim);
	margin-top: 18px; min-height: 20px; letter-spacing: .02em;
}
.mssc-spinner {
	width: 32px; height: 32px; margin: 0 auto;
	border: 2px solid var(--mssc-line);
	border-top-color: var(--mssc-teal);
	border-radius: 50%;
	animation: mssc-spin .8s linear infinite;
}
@keyframes mssc-spin { to { transform: rotate(360deg); } }

/* ========== 結果 ========== */
.mssc-results { display: none; }
.mssc-results.mssc-show { display: block; }

/* ---- スコアカード ---- */
.mssc-score-card {
	display: flex; align-items: center; gap: 36px;
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 14px;
	padding: 36px 32px;
	margin-bottom: 28px;
	box-shadow: var(--mssc-shadow-md);
	opacity: 0; transform: translateY(8px);
	animation: mssc-rise .5s ease forwards;
}
@keyframes mssc-rise { to { opacity: 1; transform: none; } }

.mssc-score-ring {
	width: 184px; height: 184px; flex-shrink: 0; border-radius: 50%;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	position: relative;
	background: #eef0f3;
}
.mssc-score-ring::after {
	content: ''; position: absolute; inset: 6px; border-radius: 50%;
	background: var(--mssc-panel);
}
.mssc-score-number {
	position: relative; z-index: 1;
	display: flex; align-items: baseline; justify-content: center;
	max-width: 92%;            /* 内側円の幅を超えないようガード */
	color: var(--mssc-navy);
	font-feature-settings: "tnum" 1;
	letter-spacing: -0.05em;   /* 100 などの3桁が円内に収まるよう詰める */
	line-height: 1;
}
.mssc-score-number #mssc-score-num {
	font-size: 66px; font-weight: 800;
}
.mssc-score-unit {
	font-size: 18px; font-weight: 500; color: var(--mssc-ink-soft);
	margin-left: 3px; letter-spacing: 0;
}
.mssc-score-caption {
	position: relative; z-index: 1;
	font-size: 11.5px; font-weight: 600; letter-spacing: .14em;
	color: var(--mssc-ink-soft);
	margin-top: 8px;
}
.mssc-ring-green .mssc-score-number #mssc-score-num { color: var(--mssc-green); }
.mssc-ring-yellow .mssc-score-number #mssc-score-num { color: var(--mssc-yellow); }
.mssc-ring-red .mssc-score-number #mssc-score-num { color: var(--mssc-red); }

.mssc-score-meta { flex: 1; min-width: 0; }
.mssc-score-meta h3 {
	font-size: 24px; font-weight: 800;
	letter-spacing: -0.01em;
	margin: 0 !important; color: var(--mssc-navy);
}
.mssc-score-meta p {
	font-size: 15px; color: var(--mssc-ink-dim);
	font-weight: 500; margin: 8px 0 0;
}
.mssc-score-target {
	font-size: 13px; color: var(--mssc-ink-soft);
	margin-top: 14px; word-break: break-all;
	padding-top: 12px; border-top: 1px solid var(--mssc-line);
}

/* ---- レーダーチャート ---- */
.mssc-radar-card {
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 14px;
	padding: 22px 24px 18px;
	margin-bottom: 28px;
	box-shadow: var(--mssc-shadow-sm);
	opacity: 0; transform: translateY(8px);
	animation: mssc-rise .5s ease forwards;
	animation-delay: 80ms;
}
.mssc-radar-head {
	display: flex; justify-content: space-between; align-items: baseline;
	gap: 12px; flex-wrap: wrap; margin-bottom: 4px;
}
.mssc-radar-head h4 {
	font-size: 15px; font-weight: 800;
	letter-spacing: -0.005em;
	margin: 0 !important; color: var(--mssc-navy);
	padding: 0 !important; border: 0 !important;
}
.mssc-radar-hint {
	font-size: 12px; color: var(--mssc-ink-soft);
	letter-spacing: .04em;
}
.mssc-radar-canvas {
	max-width: 380px; margin: 0 auto;
}
.mssc-radar-svg { width: 100%; height: auto; display: block; overflow: visible; }
.mssc-radar-grid { fill: none; stroke: var(--mssc-line); stroke-width: 1; }
.mssc-radar-grid.mssc-radar-grid-outer { stroke: var(--mssc-line-strong); }
.mssc-radar-axis { stroke: var(--mssc-line); stroke-width: 1; }
.mssc-radar-data {
	fill: rgba(15,155,142,.10);
	stroke: var(--mssc-teal);
	stroke-width: 1.5;
	stroke-linejoin: round;
}
.mssc-radar-vertex {
	cursor: pointer;
	transition: r .12s ease, stroke-width .12s ease;
	stroke: #fff; stroke-width: 1.5;
}
.mssc-radar-vertex:hover { stroke-width: 2.5; }
.mssc-radar-vertex:focus { outline: none; stroke-width: 2.5; }
.mssc-radar-label {
	cursor: pointer;
	font-size: 12px; font-weight: 600;
	fill: var(--mssc-ink-dim);
	transition: fill .12s ease;
	user-select: none;
}
.mssc-radar-label:hover { fill: var(--mssc-teal); }

/* ---- 個別項目グリッド ---- */
.mssc-item-grid {
	display: grid; grid-template-columns: 1fr; gap: 12px;
}
@media (min-width: 720px) {
	.mssc-item-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
}

.mssc-item {
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 10px;
	padding: 18px 20px;
	position: relative;
	display: flex;                 /* impact を下端に張り付かせるために縦 flex */
	flex-direction: column;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	opacity: 0; transform: translateY(6px);
	animation: mssc-rise .4s ease forwards;
	animation-delay: var(--mssc-delay, 0ms);
}
.mssc-item:hover {
	transform: translateY(-2px);
	box-shadow: var(--mssc-shadow-md);
	border-color: var(--mssc-line-strong);
}
.mssc-item::before {
	content: ''; position: absolute; left: 0; top: 18px; bottom: 18px;
	width: 3px; border-radius: 0 2px 2px 0;
	background: var(--mssc-line);
}
.mssc-item.mssc-s-green::before { background: var(--mssc-green); }
.mssc-item.mssc-s-yellow::before { background: var(--mssc-yellow); }
.mssc-item.mssc-s-red::before { background: var(--mssc-red); }
.mssc-item.mssc-s-skip { opacity: .72; }

/* レーダーからジャンプしたときのフラッシュ
   親要素の mssc-rise アニメーションと競合させないよう ::after に分離。
   2.6秒かけて、リング拡張 → 薄い塗り維持 → フェードアウトで認識しやすく。 */
.mssc-item::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 10px;
	pointer-events: none;
	opacity: 0;
	background-color: transparent;
}
.mssc-item.mssc-item-flash::after {
	animation: mssc-item-flash var(--mssc-flash-dur, 2.6s) ease-out;
}
@keyframes mssc-item-flash {
	0%   { opacity: 1; background-color: rgba(15,155,142,.16); box-shadow: 0 0 0 0   rgba(15,155,142,.75); }
	18%  { opacity: 1; background-color: rgba(15,155,142,.14); box-shadow: 0 0 0 10px rgba(15,155,142,.35); }
	70%  { opacity: 1; background-color: rgba(15,155,142,.10); box-shadow: 0 0 0 10px rgba(15,155,142,.20); }
	100% { opacity: 0; background-color: rgba(15,155,142,0);   box-shadow: 0 0 0 10px rgba(15,155,142,0); }
}

.mssc-item-head {
	display: flex; align-items: center; gap: 10px;
	flex-wrap: nowrap;
	padding-right: 96px;            /* 右上 absolute のタグ用スペース。長いカテゴリ名（REPUTATION 等）に対応 */
	margin-bottom: 10px;
	min-height: 22px;
}
.mssc-light {
	width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.mssc-light.mssc-green { background: var(--mssc-green); box-shadow: 0 0 0 3px var(--mssc-green-bg); }
.mssc-light.mssc-yellow { background: var(--mssc-yellow); box-shadow: 0 0 0 3px var(--mssc-yellow-bg); }
.mssc-light.mssc-red { background: var(--mssc-red); box-shadow: 0 0 0 3px var(--mssc-red-bg); }
.mssc-light.mssc-skip { background: #b4bcc5; }
.mssc-item-title {
	font-size: 15.5px; font-weight: 700; color: var(--mssc-navy);
	letter-spacing: -0.005em; line-height: 1.5;
}
.mssc-item-tag {
	position: absolute;             /* タイトル長に依存せず常に右上に固定 */
	top: 16px;
	right: 16px;
	margin-left: 0;
	font-size: 10px; letter-spacing: .10em; font-weight: 600;
	color: var(--mssc-ink-soft);
	padding: 2px 7px; border-radius: 3px;
	background: var(--mssc-panel-2);
	border: 1px solid var(--mssc-line);
	white-space: nowrap;
	max-width: 84px;
	overflow: hidden; text-overflow: ellipsis;
}
.mssc-item-detail {
	font-size: 14px; color: var(--mssc-ink); font-weight: 500;
	line-height: 1.75; margin-top: 8px;
}
.mssc-item-impact {
	font-size: 13.5px; color: var(--mssc-ink); font-weight: 500;
	line-height: 1.8;
	margin-top: auto;               /* 2列グリッドで各カードの下端に揃える */
	padding: 11px 13px;
	border-radius: 7px;
}
/* impact がある時だけ detail に下余白を付け、auto による詰まりを防ぐ */
.mssc-item:has(.mssc-item-impact) .mssc-item-detail { margin-bottom: 12px; }
.mssc-s-green .mssc-item-impact { background: var(--mssc-green-bg); }
.mssc-s-yellow .mssc-item-impact { background: var(--mssc-yellow-bg); }
.mssc-s-red .mssc-item-impact { background: var(--mssc-red-bg); }
.mssc-item-impact b { font-weight: 700; }

/* ---- CTA（控えめに） ---- */
.mssc-cta {
	margin-top: 30px;
	background: var(--mssc-panel);
	border: 1px solid var(--mssc-line);
	border-radius: 12px;
	padding: 28px 28px;
	text-align: center;
	box-shadow: var(--mssc-shadow-sm);
}
.mssc-cta h3 {
	font-size: 18px; font-weight: 800;
	letter-spacing: -0.01em;
	margin: 0 !important; color: var(--mssc-navy);
	padding-bottom: 0 !important;
	border: 0 !important;
}
.mssc-cta p {
	font-size: 14px; color: var(--mssc-ink-dim);
	font-weight: 500; line-height: 1.9;
	margin: 14px 0 22px;
}
.mssc-cta-btn {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--mssc-teal); color: #fff; text-decoration: none;
	font-weight: 700; font-size: 15px;
	padding: 14px 30px; border-radius: 8px;
	transition: background .15s, transform .05s;
}
.mssc-cta-btn:hover { background: var(--mssc-teal-dark); color: #fff; }
.mssc-cta-btn:active { transform: scale(.98); }
.mssc-cta-btn::after {
	content: '→'; font-size: 16px; line-height: 1;
	transition: transform .15s;
}
.mssc-cta-btn:hover::after { transform: translateX(3px); }

/* ---- 履歴保存導線（未ログイン時） ---- */
.mssc-save-cta {
	margin-top: 16px; padding: 18px 20px; text-align: center;
	background: transparent;
	border: 1px dashed var(--mssc-line);
	border-radius: 10px;
}
.mssc-save-cta p {
	font-size: 14px; color: var(--mssc-ink-dim);
	font-weight: 500; margin: 0 0 14px; line-height: 1.8;
}
.mssc-save-link {
	display: inline-block;
	background: transparent; border: 1px solid var(--mssc-teal);
	color: var(--mssc-teal); text-decoration: none;
	font-weight: 700; font-size: 14px;
	padding: 10px 22px; border-radius: 8px;
	transition: background .15s, color .15s;
}
.mssc-save-link:hover { background: var(--mssc-teal); color: #fff; }

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

/* 管理画面で「reCAPTCHA バッジを非表示」を ON にしたページ用ルール。
   診断ページのみに body.mssc-hide-recaptcha が付くので、他ページのバッジには影響しない。
   ※ Google 規約上、バッジを隠す場合は所定の開示文を本文中に明示する必要がある。
     開示文は templates/form.php・dashboard.php の本文末尾に出力している。 */
body.mssc-hide-recaptcha .grecaptcha-badge {
	visibility: hidden !important;
}

/* reCAPTCHA バッジ代替開示文（Google 規約必須） */
.mssc-recaptcha-notice {
	font-size: 11px;
	color: var(--mssc-ink-soft);
	text-align: center;
	line-height: 1.8;
	margin: 28px 0 0;
}
.mssc-recaptcha-notice a {
	color: var(--mssc-teal);
	text-decoration: underline;
}

/* ========== フローティング：上へ戻る ========== */
.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-back-top.mssc-show {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}
.mssc-back-top:hover {
	background: var(--mssc-teal);
	transform: translateY(-3px);
}
.mssc-back-top:active { transform: translateY(-1px); }
.mssc-back-top:focus-visible {
	outline: 2px solid var(--mssc-teal);
	outline-offset: 3px;
}
.mssc-back-top-icon {
	width: 18px; height: 18px;
	display: block;
}
@media (max-width: 600px) {
	.mssc-back-top { right: 14px; bottom: 14px; width: 42px; height: 42px; }
}

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

	.mssc-score-card {
		flex-direction: column; text-align: center; gap: 22px;
		padding: 28px 22px;
	}
	.mssc-score-ring { width: 156px; height: 156px; }
	.mssc-score-number #mssc-score-num { font-size: 62px; }
	.mssc-score-target { word-break: break-all; }

	.mssc-cta { padding: 24px 20px; }
	.mssc-cta-btn { padding: 14px 22px; }

	.mssc-radar-card { padding: 18px 16px 14px; }
	.mssc-radar-canvas { max-width: 320px; }
	.mssc-radar-label { font-size: 11.5px; }
}
