/* =========================================================
   Bloomy Plan Modal v6.0
   Desktop Layout Only / 80% Viewport Scale
   ---------------------------------------------------------
   Built from stable desktop CSS only.
   All @media responsive wrappers have been removed.
   The desktop layout is applied universally.
   Screen fitting is handled by scale-controller v6.0.
========================================================= */

.bloomy-plan-modal {
	position: fixed !important;
	inset: 0 !important;
	z-index: 99999 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 28px !important;
	color: #071b4d !important;
	font-family: -apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif !important;
	-webkit-font-smoothing: antialiased !important;
	-moz-osx-font-smoothing: grayscale !important;
	text-rendering: optimizeLegibility !important;
}.bloomy-plan-modal * {
	font-family: -apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif !important;
	-webkit-font-smoothing: antialiased !important;
	-moz-osx-font-smoothing: grayscale !important;
	text-rendering: optimizeLegibility !important;
}.bloomy-plan-modal[hidden] {
	display: none !important;
}.bloomy-plan-modal__backdrop {
	position: absolute !important;
	inset: 0 !important;
	background: rgba(29, 45, 70, 0.56) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
}.bloomy-plan-modal__dialog {
	position: relative !important;
	z-index: 1 !important;
	width: min(1000px, calc(100vw - 72px)) !important;
	max-height: calc(100vh - 56px) !important;
	overflow: hidden !important;
	display: grid !important;
	grid-template-columns: minmax(0, 1.55fr) minmax(310px, 0.92fr) !important;
	grid-template-rows: auto 1fr !important;
	column-gap: 24px !important;
	row-gap: 14px !important;
	padding: 30px 42px 28px !important;
	border-radius: 28px !important;
	background: #ffffff !important;
	box-shadow: 0 28px 80px rgba(12, 32, 74, 0.24) !important;
}.bloomy-plan-modal__close {
	position: absolute !important;
	top: 18px !important;
	right: 18px !important;
	z-index: 20 !important;
	width: 44px !important;
	height: 44px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	border: 1px solid #dfe8f8 !important;
	border-radius: 50% !important;
	background: #ffffff !important;
	color: #071b4d !important;
	font-size: 34px !important;
	line-height: 1 !important;
	font-weight: 300 !important;
	cursor: pointer !important;
	box-shadow: 0 6px 16px rgba(17, 44, 91, 0.13) !important;
}.bloomy-plan-modal__top {
	grid-column: 1 / 3 !important;
	grid-row: 1 !important;
	position: relative !important;
	min-height: 132px !important;
	display: flex !important;
	align-items: flex-start !important;
	padding-right: 330px !important;
}.bloomy-plan-modal__top-copy {
	max-width: 620px !important;
}.bloomy-plan-modal__eyebrow {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: fit-content !important;
	margin: 0 0 13px !important;
	padding: 8px 22px !important;
	border-radius: 999px !important;
	background: #e2f0ff !important;
	color: #0880ff !important;
	font-size: 15px !important;
	line-height: 1 !important;
	font-weight: 800 !important;
	letter-spacing: -0.02em !important;
}.bloomy-plan-modal__title {
	margin: 0 !important;
	color: #071b4d !important;
	font-size: 32px !important;
	line-height: 1.25 !important;
	font-weight: 800 !important;
	letter-spacing: -0.045em !important;
}.bloomy-plan-modal__lead {
	margin: 12px 0 0 !important;
	color: #263a63 !important;
	font-size: 15.5px !important;
	line-height: 1.55 !important;
	font-weight: 700 !important;
	letter-spacing: -0.01em !important;
}.bloomy-plan-modal__visual {
	position: absolute !important;
	top: 64px !important;
	right: 126px !important;
	z-index: 2 !important;
	width: 224px !important;
	height: auto !important;
	left: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	overflow: visible !important;
	pointer-events: none !important;
	transform: none !important;
}.bloomy-plan-modal__visual img {
	display: block !important;
	width: 100% !important;
	height: auto !important;
	object-fit: contain !important;
	filter: none !important;
}.bloomy-plan-modal__left {
	grid-column: 1 !important;
	grid-row: 2 !important;
	min-width: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	margin-top: -14px !important;
}.bloomy-plan-modal__right {
	grid-column: 2 !important;
	grid-row: 2 !important;
	min-width: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: flex-start !important;
	gap: 16px !important;
	padding-top: 4px !important;
}.bloomy-plan-modal__summary {
	margin: 0 !important;
	padding: 24px 26px 21px !important;
	border: 1px solid #d8e8fb !important;
	border-radius: 20px !important;
	background: #eef6ff !important;
	box-shadow: none !important;
}.bloomy-plan-modal__summary-head {
	margin: 0 !important;
}.bloomy-plan-modal__country-wrap {
	display: grid !important;
	grid-template-columns: 92px minmax(0, 1fr) !important;
	gap: 22px !important;
	align-items: center !important;
}.bloomy-plan-modal__flag {
	width: 78px !important;
	height: 66px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border: 2px solid #d7d7d7 !important;
	border-radius: 12px !important;
	background: #ffffff !important;
	overflow: hidden !important;
	box-shadow: 0 2px 8px rgba(10, 30, 70, 0.06) !important;
}.bloomy-plan-modal__flag img {
	display: block !important;
	width: 48px !important;
	height: auto !important;
	object-fit: contain !important;
}.bloomy-plan-modal__summary-copy {
	min-width: 0 !important;
}.bloomy-plan-modal__country-row {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	flex-wrap: wrap !important;
	margin: 0 !important;
}.bloomy-plan-modal__country {
	margin: 0 !important;
	color: #071b4d !important;
	font-size: 32px !important;
	line-height: 1.18 !important;
	font-weight: 800 !important;
	letter-spacing: -0.045em !important;
}.bloomy-plan-modal__description {
	margin: 10px 0 0 !important;
	color: #102854 !important;
	font-size: 14.5px !important;
	line-height: 1.65 !important;
	font-weight: 700 !important;
	letter-spacing: -0.01em !important;
}.bloomy-plan-modal__specs {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 0 !important;
	margin-top: 20px !important;
	padding: 0 !important;
	border: 1px solid #dfe7f3 !important;
	border-radius: 17px !important;
	background: #ffffff !important;
	overflow: hidden !important;
	box-shadow: none !important;
}.bloomy-plan-modal__spec {
	position: relative !important;
	min-width: 0 !important;
	display: grid !important;
	grid-template-columns: 40px minmax(0, 1fr) !important;
	grid-template-rows: auto auto !important;
	column-gap: 10px !important;
	align-items: center !important;
	margin: 0 !important;
	padding: 17px 18px !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	text-align: left !important;
}.bloomy-plan-modal__spec + .bloomy-plan-modal__spec::before {
	content: "" !important;
	position: absolute !important;
	left: 0 !important;
	top: 17px !important;
	bottom: 17px !important;
	width: 1px !important;
	background: #d9e1ec !important;
}.bloomy-plan-modal__spec::after,
.bloomy-plan-modal__spec--data::after,
.bloomy-plan-modal__spec--period::after,
.bloomy-plan-modal__spec--price::after,
.bloomy-plan-modal__specs .bloomy-plan-modal__spec:nth-child(1)::after,
.bloomy-plan-modal__specs .bloomy-plan-modal__spec:nth-child(2)::after,
.bloomy-plan-modal__specs .bloomy-plan-modal__spec:nth-child(3)::after {
	content: none !important;
	display: none !important;
	background-image: none !important;
}.bloomy-plan-modal__spec-icon,
.bloomy-plan-modal__spec-icon-img {
	grid-column: 1 !important;
	grid-row: 1 / 3 !important;
	display: block !important;
	width: 34px !important;
	height: 34px !important;
	max-width: 34px !important;
	max-height: 34px !important;
	object-fit: contain !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}.bloomy-plan-modal__spec-label {
	grid-column: 2 !important;
	grid-row: 1 !important;
	margin: 0 !important;
	color: #7b88a6 !important;
	font-size: 10.5px !important;
	line-height: 1.22 !important;
	font-weight: 600 !important;
	letter-spacing: -0.01em !important;
	white-space: nowrap !important;
	text-align: left !important;
}.bloomy-plan-modal__spec-value,
.bloomy-plan-modal__spec-value--price,
#bloomyPlanModalData,
#bloomyPlanModalPeriod,
#bloomyPlanModalPrice {
	grid-column: 2 !important;
	grid-row: 2 !important;
	margin: 3px 0 0 !important;
	color: #071b4d !important;
	font-size: 23px !important;
	line-height: 1.05 !important;
	font-weight: 700 !important;
	letter-spacing: -0.035em !important;
	white-space: nowrap !important;
	text-align: left !important;
}.bloomy-plan-modal__safe {
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}.bloomy-plan-modal__section-title {
	position: relative !important;
	margin: 0 0 13px !important;
	padding-left: 38px !important;
	color: #071b4d !important;
	font-size: 18px !important;
	line-height: 1.35 !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__safe .bloomy-plan-modal__section-title {
	display: flex !important;
	align-items: center !important;
	min-height: 32px !important;
	margin: 0 0 12px !important;
	padding-left: 44px !important;
	line-height: 1.2 !important;
}.bloomy-plan-modal__safe .bloomy-plan-modal__section-title::before {
	content: "" !important;
	position: absolute !important;
	left: 0 !important;
	top: 50% !important;
	width: 28px !important;
	height: 28px !important;
	transform: translateY(-50%) !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
	background-image: url("data:image/svg+xml,%3Csvg width='32' height='32' viewBox='0 0 32 32' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 3.5L26 7.5V15.2C26 21.7 21.7 27.5 16 29C10.3 27.5 6 21.7 6 15.2V7.5L16 3.5Z' stroke='%231887ff' stroke-width='2.5' stroke-linejoin='round'/%3E%3Cpath d='M11.5 16.1L14.4 19L20.8 12.5' stroke='%231887ff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__safe-grid {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 12px !important;
}.bloomy-plan-modal__safe-card {
	position: relative !important;
	min-width: 0 !important;
	min-height: 104px !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: flex-end !important;
	padding: 48px 10px 12px !important;
	border: 1px solid #dfeff0 !important;
	border-radius: 14px !important;
	background: linear-gradient(180deg, #f2fbf8 0%, #eef8f5 100%) !important;
	text-align: center !important;
	box-shadow: none !important;
}.bloomy-plan-modal__safe-card::before {
	content: "" !important;
	position: absolute !important;
	top: 10px !important;
	left: 50% !important;
	width: 38px !important;
	height: 38px !important;
	transform: translateX(-50%) !important;
	border-radius: 50% !important;
	background: #e2efff !important;
}.bloomy-plan-modal__safe-card::after {
	content: "" !important;
	position: absolute !important;
	top: 18px !important;
	left: 50% !important;
	width: 21px !important;
	height: 21px !important;
	transform: translateX(-50%) !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
}.bloomy-plan-modal__safe-card:nth-child(1)::after {
	background-image: url("data:image/svg+xml,%3Csvg width='30' height='30' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 5H12V12H5V5Z' stroke='%23071b4d' stroke-width='2.3'/%3E%3Cpath d='M18 5H25V12H18V5Z' stroke='%23071b4d' stroke-width='2.3'/%3E%3Cpath d='M5 18H12V25H5V18Z' stroke='%23071b4d' stroke-width='2.3'/%3E%3Cpath d='M18 18H21M25 18V21M18 25H25M25 25V24' stroke='%23071b4d' stroke-width='2.3' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__safe-card:nth-child(2)::after {
	background-image: url("data:image/svg+xml,%3Csvg width='30' height='30' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M17 2L6 17H14L12 28L24 12H16L17 2Z' fill='%23ffd45a' stroke='%23071b4d' stroke-width='2.2' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__safe-card:nth-child(3)::after {
	background-image: url("data:image/svg+xml,%3Csvg width='30' height='30' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='5' y='8' width='20' height='15' rx='2.5' stroke='%231887ff' stroke-width='2.4'/%3E%3Cpath d='M5 13H25' stroke='%231887ff' stroke-width='2.4'/%3E%3Cpath d='M19 19H22' stroke='%231887ff' stroke-width='2.4' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__safe-card strong {
	display: block !important;
	margin: 0 !important;
	color: #039a5f !important;
	font-size: 14px !important;
	line-height: 1.25 !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__safe-card span {
	display: block !important;
	margin: 5px 0 0 !important;
	color: #263a63 !important;
	font-size: 11px !important;
	line-height: 1.3 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__notice {
	margin: 0 !important;
	padding: 23px 27px !important;
	min-height: 0 !important;
	border: 1px solid #dfe7f2 !important;
	border-radius: 19px !important;
	background: #ffffff !important;
	box-shadow: none !important;
}.bloomy-plan-modal__notice .bloomy-plan-modal__section-title {
	margin-bottom: 12px !important;
	padding-left: 38px !important;
	font-size: 17px !important;
	line-height: 1.3 !important;
}.bloomy-plan-modal__notice .bloomy-plan-modal__section-title::before {
	content: "i" !important;
	position: absolute !important;
	left: 0 !important;
	top: 50% !important;
	width: 26px !important;
	height: 26px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transform: translateY(-50%) !important;
	border: 2px solid #6b7792 !important;
	border-radius: 50% !important;
	color: #6b7792 !important;
	font-family: Georgia, serif !important;
	font-size: 17px !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__notice ul {
	margin: 0 !important;
	padding-left: 18px !important;
}.bloomy-plan-modal__notice li {
	display: list-item !important;
	margin: 0 0 7px !important;
	color: #071b4d !important;
	font-size: 12.8px !important;
	line-height: 1.66 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__notice li {
	margin-bottom: 0 !important;
}.bloomy-plan-modal__footer {
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}.bloomy-plan-modal__price-box {
	width: 100% !important;
	display: flex !important;
	justify-content: center !important;
	margin: 10px 0 12px !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
}.bloomy-plan-modal__price-row {
	width: 100% !important;
	display: flex !important;
	align-items: baseline !important;
	justify-content: center !important;
	gap: 14px !important;
	flex-wrap: wrap !important;
	text-align: center !important;
}.bloomy-plan-modal__price-label {
	margin: 0 !important;
	color: #071b4d !important;
	font-size: 15px !important;
	line-height: 1.2 !important;
	font-weight: 800 !important;
	white-space: nowrap !important;
}.bloomy-plan-modal__price-main {
	margin: 0 !important;
	color: #1887ff !important;
	font-size: 38px !important;
	line-height: 1 !important;
	font-weight: 800 !important;
	letter-spacing: -0.045em !important;
	white-space: nowrap !important;
}.bloomy-plan-modal__footer-action {
	margin: 0 !important;
}.bloomy-plan-modal__cta {
	width: 100% !important;
	min-height: 64px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 16px !important;
	padding: 16px 24px !important;
	border-radius: 999px !important;
	background: linear-gradient(180deg, #1887ff 0%, #0878f8 100%) !important;
	color: #ffffff !important;
	text-decoration: none !important;
	font-size: 19px !important;
	line-height: 1.2 !important;
	font-weight: 800 !important;
	letter-spacing: 0.02em !important;
	white-space: nowrap !important;
	overflow: hidden !important;
	box-shadow: 0 6px 12px rgba(24, 135, 255, 0.14) !important;
}.bloomy-plan-modal__cta::before {
	content: "" !important;
	width: 26px !important;
	height: 26px !important;
	flex: 0 0 26px !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
	background-image: url("data:image/svg+xml,%3Csvg width='30' height='30' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='6' y='13' width='18' height='13' rx='3' fill='white'/%3E%3Cpath d='M10 13V9.5C10 6.8 12.2 4.7 15 4.7C17.8 4.7 20 6.8 20 9.5V13' stroke='white' stroke-width='3' stroke-linecap='round'/%3E%3Ccircle cx='15' cy='19' r='1.7' fill='%231887ff'/%3E%3Cpath d='M15 20.5V23' stroke='%231887ff' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__cta::after {
	content: "" !important;
	display: block !important;
	width: 15px !important;
	height: 15px !important;
	flex: 0 0 15px !important;
	margin-left: 6px !important;
	border-top: 3px solid #ffffff !important;
	border-right: 3px solid #ffffff !important;
	background: none !important;
	color: transparent !important;
	font-size: 0 !important;
	line-height: 0 !important;
	transform: rotate(45deg) !important;
}.bloomy-plan-modal__footer-note {
	position: relative !important;
	width: fit-content !important;
	margin: 11px auto 0 !important;
	padding-left: 23px !important;
	color: #8290a8 !important;
	font-size: 12.5px !important;
	line-height: 1.35 !important;
	font-weight: 700 !important;
	text-align: center !important;
}.bloomy-plan-modal__footer-note::before {
	content: "" !important;
	position: absolute !important;
	left: 0 !important;
	top: 50% !important;
	width: 17px !important;
	height: 17px !important;
	transform: translateY(-50%) !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 2L16 4.5V9.1C16 13 13.4 16.5 10 17.4C6.6 16.5 4 13 4 9.1V4.5L10 2Z' stroke='%238290a8' stroke-width='1.8' stroke-linejoin='round'/%3E%3Cpath d='M7.3 9.8L9 11.5L12.8 7.7' stroke='%238290a8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__coverage {
	position: relative !important;
	margin-top: 12px !important;
	padding: 9px 12px 10px !important;
	border: 1px solid rgba(24, 135, 255, 0.14) !important;
	border-radius: 14px !important;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(248, 252, 255, 0.78) 100%) !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}.bloomy-plan-modal__coverage::before {
	content: "" !important;
	position: absolute !important;
	left: 12px !important;
	top: 10px !important;
	width: 18px !important;
	height: 18px !important;
	border-radius: 999px !important;
	background: linear-gradient(180deg, rgba(24, 135, 255, 0.13), rgba(24, 135, 255, 0.08)) !important;
}.bloomy-plan-modal__coverage-label {
	position: relative !important;
	display: flex !important;
	align-items: center !important;
	gap: 6px !important;
	margin: 0 0 4px !important;
	padding-left: 27px !important;
	color: #6f7f9f !important;
	font-size: 10.5px !important;
	line-height: 1.25 !important;
	font-weight: 800 !important;
	letter-spacing: 0.02em !important;
}.bloomy-plan-modal__coverage-label::before {
	content: "" !important;
	position: absolute !important;
	left: 4px !important;
	top: 50% !important;
	width: 12px !important;
	height: 12px !important;
	transform: translateY(-50%) !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
	background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='9' cy='9' r='7' stroke='%231887ff' stroke-width='1.8'/%3E%3Cpath d='M2.5 9h13M9 2.4c1.9 2 2.8 4.2 2.8 6.6s-.9 4.6-2.8 6.6M9 2.4C7.1 4.4 6.2 6.6 6.2 9s.9 4.6 2.8 6.6' stroke='%231887ff' stroke-width='1.45' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}.bloomy-plan-modal__coverage-body {
	display: flex !important;
	flex-direction: column !important;
	gap: 3px !important;
	min-width: 0 !important;
	padding-left: 27px !important;
}.bloomy-plan-modal__coverage-summary {
	display: inline-block !important;
	width: fit-content !important;
	max-width: 100% !important;
	color: #071b4d !important;
	font-size: 13.5px !important;
	line-height: 1.35 !important;
	font-weight: 800 !important;
	letter-spacing: -0.02em !important;
}.bloomy-plan-modal__coverage-list {
	color: #526484 !important;
	font-size: 11.2px !important;
	line-height: 1.48 !important;
	font-weight: 650 !important;
	letter-spacing: -0.01em !important;
}.bloomy-plan-modal__coverage.has-coverage-list {
	padding-bottom: 11px !important;
}.bloomy-plan-modal__coverage.has-coverage-list .bloomy-plan-modal__coverage-summary {
	margin-bottom: 1px !important;
}.bloomy-plan-modal__coverage-toggle {
	width: fit-content !important;
	max-width: 100% !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 5px !important;
	margin: 3px 0 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: #1887ff !important;
	font-size: 11.2px !important;
	line-height: 1.45 !important;
	font-weight: 800 !important;
	letter-spacing: -0.01em !important;
	text-align: left !important;
	cursor: pointer !important;
	appearance: none !important;
	-webkit-appearance: none !important;
	text-decoration: underline !important;
	text-underline-offset: 3px !important;
	box-shadow: none !important;
}.bloomy-plan-modal__coverage-toggle::after {
	content: "" !important;
	width: 6px !important;
	height: 6px !important;
	flex: 0 0 6px !important;
	margin-top: -2px !important;
	border-right: 2px solid currentColor !important;
	border-bottom: 2px solid currentColor !important;
	transform: rotate(45deg) !important;
	transition: transform 0.18s ease !important;
}.bloomy-plan-modal__coverage.is-expanded .bloomy-plan-modal__coverage-toggle::after {
	margin-top: 2px !important;
	transform: rotate(225deg) !important;
}.bloomy-plan-modal__coverage-full {
	margin-top: 8px !important;
	padding: 9px 10px !important;
	border: 1px solid rgba(24, 135, 255, 0.12) !important;
	border-radius: 11px !important;
	background: rgba(238, 246, 255, 0.72) !important;
	color: #33486f !important;
	font-size: 11px !important;
	line-height: 1.65 !important;
	font-weight: 700 !important;
	letter-spacing: -0.01em !important;
}.bloomy-plan-modal__coverage-full[hidden],
.bloomy-plan-modal__coverage-toggle[hidden] {
	display: none !important;
}

/* Unwrapped former media block; desktop layout is intentionally universal. */
.bloomy-plan-modal__visual {
	top: 54px !important;
	right: 104px !important;
	width: 200px !important;
}.bloomy-plan-modal__right {
	padding-top: 0 !important;
	gap: 0 !important;
}.bloomy-plan-modal__notice {
	margin-top: 1px !important;
}

.bloomy-plan-modal__title {
	font-size: 29px !important;
	line-height: 1.24 !important;
	font-weight: 800 !important;
	letter-spacing: -0.04em !important;
}.bloomy-plan-modal__lead {
	font-size: 14px !important;
	line-height: 1.5 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__eyebrow {
	font-size: 13px !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__country {
	font-size: 28px !important;
	line-height: 1.16 !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__description {
	font-size: 13px !important;
	line-height: 1.55 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__section-title {
	font-size: 16px !important;
	line-height: 1.3 !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__safe-card strong {
	font-size: 12px !important;
	line-height: 1.22 !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__safe-card span {
	font-size: 10px !important;
	line-height: 1.28 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__coverage-label {
	font-size: 10px !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__coverage-summary {
	font-size: 12.2px !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__coverage-list,
.bloomy-plan-modal__coverage-full {
	font-size: 10.5px !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__coverage-toggle {
	font-size: 10.8px !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__price-label {
	font-size: 13px !important;
	font-weight: 700 !important;
}.bloomy-plan-modal__price-main {
	font-size: 32px !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__cta {
	font-size: 16.5px !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__footer-note {
	font-size: 11px !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__specs {
	margin-top: 18px !important;
	border-radius: 16px !important;
	background: #ffffff !important;
}.bloomy-plan-modal__spec {
	grid-template-columns: 34px minmax(0, 1fr) !important;
	column-gap: 12px !important;
	align-items: center !important;
	padding: 16px 20px !important;
}.bloomy-plan-modal__spec + .bloomy-plan-modal__spec::before {
	top: 17px !important;
	bottom: 17px !important;
	background: rgba(127, 145, 176, 0.24) !important;
}.bloomy-plan-modal__spec-icon,
.bloomy-plan-modal__spec-icon-img {
	width: 30px !important;
	height: 30px !important;
	max-width: 30px !important;
	max-height: 30px !important;
	align-self: center !important;
}.bloomy-plan-modal__spec-label {
	margin: 0 0 3px !important;
	color: #7d8aa8 !important;
	font-size: 10.2px !important;
	line-height: 1.18 !important;
	font-weight: 700 !important;
	letter-spacing: -0.01em !important;
}.bloomy-plan-modal__spec-value,
.bloomy-plan-modal__spec-value--price,
#bloomyPlanModalData,
#bloomyPlanModalPeriod,
#bloomyPlanModalPrice {
	margin: 0 !important;
	color: #071b4d !important;
	font-size: 22px !important;
	line-height: 1.05 !important;
	font-weight: 800 !important;
	letter-spacing: -0.045em !important;
}.bloomy-plan-modal__spec--data {
	grid-template-columns: 34px minmax(0, 1fr) !important;
}#bloomyPlanModalPrice {
	font-size: 22px !important;
	font-weight: 800 !important;
}.bloomy-plan-modal__notice {
	padding: 22px 26px !important;
	border-radius: 18px !important;
}.bloomy-plan-modal__notice .bloomy-plan-modal__section-title {
	margin-bottom: 12px !important;
	font-size: 16px !important;
	line-height: 1.3 !important;
}.bloomy-plan-modal__notice li {
	font-size: 11.5px !important;
	line-height: 1.62 !important;
	font-weight: 600 !important;
}.bloomy-plan-modal__right {
	gap: 0 !important;
}.bloomy-plan-modal__footer {
	margin-top: 24px !important;
}.bloomy-plan-modal__price-box {
	margin: 0 0 12px !important;
}

/* Unwrapped former media block; desktop layout is intentionally universal. */
.bloomy-plan-modal__right {
	position: relative !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	padding-top: 0 !important;
}.bloomy-plan-modal__right > .bloomy-plan-modal__visual {
	position: relative !important;
	top: auto !important;
	right: auto !important;
	left: auto !important;
	width: 200px !important;
	margin: 0 auto 2px !important;
	transform: none !important;
	z-index: 2 !important;
	pointer-events: none !important;
}.bloomy-plan-modal__right > .bloomy-plan-modal__notice {
	margin-top: 0 !important;
}.bloomy-plan-modal__right > .bloomy-plan-modal__notice + .bloomy-plan-modal__footer {
	margin-top: 26px !important;
}.bloomy-plan-modal__right .bloomy-plan-modal__price-box {
	margin: 0 0 12px !important;
}

/* Unwrapped former media block; desktop layout is intentionally universal. */
.bloomy-plan-modal__right {
	margin-top: -100px !important;
}

/* =========================================================
   Bloomy Plan Modal v6.0
   Desktop Layout Only / 80% Viewport Scale
   ---------------------------------------------------------
   Purpose:
   - Remove responsive layout switching.
   - Keep the desktop horizontal modal layout at every screen size.
   - Fix the modal's base width at 1000px.
   - Do not resize/reflow internal sections by viewport.
   - Display size is controlled only by transform: scale().
   - JS scales the whole modal so it fits within 80% of viewport width/height.
========================================================= */

.bloomy-plan-modal {
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	overflow: hidden !important;
}

.bloomy-plan-modal__dialog {
	--bloomy-modal-desktop-scale: 1;

	width: 1000px !important;
	min-width: 1000px !important;
	max-width: 1000px !important;

	height: auto !important;
	min-height: 0 !important;
	max-height: none !important;

	transform: scale(var(--bloomy-modal-desktop-scale)) !important;
	transform-origin: center center !important;
	will-change: transform !important;

	box-sizing: border-box !important;
	overflow: hidden !important;
}
/* =========================================================
   Bloomy Plan Modal v6.1
   Safe Card Compact Stability Fix
   ---------------------------------------------------------
   Based on:
   - v6.0 desktop-only 80% scale

   Scope:
   - Only adjusts the "螳牙ｿ�＠縺ｦ菴ｿ縺医∪縺�" cards so they do not collapse
     awkwardly when the full desktop modal is scaled down.
   - No JS changes.
   - No text, color, icon type, HTML, CTA, summary, specs, notice, visual,
     left/right layout changes.
========================================================= */

.bloomy-plan-modal__safe-card {
	min-height: 96px !important;
	padding: 42px 10px 10px !important;
}

.bloomy-plan-modal__safe-card::before {
	top: 8px !important;
	width: 32px !important;
	height: 32px !important;
}

.bloomy-plan-modal__safe-card::after {
	top: 15px !important;
	width: 18px !important;
	height: 18px !important;
}

.bloomy-plan-modal__safe-card strong {
	font-size: 12px !important;
	line-height: 1.18 !important;
	letter-spacing: -0.02em !important;
}

.bloomy-plan-modal__safe-card span {
	margin-top: 3px !important;
	font-size: 9.5px !important;
	line-height: 1.22 !important;
	letter-spacing: -0.01em !important;
}

/* =========================================================
   Bloomy Plan Modal — Portrait One-Screen Layout v20
   2026-05-30. CSS ONLY.（v3 + 隙間詰め + スペック枠合わせ縮小）
   Changes vs v3:
   - 各セクションの隙間を詰めた（dialog/left/right gap, specs/footer margin）
   - スペック(容量/期間/単価)の見出し・値・アイコンを枠に合わせて縮小
   - ご注意↔合計の余白(デスクトップ26px規則)を特異度を上げて解消
   Landscape は無改変。元に戻すにはこのブロックを削除。
========================================================= */
@media (orientation: portrait) {

  .bloomy-plan-modal.bloomy-plan-modal{
    padding: 3.5vw !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
  }

  .bloomy-plan-modal .bloomy-plan-modal__dialog{
    transform: none !important;
    width: 92vw !important;
    min-width: 0 !important;
    max-width: 92vw !important;
    height: auto !important;
    max-height: 92vh !important;
    display: flex !important;
    flex-direction: column !important;
    gap: clamp(3px, 0.9vw, 8px) !important;
    padding: clamp(11px, 3vw, 18px) !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  .bloomy-plan-modal .bloomy-plan-modal__top,
  .bloomy-plan-modal .bloomy-plan-modal__left,
  .bloomy-plan-modal .bloomy-plan-modal__right{
    width: 100% !important; max-width: 100% !important; min-width: 0 !important; margin: 0 !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__left,
  .bloomy-plan-modal .bloomy-plan-modal__right{
    display: flex !important; flex-direction: column !important;
    gap: clamp(3px, 0.9vw, 7px) !important;
  }

  .bloomy-plan-modal .bloomy-plan-modal__top{
    min-height: 0 !important;
    padding-right: 0 !important;
    display: block !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__top-copy{ max-width: 100% !important; }

  .bloomy-plan-modal .bloomy-plan-modal__visual{ display: none !important; }
  .bloomy-plan-modal .bloomy-plan-modal__lead{ display: none !important; }

  .bloomy-plan-modal .bloomy-plan-modal__eyebrow{
    margin: 0 0 clamp(3px, 1vw, 6px) !important;
    padding: clamp(3px,1vw,6px) clamp(10px,3.2vw,18px) !important;
    font-size: clamp(8.1px, 2.4vw, 9.7px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__title{
    font-size: clamp(12.2px, 3.7vw, 17px) !important;
    line-height: 1.2 !important;
  }

  .bloomy-plan-modal .bloomy-plan-modal__summary{ padding: clamp(9px, 2.6vw, 15px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__country-wrap{
    grid-template-columns: clamp(38px,10vw,54px) minmax(0,1fr) !important;
    gap: clamp(8px, 3vw, 16px) !important;
    align-items: center !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__flag{ width: clamp(38px,10vw,54px) !important; height: auto !important; }
  .bloomy-plan-modal .bloomy-plan-modal__country{
    font-size: clamp(14.6px, 4.4vw, 20.2px) !important;
    line-height: 1.14 !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__description{
    margin: clamp(3px,1vw,7px) 0 0 !important;
    font-size: clamp(8.9px, 2.6vw, 10.5px) !important;
    line-height: 1.5 !important;
    display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__coverage{
    margin-top: clamp(4px,1.4vw,9px) !important;
  }
  /* 利用可能エリア内の地域名は上のタイトルと重複するので非表示（ラベル＋対応国リストのみ残す） */
  .bloomy-plan-modal .bloomy-plan-modal__coverage-summary{ display: none !important; }
  /* 対応国アコーディオン：多数国プランで「すべての対応地域を見る」展開を有効化。
     展開時は内部スクロールで高さを制限し、CTAを画面外に押し出さない。
     ([hidden]時はブラウザ既定のdisplay:noneで畳まれる＝既定は1画面のまま) */
  .bloomy-plan-modal .bloomy-plan-modal__coverage-full{
    max-height: clamp(70px, 18vh, 120px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* スペック：枠に合わせて見出し・値・アイコンを縮小 */
  .bloomy-plan-modal .bloomy-plan-modal__specs{
    margin-top: clamp(4px, 1.4vw, 9px) !important;
    gap: 0 !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__spec{
    grid-template-columns: clamp(16px,4.4vw,20px) minmax(0,1fr) !important;
    column-gap: clamp(3px,1vw,6px) !important;
    padding: clamp(7px,1.8vw,12px) clamp(3px,1vw,7px) !important;
  }
  /* 値(3GB/15日間/28円)はID指定でleftが効くので、IDで中央に上書き（特異度1,1,0>1,0,0） */
  .bloomy-plan-modal #bloomyPlanModalData,
  .bloomy-plan-modal #bloomyPlanModalPeriod,
  .bloomy-plan-modal #bloomyPlanModalPrice{
    text-align: center !important;
    font-weight: 700 !important;
    font-size: clamp(12px, 3.4vw, 16px) !important;  /* 2段階大きく。字間詰め＋細アイコン列で15,710円も収まる（vw連動で小型端末は自動縮小） */
    letter-spacing: -0.06em !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__spec-icon,
  .bloomy-plan-modal .bloomy-plan-modal__spec-icon-img{
    width: clamp(20px,6vw,26px) !important;
    height: clamp(20px,6vw,26px) !important;
    max-width: clamp(20px,6vw,26px) !important;
    max-height: clamp(20px,6vw,26px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__spec-label{
    font-size: clamp(6.5px, 1.9vw, 7.7px) !important;
    text-align: center !important;
    line-height: 1.15 !important;
    letter-spacing: -0.02em !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__spec-value,
  .bloomy-plan-modal .bloomy-plan-modal__spec-value--price{
    font-size: clamp(9.7px, 2.8vw, 13px) !important;
    text-align: center !important;
    line-height: 1.05 !important;
    letter-spacing: -0.04em !important;
  }

  /* 安心して使えます */
  .bloomy-plan-modal .bloomy-plan-modal__safe .bloomy-plan-modal__section-title,
  .bloomy-plan-modal .bloomy-plan-modal__notice .bloomy-plan-modal__section-title{
    font-size: clamp(9.7px, 2.9vw, 12.2px) !important;
    margin: 0 0 clamp(4px,1.2vw,8px) !important;
    min-height: 0 !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__safe{ margin-top: clamp(4px, 1.6vw, 11px) !important; } /* 安心の上に余白 */
  /* セクション見出しのアイコンを文字サイズに合わせて縮小 */
  .bloomy-plan-modal .bloomy-plan-modal__safe .bloomy-plan-modal__section-title{ padding-left: clamp(17px, 5vw, 22px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__safe .bloomy-plan-modal__section-title::before{
    width: clamp(13px, 3.9vw, 16px) !important; height: clamp(13px, 3.9vw, 16px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__notice .bloomy-plan-modal__section-title{ padding-left: clamp(17px, 5vw, 22px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__notice .bloomy-plan-modal__section-title::before{
    width: clamp(13px, 3.9vw, 16px) !important; height: clamp(13px, 3.9vw, 16px) !important;
    font-size: clamp(8.5px, 2.5vw, 10.5px) !important; border-width: 1.5px !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__safe-grid{ gap: clamp(5px, 1.6vw, 10px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__safe-card{
    min-height: 0 !important;
    justify-content: flex-start !important;
    padding: 38px clamp(4px,1.4vw,8px) clamp(6px,1.4vw,9px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__safe-card::before{ top: 8px !important; width: 28px !important; height: 28px !important; }
  .bloomy-plan-modal .bloomy-plan-modal__safe-card::after{ top: 13px !important; width: 16px !important; height: 16px !important; }
  .bloomy-plan-modal .bloomy-plan-modal__safe-card strong{ font-size: clamp(8.6px, 2.3vw, 10.1px) !important; line-height: 1.18 !important; }
  .bloomy-plan-modal .bloomy-plan-modal__safe-card span{ font-size: clamp(7.3px, 2vw, 8.6px) !important; line-height: 1.22 !important; margin-top: 2px !important; }

  /* ご注意 */
  .bloomy-plan-modal .bloomy-plan-modal__notice{ padding: clamp(8px,2.2vw,16px) clamp(11px,3vw,20px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__right > .bloomy-plan-modal__notice{ margin-top: clamp(6px, 2vw, 13px) !important; } /* 安心↔ご注意の余白 */
  .bloomy-plan-modal .bloomy-plan-modal__notice li{ font-size: clamp(8.6px, 2.4vw, 10.1px) !important; line-height: 1.5 !important; }

  /* フッター（合計＋購入ボタン）＋ ご注意↔合計の余白を解消（特異度0,4,0で勝つ） */
  .bloomy-plan-modal .bloomy-plan-modal__footer{ margin-top: clamp(3px,1vw,8px) !important; flex-shrink: 0 !important; }
  .bloomy-plan-modal .bloomy-plan-modal__right > .bloomy-plan-modal__notice + .bloomy-plan-modal__footer{ margin-top: clamp(3px,1vw,8px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__price-box{ margin: 0 0 clamp(4px,1.4vw,9px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__price-label{ font-size: clamp(8.9px, 2.4vw, 11.3px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__price-main{ font-size: clamp(16.2px, 4.9vw, 24.3px) !important; }
  .bloomy-plan-modal .bloomy-plan-modal__cta{
    min-height: clamp(44px, 12vw, 56px) !important;
    padding: clamp(10px,2vw,16px) clamp(14px,4vw,24px) !important;
    font-size: clamp(11.3px, 3.2vw, 13.8px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__footer-note{ font-size: clamp(8.1px, 2.4vw, 9.7px) !important; margin-top: clamp(3px,1.2vw,8px) !important; }

  /* 縦画面だけ×ボタンを小さく（数値を変えればサイズ調整可） */
  .bloomy-plan-modal .bloomy-plan-modal__close{
    z-index: 6 !important;
    top: clamp(8px, 2.6vw, 14px) !important;
    right: clamp(8px, 2.6vw, 14px) !important;
    width: clamp(30px, 8vw, 38px) !important;
    height: clamp(30px, 8vw, 38px) !important;
  }
  .bloomy-plan-modal .bloomy-plan-modal__close::before,
  .bloomy-plan-modal .bloomy-plan-modal__close::after{ width: clamp(13px, 3.6vw, 17px) !important; }
}

/* =========================================================
   Close (×) button — 円の中で完全中央化（全向き共通）
   元の×はテキスト文字で中心からズレるため、文字を隠して
   2本の線で×を描き、translate(-50%,-50%)で中央に固定。
   横画面=棒22px / 縦画面=上の clamp で短縮。
========================================================= */
.bloomy-plan-modal__close{ font-size: 0 !important; line-height: 0 !important; }
.bloomy-plan-modal__close::before,
.bloomy-plan-modal__close::after{
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 22px !important;
  height: 2px !important;
  background: currentColor !important;
  border-radius: 2px !important;
  pointer-events: none !important;
}
.bloomy-plan-modal__close::before{ transform: translate(-50%, -50%) rotate(45deg) !important; }
.bloomy-plan-modal__close::after{  transform: translate(-50%, -50%) rotate(-45deg) !important; }

/* =========================================================
   利用可能エリア内の重複地域名を非表示（横画面・縦画面ともに）
   上のタイトル(国/地域名)と同じ語が __coverage-summary に出るため。
========================================================= */
.bloomy-plan-modal .bloomy-plan-modal__coverage-summary{ display: none !important; }
