@charset "utf-8";

/* --------------------------------------------------------------------------------
	会社・企業向けビンゴ景品ページ PC
-------------------------------------------------------------------------------- */

:root {
	--bt-navy: #183b6b;
	--bt-blue: #0b5cab;
	--bt-orange: #ff7a00;

	--bt-text: #333;
	--bt-text-main: #1f3550;
	--bt-text-sub: #4d5d72;
	--bt-text-muted: #68788c;

	--bt-bg-light: #f7fbff;
	--bt-bg-blue: #eef6ff;
	--bt-bg-answer: #fbfdff;
	--bt-bg-chip: #eef5fd;
	--bt-white: #fff;

	--bt-border: #d7e1ee;
	--bt-border-light: #e3eaf2;
	--bt-border-card: #dbe6f2;
	--bt-border-hero: #d9e6f5;
	--bt-border-chip: #cfe0f4;
	--bt-border-open: #a8c5e7;

	--bt-navy-dark: #112d52;
	--bt-orange-dark: #d96200;
	--bt-orange-light: #fff0e0;
	--bt-success: #1a7f4b;
	--bt-success-bg: #eafaf1;

	--bt-shadow-sm: rgba(24, 59, 107, .08);
	--bt-shadow-md: rgba(24, 59, 107, .14);
	--bt-shadow-lg: rgba(24, 59, 107, .20);
	--bt-orange-glow: rgba(255, 122, 0, .18);

	--bt-font-base: 15px;
	--bt-font-h1: 34px;
	--bt-font-h2: 26px;
	--bt-font-h3: 18px;
	--bt-font-small: 14px;
	--bt-font-label: 12px;
	--bt-font-cta: 24px;

	--bt-radius-sm: 8px;
	--bt-radius-md: 14px;
	--bt-radius-lg: 18px;
	--bt-radius-xl: 24px;
	--bt-radius-pill: 999px;

	--bt-ease: cubic-bezier(.25, .8, .25, 1);
}

#company-bingo.company-bingo-renewal {
	color: var(--bt-text);
	font-size: var(--bt-font-base);
	line-height: 1.85;
}

#company-bingo *,
#company-bingo *::before,
#company-bingo *::after {
	box-sizing: border-box;
}

#company-bingo img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

#company-bingo a {
	color: inherit;
	text-decoration: none;
	transition: .2s var(--bt-ease);
}

#company-bingo a:hover {
	opacity: .88;
}

/* パンくず */
#company-bingo .breadcrumb {
	margin: 0 0 14px;
}

#company-bingo .breadcrumb ul,
#company-bingo ul.breadcrumb {
	margin: 0;
	padding: 0;
	list-style: none;
}

#company-bingo .breadcrumb li {
	float: left;
	margin: 0 6px 0 0;
	font-size: 12px;
	color: var(--bt-text-muted);
	line-height: 1.6;
}

#company-bingo .breadcrumb li a {
	color: var(--bt-blue);
	text-decoration: underline;
}

/* 共通ボタン */
#company-bingo .cb-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 22px;
	border-radius: var(--bt-radius-pill);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	text-align: center;
	box-shadow: 0 8px 18px var(--bt-shadow-sm);
}

#company-bingo .cb-btn--primary {
	color: var(--bt-white);
	background: linear-gradient(135deg, var(--bt-orange), var(--bt-orange-dark));
	box-shadow: 0 10px 24px var(--bt-orange-glow);
}

#company-bingo .cb-btn--sub {
	color: var(--bt-white);
	background: linear-gradient(135deg, var(--bt-blue), var(--bt-navy));
}

#company-bingo .cb-btn--line {
	color: var(--bt-navy);
	background: var(--bt-white);
	border: 2px solid var(--bt-border-chip);
	box-shadow: none;
}

#company-bingo .cb-btn--white {
	color: var(--bt-navy);
	background: var(--bt-white);
	border: 2px solid rgba(255, 255, 255, .72);
	box-shadow: 0 8px 18px rgba(0, 0, 0, .08);
}

#company-bingo .cb-btn:hover {
	transform: translateY(-2px);
}

/* ヒーロー */
#company-bingo .cb-hero {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 310px;
	gap: 28px;
	margin: 0 0 34px;
	padding: 34px;
	border: 1px solid var(--bt-border-hero);
	border-radius: var(--bt-radius-xl);
	overflow: hidden;
	background:
		radial-gradient(circle at 95% 10%, rgba(255, 122, 0, .18), transparent 26%),
		linear-gradient(135deg, #f7fbff 0%, #eef6ff 45%, #fff 100%);
	box-shadow: 0 18px 40px var(--bt-shadow-md);
}

#company-bingo .cb-hero::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 8px;
	height: 100%;
	background: linear-gradient(180deg, var(--bt-orange), var(--bt-blue));
}

#company-bingo .cb-hero__body {
	position: relative;
	z-index: 1;
}

#company-bingo .cb-hero__label,
#company-bingo .cb-section__label,
#company-bingo .cb-cta__label {
	display: inline-flex;
	align-items: center;
	margin: 0 0 12px;
	padding: 5px 12px;
	border-radius: var(--bt-radius-pill);
	color: var(--bt-blue);
	font-size: var(--bt-font-label);
	font-weight: 700;
	letter-spacing: .04em;
	background: var(--bt-bg-chip);
	border: 1px solid var(--bt-border-chip);
}

#company-bingo .cb-hero h2 {
	margin: 0 0 16px;
	color: var(--bt-navy);
	font-size: var(--bt-font-h1);
	font-weight: 800;
	line-height: 1.35;
	background: none;
	border-radius: 0;
	min-height: 0;
}

#company-bingo .cb-hero h2 span {
	display: inline;
	padding: 0;
	color: var(--bt-orange);
	background: linear-gradient(transparent 66%, rgba(255, 122, 0, .18) 66%);
}

#company-bingo .cb-hero__lead {
	margin: 0 0 24px;
	color: var(--bt-text-sub);
	font-size: 16px;
	line-height: 1.95;
}

#company-bingo .cb-hero__btns,
#company-bingo .cb-cta__btns {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

#company-bingo .cb-hero__side {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: stretch;
}

#company-bingo .cb-heroCard {
	width: 100%;
	padding: 22px;
	border-radius: var(--bt-radius-lg);
	background: rgba(255, 255, 255, .92);
	border: 1px solid var(--bt-border-card);
	box-shadow: 0 12px 28px var(--bt-shadow-sm);
}

#company-bingo .cb-heroCard__title {
	margin: 0 0 12px;
	color: var(--bt-navy);
	font-size: 18px;
	font-weight: 800;
	line-height: 1.5;
}

#company-bingo .cb-heroCard ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

#company-bingo .cb-heroCard li {
	position: relative;
	padding: 8px 0 8px 26px;
	border-bottom: 1px solid var(--bt-border-light);
	color: var(--bt-text-main);
	font-size: 14px;
	font-weight: 700;
}

#company-bingo .cb-heroCard li:last-child {
	border-bottom: none;
}

#company-bingo .cb-heroCard li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	color: var(--bt-white);
	font-size: 12px;
	background: var(--bt-success);
}

/* セクション共通 */
#company-bingo .cb-section {
	margin: 0 0 36px;
	padding: 30px;
	border-radius: var(--bt-radius-xl);
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
	box-shadow: 0 12px 28px var(--bt-shadow-sm);
}

#company-bingo .cb-section__head {
	margin: 0 0 24px;
}

#company-bingo .cb-section__head h3,
#company-bingo .cb-receipt h3,
#company-bingo .cb-cta h3 {
	margin: 0 0 10px;
	padding: 0 0 12px;
	color: var(--bt-navy);
	font-size: var(--bt-font-h2);
	font-weight: 800;
	line-height: 1.45;
	border: none;
	border-bottom: 3px solid var(--bt-border-light);
	position: relative;
}

#company-bingo .cb-section__head h3::after,
#company-bingo .cb-receipt h3::after,
#company-bingo .cb-cta h3::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 86px;
	height: 3px;
	background: var(--bt-orange);
	border-radius: var(--bt-radius-pill);
}

#company-bingo .cb-section__head p {
	margin: 0;
	color: var(--bt-text-sub);
	font-size: 15px;
}

/* 悩みカード */
#company-bingo .cb-cardGrid {
	display: grid;
	gap: 18px;
}

#company-bingo .cb-cardGrid--4 {
	grid-template-columns: repeat(4, 1fr);
}

#company-bingo .cb-cardGrid--3 {
	grid-template-columns: repeat(3, 1fr);
}

#company-bingo .cb-miniCard,
#company-bingo .cb-meritCard {
	padding: 20px;
	border-radius: var(--bt-radius-lg);
	background: var(--bt-bg-light);
	border: 1px solid var(--bt-border-card);
}

#company-bingo .cb-miniCard__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin: 0 0 12px;
	border-radius: 50%;
	color: var(--bt-white);
	font-size: 16px;
	font-weight: 800;
	background: linear-gradient(135deg, var(--bt-blue), var(--bt-navy));
}

#company-bingo .cb-miniCard h4,
#company-bingo .cb-meritCard h4 {
	margin: 0 0 8px;
	color: var(--bt-text-main);
	font-size: var(--bt-font-h3);
	font-weight: 800;
	line-height: 1.45;
}

#company-bingo .cb-miniCard p,
#company-bingo .cb-meritCard p {
	margin: 0;
	color: var(--bt-text-sub);
	font-size: 14px;
	line-height: 1.75;
}

/* 選び方ステップ */
#company-bingo .cb-choice {
	background: linear-gradient(180deg, #fff 0%, var(--bt-bg-light) 100%);
}

#company-bingo .cb-stepList {
	display: grid;
	gap: 14px;
}

#company-bingo .cb-step {
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 18px;
	align-items: stretch;
	padding: 18px;
	border-radius: var(--bt-radius-lg);
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
}

#company-bingo .cb-step__num {
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--bt-radius-md);
	color: var(--bt-white);
	font-size: 20px;
	font-weight: 800;
	background: linear-gradient(135deg, var(--bt-orange), var(--bt-orange-dark));
}

#company-bingo .cb-step__body h4 {
	margin: 0 0 6px;
	color: var(--bt-navy);
	font-size: 18px;
	font-weight: 800;
}

#company-bingo .cb-step__body p {
	margin: 0;
	color: var(--bt-text-sub);
	font-size: 15px;
}

/* 検索リンク */
#company-bingo .cb-search {
	background: var(--bt-bg-blue);
}

#company-bingo .cb-searchBlock {
	margin: 0 0 22px;
	padding: 24px;
	border-radius: var(--bt-radius-lg);
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
}

#company-bingo .cb-searchBlock:last-child {
	margin-bottom: 0;
}

#company-bingo .cb-searchBlock__head {
	margin: 0 0 16px;
}

#company-bingo .cb-searchBlock__head h4 {
	margin: 0 0 5px;
	color: var(--bt-navy);
	font-size: 20px;
	font-weight: 800;
}

#company-bingo .cb-searchBlock__head p {
	margin: 0;
	color: var(--bt-text-muted);
	font-size: 14px;
}

#company-bingo .cb-linkGrid {
	display: grid;
	gap: 10px;
}

#company-bingo .cb-linkGrid--budget {
	grid-template-columns: repeat(4, 1fr);
}

#company-bingo .cb-linkGrid a {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 10px 14px;
	border-radius: var(--bt-radius-md);
	color: var(--bt-navy);
	font-size: 15px;
	font-weight: 800;
	background: var(--bt-bg-light);
	border: 1px solid var(--bt-border-chip);
}

#company-bingo .cb-linkGrid a::after {
	content: "›";
	margin-left: 8px;
	color: var(--bt-orange);
	font-size: 20px;
	font-weight: 800;
	line-height: 1;
}

#company-bingo .cb-linkGrid a:hover {
	color: var(--bt-white);
	background: var(--bt-blue);
	border-color: var(--bt-blue);
	opacity: 1;
}

#company-bingo .cb-linkGrid a:hover::after {
	color: var(--bt-white);
}

/* 目玉カテゴリ */
#company-bingo .cb-categoryGrid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}

#company-bingo .cb-categoryGrid a {
	display: block;
	border-radius: var(--bt-radius-lg);
	overflow: hidden;
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
	box-shadow: 0 8px 18px var(--bt-shadow-sm);
}

#company-bingo .cb-categoryGrid img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	background: var(--bt-bg-light);
}

#company-bingo .cb-categoryGrid span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 52px;
	padding: 8px 12px;
	color: var(--bt-text-main);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.45;
	text-align: center;
	background: var(--bt-white);
}

#company-bingo .cb-categoryGrid a:hover {
	transform: translateY(-3px);
	opacity: 1;
}

/* おすすめ商品 */
#company-bingo .cb-recommend {
	background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
}

#company-bingo .cb-productGrid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}

#company-bingo .cb-productCard {
	border-radius: var(--bt-radius-xl);
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
	box-shadow: 0 12px 28px var(--bt-shadow-sm);
	overflow: hidden;
}

#company-bingo .cb-productCard a {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 18px;
}

#company-bingo .cb-productCard__tag {
	display: inline-flex;
	align-self: flex-start;
	margin: 0 0 12px;
	padding: 5px 10px;
	border-radius: var(--bt-radius-pill);
	color: var(--bt-orange-dark);
	font-size: 12px;
	font-weight: 800;
	background: var(--bt-orange-light);
	border: 1px solid rgba(255, 122, 0, .26);
}

#company-bingo .cb-productCard__thumb {
	display: block;
	margin: 0 0 14px;
	border-radius: var(--bt-radius-md);
	overflow: hidden;
	background: var(--bt-bg-light);
	border: 1px solid var(--bt-border-light);
}

#company-bingo .cb-productCard__thumb img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

#company-bingo .cb-productCard__name {
	display: block;
	min-height: 78px;
	margin: 0 0 12px;
	color: var(--bt-text-main);
	font-size: 15px;
	font-weight: 800;
	line-height: 1.65;
}

#company-bingo .cb-productCard__price {
	display: block;
	margin: auto 0 14px;
	color: #d90000;
	font-size: 22px;
	font-weight: 800;
	line-height: 1.3;
}

#company-bingo .cb-productCard__price span {
	margin-left: 4px;
	color: var(--bt-text-muted);
	font-size: 12px;
	font-weight: 700;
}

#company-bingo .cb-productCard__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	border-radius: var(--bt-radius-pill);
	color: var(--bt-white);
	font-size: 14px;
	font-weight: 800;
	background: var(--bt-blue);
}

#company-bingo .cb-productCard:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 34px var(--bt-shadow-md);
}

#company-bingo .cb-moreBtn {
	margin: 24px 0 0;
	text-align: center;
}

/* メリット */
#company-bingo .cb-merit {
	background: var(--bt-bg-light);
}

#company-bingo .cb-meritCard {
	background: var(--bt-white);
	position: relative;
	padding-top: 24px;
}

#company-bingo .cb-meritCard::before {
	content: "";
	position: absolute;
	top: 0;
	left: 20px;
	right: 20px;
	height: 4px;
	border-radius: var(--bt-radius-pill);
	background: linear-gradient(90deg, var(--bt-blue), var(--bt-orange));
}

/* 領収書 */
#company-bingo .cb-receipt {
	padding: 0;
	border: none;
	background: none;
	box-shadow: none;
}

#company-bingo .cb-receipt__box {
	display: grid;
	grid-template-columns: 1fr 240px;
	gap: 24px;
	align-items: center;
	padding: 28px;
	border-radius: var(--bt-radius-xl);
	background: var(--bt-white);
	border: 1px solid var(--bt-border-card);
	box-shadow: 0 12px 28px var(--bt-shadow-sm);
}

#company-bingo .cb-receipt p {
	margin: 0;
	color: var(--bt-text-sub);
	font-size: 15px;
}

/* CTA */
#company-bingo .cb-cta {
	margin: 0 0 20px;
	padding: 34px;
	border-radius: var(--bt-radius-xl);
	color: var(--bt-white);
	background:
		radial-gradient(circle at 90% 10%, rgba(255, 122, 0, .28), transparent 30%),
		linear-gradient(135deg, var(--bt-navy), var(--bt-blue));
	box-shadow: 0 18px 40px var(--bt-shadow-lg);
}

#company-bingo .cb-cta__label {
	color: var(--bt-white);
	background: rgba(255, 255, 255, .14);
	border-color: rgba(255, 255, 255, .28);
}

#company-bingo .cb-cta h3 {
	color: var(--bt-white);
	font-size: var(--bt-font-cta);
	border-bottom-color: rgba(255, 255, 255, .22);
}

#company-bingo .cb-cta h3::after {
	background: var(--bt-orange);
}

/* 既存clearfix対策 */
#company-bingo .clearfix::after {
	content: "";
	display: block;
	clear: both;
}

/* PC幅が少し狭い場合の保険 */
@media screen and (max-width: 1100px) {
	#company-bingo .cb-hero {
		grid-template-columns: 1fr;
	}

	#company-bingo .cb-cardGrid--4,
	#company-bingo .cb-categoryGrid {
		grid-template-columns: repeat(2, 1fr);
	}

	#company-bingo .cb-linkGrid--budget {
		grid-template-columns: repeat(3, 1fr);
	}
}