/* =========================================================
   Bloomy マイページ (my-account) — 旅行中に安心して使えるUI
   モバイルファースト / 余白・階層・一貫性で大手サービスの完成度へ
   ========================================================= */
.bloomy-acct-page {
	--a-blue: #1f6fff;
	--a-ink: #1f2a44;
	--a-sub: #6b7891;
	--a-line: #eef1f8;
	background: #f6f8fc;
	min-height: 60vh;
	padding: 28px 16px 64px;
}
.bloomy-acct {
	max-width: 760px;
	margin: 0 auto;
	color: var(--a-ink);
}

/* ---- ログインゲート ---- */
.bloomy-acct-login {
	max-width: 420px;
	margin: 24px auto;
	background: #fff;
	border: 1px solid var(--a-line);
	border-radius: 22px;
	padding: 36px 28px;
	text-align: center;
	box-shadow: 0 10px 30px -18px rgba(31, 42, 68, .3);
}
.bloomy-acct-login__flower img { display: inline-block; }
.bloomy-acct-login__title { font-size: 1.4rem; font-weight: 800; margin: 12px 0 6px; }
.bloomy-acct-login__lead { color: var(--a-sub); font-size: .92rem; line-height: 1.7; margin: 0 0 22px; }
.bloomy-acct-login__benefits {
	list-style: none; padding: 0; margin: 22px 0 0; text-align: left;
	display: flex; flex-direction: column; gap: 10px;
}
.bloomy-acct-login__benefits li {
	position: relative; padding-left: 26px; font-size: .9rem; color: #41506e;
}
.bloomy-acct-login__benefits li::before {
	content: ""; position: absolute; left: 4px; top: 4px;
	width: 6px; height: 11px; border-right: 2px solid #1faa66; border-bottom: 2px solid #1faa66;
	transform: rotate(45deg);
}

/* Google ボタン（大） */
.bloomy-google-btn--lg {
	display: inline-flex; align-items: center; justify-content: center; gap: 10px;
	width: 100%; height: 52px; border-radius: 14px;
	border: 1px solid #e2e8f3; background: #fff; color: #2b3a5b;
	font-size: 1rem; font-weight: 700; text-decoration: none;
	box-shadow: 0 6px 16px -8px rgba(31, 42, 68, .25);
	transition: background .15s ease, box-shadow .15s ease;
}
.bloomy-google-btn--lg:hover { background: #f7faff; box-shadow: 0 10px 22px -10px rgba(31, 42, 68, .32); }

/* ---- 見出し / サマリ ---- */
.bloomy-acct__head { margin: 6px 0 22px; }
.bloomy-acct__greet { font-size: 1.5rem; font-weight: 800; margin: 0 0 16px; }
.bloomy-acct__summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.bloomy-acct__stat {
	background: #fff; border: 1px solid var(--a-line); border-radius: 16px;
	padding: 16px; display: flex; flex-direction: column; gap: 2px;
	box-shadow: 0 6px 18px -16px rgba(31, 42, 68, .4);
}
.bloomy-acct__stat-num { font-size: 1.8rem; font-weight: 800; color: var(--a-blue); line-height: 1.1; font-variant-numeric: tabular-nums; }
.bloomy-acct__stat-label { font-size: .82rem; color: var(--a-sub); font-weight: 600; }
.bloomy-acct__stat--topup .bloomy-acct__stat-num { color: #1faa66; }
.bloomy-acct__stat--attention .bloomy-acct__stat-num { color: #d99100; }

/* ---- eSIM カード ---- */
.bloomy-acct-cards { display: flex; flex-direction: column; gap: 16px; }
.bloomy-acct-card {
	background: #fff; border: 1px solid var(--a-line); border-radius: 20px;
	padding: 18px; box-shadow: 0 10px 26px -20px rgba(31, 42, 68, .4);
}
.bloomy-acct-card.is-low { border-color: #ffd9cf; box-shadow: 0 10px 26px -18px rgba(240, 116, 74, .4); }
.bloomy-acct-card__top { display: flex; align-items: center; gap: 12px; }
.bloomy-acct-card__flag { font-size: 1.7rem; line-height: 1; flex: 0 0 auto; }
.bloomy-acct-card__titles { flex: 1 1 auto; min-width: 0; }
.bloomy-acct-card__country { font-size: 1.05rem; font-weight: 800; margin: 0; }
.bloomy-acct-card__plan { font-size: .82rem; color: var(--a-sub); margin: 2px 0 0; }

.bloomy-acct-status {
	flex: 0 0 auto; font-size: .72rem; font-weight: 700; padding: 5px 10px; border-radius: 999px;
}
.bloomy-acct-status--active   { background: #e7f7ef; color: #1faa66; }
.bloomy-acct-status--before   { background: #eef2fb; color: #5a6b8c; }
.bloomy-acct-status--low      { background: #fff2ec; color: #f0744a; }
.bloomy-acct-status--expiring { background: #fff5e6; color: #d99100; }
.bloomy-acct-status--expired  { background: #f1f2f5; color: #9aa3b2; }
.bloomy-acct-status--topup    { background: #eaf1ff; color: #1f6fff; }

/* 本体: ドーナツ + メタ */
.bloomy-acct-card__body { display: flex; align-items: center; gap: 18px; margin: 16px 0 4px; }
.bloomy-acct-donut { position: relative; flex: 0 0 auto; width: 120px; height: 120px; }
.bloomy-acct-donut__track { stroke: #eef1f8; }
.bloomy-acct-donut__val { stroke: #1f6fff; transition: stroke-dasharray .5s ease; }
.bloomy-acct-donut.is-low .bloomy-acct-donut__val { stroke: #f0a44a; }
.bloomy-acct-donut.is-critical .bloomy-acct-donut__val { stroke: #f0744a; }
.bloomy-acct-donut.is-unlimited .bloomy-acct-donut__val { stroke: #1faa66; }
.bloomy-acct-donut__center {
	position: absolute; inset: 0; display: flex; flex-direction: column;
	align-items: center; justify-content: center; text-align: center;
}
.bloomy-acct-donut__big { font-size: .98rem; font-weight: 800; color: var(--a-ink); line-height: 1.15; }
.bloomy-acct-donut.is-unlimited .bloomy-acct-donut__big { font-size: 1.7rem; }
.bloomy-acct-donut__sub { font-size: 1.1rem; font-weight: 800; color: var(--a-blue); }
.bloomy-acct-donut.is-low .bloomy-acct-donut__sub { color: #f0a44a; }
.bloomy-acct-donut.is-critical .bloomy-acct-donut__sub { color: #f0744a; }
.bloomy-acct-donut.is-unlimited .bloomy-acct-donut__sub { font-size: .82rem; color: #1faa66; }

.bloomy-acct-card__meta { flex: 1 1 auto; min-width: 0; }
.bloomy-acct-card__usage { font-size: .82rem; color: var(--a-sub); margin: 0 0 8px; }
.bloomy-acct-card__days strong { font-size: 1.15rem; font-weight: 800; color: var(--a-ink); }
.bloomy-acct-card__days span { display: block; font-size: .78rem; color: var(--a-sub); margin-top: 3px; }

/* アクション */
.bloomy-acct-card__actions { display: flex; gap: 10px; margin-top: 14px; }
.bloomy-acct-btn {
	flex: 1 1 0; text-align: center; font-size: .9rem; font-weight: 700;
	padding: 12px; border-radius: 12px; cursor: pointer; text-decoration: none;
	transition: background .15s ease, box-shadow .15s ease, transform .1s ease; border: 0;
}
.bloomy-acct-btn--ghost { background: #f3f6fc; color: var(--a-ink); border: 1px solid var(--a-line); }
.bloomy-acct-btn--ghost:hover { background: #eaf0fb; }
.bloomy-acct-btn--primary { background: var(--a-blue); color: #fff; box-shadow: 0 6px 14px -6px rgba(31, 111, 255, .55); }
.bloomy-acct-btn--primary:hover { background: #1a5fe0; }
.bloomy-acct-btn--primary.is-emphasized { background: #f0744a; box-shadow: 0 6px 16px -6px rgba(240, 116, 74, .6); animation: bloomyPulse 1.8s ease-in-out infinite; }
@keyframes bloomyPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.02); } }

/* ---- 空状態 ---- */
.bloomy-acct-empty {
	background: #fff; border: 1px solid var(--a-line); border-radius: 22px;
	padding: 48px 24px; text-align: center; box-shadow: 0 10px 30px -20px rgba(31, 42, 68, .35);
}
.bloomy-acct-empty__flower { opacity: .9; margin-bottom: 8px; }
.bloomy-acct-empty h2 { font-size: 1.2rem; font-weight: 800; margin: 4px 0 6px; }
.bloomy-acct-empty p { color: var(--a-sub); margin: 0 0 20px; line-height: 1.7; }
.bloomy-acct-empty__cta {
	display: inline-block; background: var(--a-blue); color: #fff; font-weight: 700;
	padding: 13px 30px; border-radius: 999px; text-decoration: none;
	box-shadow: 0 8px 18px -8px rgba(31, 111, 255, .6);
}
.bloomy-acct-empty__cta:hover { background: #1a5fe0; }

.bloomy-acct__note { text-align: center; color: #9aa6bd; font-size: .76rem; margin: 26px 0 0; }

/* ---- QR モーダル ---- */
/* ---- 詳細パネル（QR / SM-DP+ / Activation Code / 手順 / アクション） ---- */
.bloomy-acct-detail { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 18px; }
.bloomy-acct-detail[hidden] { display: none; }
.bloomy-acct-detail__overlay { position: absolute; inset: 0; background: rgba(31, 42, 68, .5); }
.bloomy-acct-detail__box {
	position: relative; background: #fff; border-radius: 20px; padding: 26px 22px 22px;
	max-width: 380px; width: 100%; max-height: 90vh; overflow-y: auto; -webkit-overflow-scrolling: touch;
	text-align: center; box-shadow: 0 24px 60px -20px rgba(31, 42, 68, .5);
}
.bloomy-acct-detail__close {
	position: absolute; top: 10px; right: 12px; border: 0; background: transparent;
	font-size: 1.6rem; line-height: 1; color: #9aa6bd; cursor: pointer;
}
.bloomy-acct-detail__title { font-size: 1rem; font-weight: 800; margin: 0 0 14px; }
.bloomy-acct-detail__qr img { width: 200px; height: 200px; border: 1px solid var(--a-line); border-radius: 12px; }
.bloomy-acct-detail__note { font-size: .82rem; color: var(--a-sub); margin: 12px 0 16px; line-height: 1.6; }

/* 手動設定 */
.bloomy-acct-detail__manual { text-align: left; background: #f6f9ff; border: 1px solid var(--a-line); border-radius: 14px; padding: 14px; margin: 0 0 14px; }
.bloomy-acct-detail__manual-title { font-size: .82rem; font-weight: 800; color: var(--a-ink); margin: 0 0 10px; }
.bloomy-acct-detail__field { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 4px 10px; }
.bloomy-acct-detail__field + .bloomy-acct-detail__field { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--a-line); }
.bloomy-acct-detail__flabel { grid-column: 1 / -1; font-size: .72rem; color: var(--a-sub); font-weight: 700; }
.bloomy-acct-detail__fval { font-size: .8rem; color: var(--a-ink); word-break: break-all; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.bloomy-acct-detail__copy {
	justify-self: end; border: 1px solid #cfe0ff; background: #fff; color: var(--a-blue);
	border-radius: 999px; padding: 5px 12px; font-size: .74rem; font-weight: 800; cursor: pointer; white-space: nowrap;
}
.bloomy-acct-detail__copy:hover { background: #f2f7ff; }

/* 設定手順アコーディオン */
.bloomy-acct-detail__steps { text-align: left; border: 1px solid var(--a-line); border-radius: 12px; padding: 0 14px; margin: 0 0 10px; }
.bloomy-acct-detail__steps > summary { list-style: none; cursor: pointer; padding: 13px 0; font-size: .88rem; font-weight: 700; color: var(--a-ink); position: relative; }
.bloomy-acct-detail__steps > summary::-webkit-details-marker { display: none; }
.bloomy-acct-detail__steps > summary::after { content: ""; position: absolute; right: 2px; top: 50%; width: 8px; height: 8px; border-right: 2px solid #b6c2d8; border-bottom: 2px solid #b6c2d8; transform: translateY(-65%) rotate(45deg); transition: transform .2s ease; }
.bloomy-acct-detail__steps[open] > summary::after { transform: translateY(-35%) rotate(-135deg); }
.bloomy-acct-detail__steps ol { margin: 0 0 14px; padding: 0 0 0 18px; }
.bloomy-acct-detail__steps li { font-size: .82rem; color: var(--a-sub); line-height: 1.7; }

/* 詳細パネル下部アクション */
.bloomy-acct-detail__actions { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.bloomy-acct-detail__act {
	display: block; width: 100%; text-align: center; text-decoration: none;
	background: #f3f6fc; border: 1px solid var(--a-line); border-radius: 10px;
	padding: 11px 12px; font-size: .85rem; font-weight: 700; color: var(--a-ink); cursor: pointer;
}
.bloomy-acct-detail__act:hover { background: #eaf0fb; color: var(--a-blue); }

body.bloomy-detail-open { overflow: hidden; }

/* ---- PC: カードを少しゆったり ---- */
@media (min-width: 640px) {
	.bloomy-acct__greet { font-size: 1.7rem; }
	.bloomy-acct-card { padding: 22px; }
}

/* =========================================================
   Phase1 追加: 状態メッセージ / 空状態サブ導線 / サポート / 留学CTA
   ========================================================= */

/* カード内 状態メッセージ（控えめ・状態色） */
.bloomy-acct-card__msg { font-size: .8rem; line-height: 1.5; margin: 8px 0 0; color: var(--a-sub); }
.bloomy-acct-card__msg--active   { color: #1faa66; }
.bloomy-acct-card__msg--low      { color: #f0744a; }
.bloomy-acct-card__msg--expiring { color: #d99100; }
.bloomy-acct-card__msg--expired  { color: #9aa3b2; }
.bloomy-acct-card__msg--before,
.bloomy-acct-card__msg--topup    { color: var(--a-sub); }

/* 空状態: 留学サブ導線（テキストリンク） */
.bloomy-acct-empty__sub {
	display: inline-block; margin-top: 14px;
	font-size: .85rem; font-weight: 700; color: var(--a-blue);
	text-decoration: none; border-bottom: 1px solid rgba(31, 111, 255, .35); padding-bottom: 1px;
}
.bloomy-acct-empty__sub:hover { border-bottom-color: var(--a-blue); }

/* セクション見出し（下部共通） */
.bloomy-acct-sec-title { font-size: 1.02rem; font-weight: 800; margin: 0 0 6px; color: var(--a-ink); }

/* サポート導線 */
.bloomy-acct-support {
	margin: 30px 0 0; background: #fff; border: 1px solid var(--a-line);
	border-radius: 16px; padding: 20px 18px;
}
.bloomy-acct-support__lead { font-size: .85rem; color: var(--a-sub); line-height: 1.6; margin: 0 0 12px; }
.bloomy-acct-support__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.bloomy-acct-support__list li + li { border-top: 1px solid var(--a-line); }
.bloomy-acct-support__list a,
.bloomy-acct-support__list button {
	display: flex; align-items: center; justify-content: space-between; gap: 10px;
	width: 100%; text-align: left; background: transparent; border: 0; cursor: pointer;
	padding: 13px 2px; font-size: .9rem; font-weight: 700; color: var(--a-ink); text-decoration: none;
}
.bloomy-acct-support__list a::after,
.bloomy-acct-support__list button::after {
	content: ""; flex: 0 0 auto; width: 8px; height: 8px;
	border-right: 2px solid #c2ccde; border-top: 2px solid #c2ccde; transform: rotate(45deg);
}
.bloomy-acct-support__list a:hover,
.bloomy-acct-support__list button:hover { color: var(--a-blue); }

/* 留学相談CTA（サブ導線・淡いブルー帯） */
.bloomy-acct-abroad {
	margin: 16px 0 0; background: linear-gradient(180deg, #f4f8ff, #eef4ff);
	border: 1px solid #e0eaff; border-radius: 16px; padding: 20px 18px;
	display: flex; flex-direction: column; gap: 14px;
}
.bloomy-acct-abroad__lead { font-size: .85rem; color: #4a5a7a; line-height: 1.7; margin: 6px 0 0; }
.bloomy-acct-abroad__cta {
	align-self: flex-start; display: inline-flex; align-items: center; gap: 6px;
	background: #fff; color: var(--a-blue); border: 1px solid #cfe0ff;
	border-radius: 999px; padding: 10px 18px; font-size: .88rem; font-weight: 800; text-decoration: none;
	box-shadow: 0 6px 16px -10px rgba(31, 111, 255, .4);
}
.bloomy-acct-abroad__cta:hover { background: #f7faff; }

@media (min-width: 640px) {
	.bloomy-acct-abroad { flex-direction: row; align-items: center; justify-content: space-between; }
	.bloomy-acct-abroad__cta { align-self: center; flex: 0 0 auto; }
}

/* アニメーション方針: 動きを減らす設定のユーザーには pulse/transition を抑止（マイページ内に限定） */
@media (prefers-reduced-motion: reduce) {
	.bloomy-acct-page *,
	.bloomy-acct-page *::before,
	.bloomy-acct-page *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
	.bloomy-acct-btn--primary.is-emphasized { animation: none !important; }
}

/* ---- タブ（マイeSIM / 注文履歴）---- */
.bloomy-acct-tabs { display: flex; gap: 2px; margin: 0 0 18px; border-bottom: 1px solid var(--a-line); }
.bloomy-acct-tab { padding: 10px 14px; font-size: .9rem; font-weight: 700; color: var(--a-sub); text-decoration: none; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.bloomy-acct-tab.is-active { color: var(--a-blue); border-bottom-color: var(--a-blue); }
.bloomy-acct-tab:hover { color: var(--a-ink); }

/* ---- 注文履歴 ---- */
.bloomy-acct-orders { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.bloomy-acct-order { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--a-line); border-radius: 14px; padding: 14px 16px; }
.bloomy-acct-order__flag { font-size: 1.5rem; line-height: 1; flex: 0 0 auto; }
.bloomy-acct-order__main { flex: 1 1 auto; min-width: 0; }
.bloomy-acct-order__plan { font-size: .92rem; font-weight: 800; color: var(--a-ink); margin: 0; }
.bloomy-acct-order__meta { font-size: .76rem; color: var(--a-sub); margin: 3px 0 0; }
.bloomy-acct-order__right { flex: 0 0 auto; text-align: right; }
.bloomy-acct-order__price { display: block; font-size: .92rem; font-weight: 800; color: var(--a-ink); }
.bloomy-acct-order__status { display: inline-block; margin-top: 4px; font-size: .68rem; font-weight: 700; color: #1faa66; background: #e7f7ef; border-radius: 999px; padding: 2px 8px; }
