@charset "utf-8";

/* ---------------------------------------------
	おすすめビンゴ景品 SP版リニューアル
--------------------------------------------- */

:root {
	--osusume-main: #f7a600;
	--osusume-main-dark: #d88700;
	--osusume-accent: #111827;
	--osusume-red: #d9362b;
	--osusume-bg: #fff8e8;
	--osusume-bg-soft: #fffdf7;
	--osusume-border: #ead8b5;
	--osusume-text: #333333;
	--osusume-muted: #666666;
	--osusume-white: #ffffff;
	--osusume-shadow: 0 8px 22px rgba(80, 55, 20, 0.14);
}
/* パンくず横並び修正 */
#osusume-renewal .breadcrumb {
	margin: 0 10px 12px;
	padding: 0;
}

#osusume-renewal .breadcrumb ul,
#osusume-renewal ul.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 8px 0;
	list-style: none;
}

#osusume-renewal .breadcrumb li {
	display: inline-flex;
	align-items: center;
	margin: 0;
	padding: 0;
	font-size: 12px;
	line-height: 1.5;
	white-space: nowrap;
}

#osusume-renewal .breadcrumb li a {
	color: #666666;
	text-decoration: underline;
}

#osusume-renewal .breadcrumb li:last-child {
	color: #333333;
	white-space: normal;
}#osusume-sp {
	color: var(--osusume-text);
	font-size: 15px;
	line-height: 1.75;
	background: #fffdf7;
}

#osusume-sp,
#osusume-sp * {
	box-sizing: border-box;
}

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

#osusume-sp a {
	text-decoration: none;
}

/* hero */
.osusume-sp-hero {
	position: relative;
	margin: 0 10px 18px;
	padding: 22px 18px 20px;
	border-radius: 18px;
	background: linear-gradient(135deg, #ffb820 0%, #fff0b8 100%);
	box-shadow: var(--osusume-shadow);
	overflow: hidden;
}

.osusume-sp-hero::before {
	content: "";
	position: absolute;
	right: -48px;
	top: -48px;
	width: 130px;
	height: 130px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.34);
}

.osusume-sp-label {
	position: relative;
	display: inline-block;
	margin: 0 0 10px;
	padding: 4px 12px;
	border-radius: 999px;
	background: var(--osusume-accent);
	color: var(--osusume-white);
	font-size: 12px;
	font-weight: bold;
	line-height: 1.5;
}

.osusume-sp-hero h1 {
	position: relative;
	margin: 0 0 10px;
	color: var(--osusume-accent);
	font-size: 23px;
	font-weight: 800;
	line-height: 1.38;
	letter-spacing: 0.01em;
}

.osusume-sp-hero p {
	position: relative;
	margin: 0;
	color: #3a2a10;
	font-size: 14px;
	font-weight: 600;
}

.osusume-sp-points {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin: 16px 0 0;
}

.osusume-sp-points span {
	display: inline-block;
	padding: 5px 9px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	color: var(--osusume-accent);
	font-size: 12px;
	font-weight: bold;
}

/* shortcut */
.osusume-sp-shortcut {
	margin: 0 10px 22px;
	padding: 16px;
	border: 1px solid var(--osusume-border);
	border-radius: 16px;
	background: var(--osusume-white);
	box-shadow: 0 4px 14px rgba(80, 55, 20, 0.08);
}

.osusume-sp-shortcut h2 {
	margin: 0 0 12px;
	padding: 0 0 9px;
	border-bottom: 3px solid var(--osusume-main);
	color: var(--osusume-accent);
	font-size: 19px;
	font-weight: 800;
}

.osusume-sp-shortcut__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 9px;
}

.osusume-sp-shortcut__grid a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 9px 8px;
	border-radius: 12px;
	background: var(--osusume-accent);
	color: #ffffff !important;
	font-size: 13px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	box-shadow: 0 4px 0 rgba(0, 0, 0, 0.18);
}

/* heading */
.osusume-sp-heading {
	margin: 0 10px 16px;
	text-align: center;
}

.osusume-sp-heading p {
	margin: 0 0 3px;
	color: var(--osusume-main-dark);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.osusume-sp-heading h2 {
	margin: 0;
	color: var(--osusume-accent);
	font-size: 22px;
	font-weight: 800;
	line-height: 1.4;
}

.osusume-sp-heading span {
	display: block;
	margin: 7px 0 0;
	color: var(--osusume-muted);
	font-size: 13px;
}

/* card */
.osusume-sp-ranking {
	margin: 0 0 24px;
}

.osusume-sp-card {
	position: relative;
	margin: 0 10px 18px;
	padding: 18px 14px 16px;
	border: 1px solid var(--osusume-border);
	border-radius: 18px;
	background: var(--osusume-white);
	box-shadow: var(--osusume-shadow);
}

.osusume-sp-card--rank1 {
	border: 3px solid var(--osusume-main);
	background: linear-gradient(180deg, #fffef8 0%, #ffffff 70%);
}

.osusume-sp-card__rank {
	position: absolute;
	top: -12px;
	left: 14px;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 68px;
	height: 30px;
	padding: 0 12px;
	border-radius: 999px;
	background: var(--osusume-red);
	color: var(--osusume-white);
	font-size: 15px;
	font-weight: 800;
	box-shadow: 0 5px 12px rgba(217, 54, 43, 0.25);
}

.osusume-sp-card__image {
	display: block;
	margin: 8px auto 14px;
	padding: 10px;
	border: 1px solid #eeeeee;
	border-radius: 14px;
	background: #fafafa;
	text-align: center;
}

.osusume-sp-card__image img {
	width: 100%;
	max-width: 320px;
	height: auto;
	object-fit: contain;
}

.osusume-sp-card__body h3 {
	margin: 0 0 10px;
	color: var(--osusume-accent);
	font-size: 19px;
	font-weight: 800;
	line-height: 1.45;
}

.osusume-sp-card__body p {
	margin: 0 0 10px;
	color: var(--osusume-text);
	font-size: 14px;
}

.osusume-sp-card__body ul {
	margin: 0 0 14px;
	padding: 0;
	list-style: none;
}

.osusume-sp-card__body li {
	position: relative;
	margin: 0 0 5px;
	padding: 0 0 0 20px;
	color: var(--osusume-muted);
	font-size: 13px;
}

.osusume-sp-card__body li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--osusume-main-dark);
	font-weight: bold;
}

.osusume-sp-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin: 0 0 14px;
}

.osusume-sp-badges span {
	display: inline-block;
	padding: 4px 9px;
	border: 1px solid var(--osusume-border);
	border-radius: 999px;
	background: var(--osusume-bg);
	color: #7a4a00;
	font-size: 12px;
	font-weight: bold;
}

.osusume-sp-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 48px;
	padding: 12px 16px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--osusume-red), #f06445);
	color: var(--osusume-white) !important;
	font-size: 16px;
	font-weight: 800;
	box-shadow: 0 5px 0 #a8241d;
}

.osusume-sp-btn::after {
	content: "›";
	margin-left: 8px;
	font-size: 21px;
	line-height: 1;
}

/* guide */
.osusume-sp-guide {
	margin: 24px 10px 22px;
	padding: 18px 14px;
	border-radius: 18px;
	background: var(--osusume-bg);
}

.osusume-sp-guide .osusume-sp-heading {
	margin-left: 0;
	margin-right: 0;
}

.osusume-sp-guide__box {
	margin: 0 0 12px;
	padding: 15px;
	border: 1px solid var(--osusume-border);
	border-radius: 14px;
	background: var(--osusume-white);
}

.osusume-sp-guide__box:last-child {
	margin-bottom: 0;
}

.osusume-sp-guide__box h3 {
	margin: 0 0 6px;
	color: var(--osusume-accent);
	font-size: 17px;
	font-weight: 800;
}

.osusume-sp-guide__box p {
	margin: 0;
	color: var(--osusume-muted);
	font-size: 14px;
}

/* cta */
.osusume-sp-cta {
	margin: 0 10px 28px;
	padding: 22px 16px;
	border-radius: 18px;
	background: var(--osusume-accent);
	color: var(--osusume-white);
	text-align: center;
}

.osusume-sp-cta h2 {
	margin: 0 0 9px;
	font-size: 21px;
	font-weight: 800;
	line-height: 1.4;
}

.osusume-sp-cta p {
	margin: 0 0 16px;
	color: rgba(255, 255, 255, 0.86);
	font-size: 14px;
}

.osusume-sp-cta__buttons {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}

.osusume-sp-cta__buttons a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 11px 12px;
	border-radius: 999px;
	background: var(--osusume-main);
	color: var(--osusume-accent);
	font-size: 15px;
	font-weight: 800;
}

/* 古いSP共通CSSとの干渉対策 */
#osusume-sp ul,
#osusume-sp li,
#osusume-sp p,
#osusume-sp h1,
#osusume-sp h2,
#osusume-sp h3 {
	padding-top: 0;
}

#osusume-sp ul {
	list-style: none;
}