@charset "utf-8";
/* CSS Document */
*{
	box-sizing: border-box;
}
body {
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Yu Gothic", YuGothic, sans-serif;
	font-weight: 500;
}
body.agfca-bg {
	background-color: #FFF;
	background-image: url(./img/bg.png);
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	background-attachment: fixed;
}
.w-100{
	width: 100%!important;
}
#second_contents{
	box-shadow: none;border:0;
	background-color: transparent;
}
.agfca-bg #second_contents{
	box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.35);
	background-color: #FFF;
}
.agfca-bg section li a{
	border:  none;
	display: inline;
}

/* font
------------------------------*/
.min-font{
	font-family: "游明朝", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}



/* color
------------------------------*/
.red{
	color: #e40211;
}
.green{
	color: #009042;
}
.d-blue{
	color: #0037a1;
}



*, *::before, *::after {
    box-sizing: border-box;
}
.img-fluid {
	max-width: 100%;
	height: auto;
  }

	.img-fluid02 {
		max-width: 100%;
		height: auto;
	  }



.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

.col {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -ms-flex-positive: 1;
    flex-grow: 1;
    max-width: 100%;
}
.col-auto {
	-ms-flex: 0 0 auto;
	flex: 0 0 auto;
	width: auto;
	max-width: 100%;
  }
  .col-5 {
	-ms-flex: 0 0 41.666667%;
	flex: 0 0 41.666667%;
	max-width: 41.666667%;
  }
  .col-3 {
	-ms-flex: 0 0 25%;
	flex: 0 0 25%;
	max-width: 25%;
  }

  .col-2 {
	-ms-flex: 0 0 16.666667%;
	flex: 0 0 16.666667%;
	max-width: 16.666667%;
  }
  @media (min-width: 576px) {
  .col-sm-5 {
    -ms-flex: 0 0 41.666667%;
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
  }
	.col-sm-4 {
		-ms-flex: 0 0 33.333333%;
		flex: 0 0 33.333333%;
		max-width: 33.333333%;
	}
	.col-sm-3 {
		-ms-flex: 0 0 25%;
		flex: 0 0 25%;
		max-width: 25%;
	}
  .col-sm-2 {
    -ms-flex: 0 0 16.666667%;
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
  }
}
.col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}
@media (min-width: 768px){
	.col-md-auto {
		-ms-flex: 0 0 auto;
		flex: 0 0 auto;
		width: auto;
		max-width: 100%;
	}
}
@media (min-width: 576px){
	.col-sm {
		-ms-flex-preferred-size: 0;
		flex-basis: 0;
		-ms-flex-positive: 1;
		flex-grow: 1;
		max-width: 100%;
	}
	.col-sm {
		-ms-flex-preferred-size: 0;
		flex-basis: 0;
		-ms-flex-positive: 1;
		flex-grow: 1;
		min-width: 0;
		max-width: 100%;
	  }
	.col-sm-6 {
	-ms-flex: 0 0 50%;
	flex: 0 0 50%;
	max-width: 50%;
	}
}


/* text
------------------------------*/
.text-center {
	text-align: center !important;
}
.text-left {
	text-align: left !important;
}

@media (min-width: 576px){
	.pos_b{
		position: absolute;
		bottom: 0;
		left: 0;
		padding-left: 15px;
	}
	.pos_c{
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		-webkit-transform: translateY(-50%) translateX(-50%);
		width: 100%;
		padding-left: 15px;
		padding-right: 15px;
	}
	.text-sm-left {
		text-align: left !important;
	}
	.text-sm-right {
		text-align: right !important;
	}
	.text-sm-center {
		text-align: center !important;
	}
}
.text_and{
	font-size: 2rem;
}
.l_font{
	font-size: 1.5rem;
}
/* space
------------------------------*/
.inner section{
	padding: 2rem 3rem ;
}

.pt-4,
.py-4 {
  padding-top: 1.5rem !important;
}
.pb-4,
.py-4 {
  padding-bottom: 1.5rem !important;
}
.pb-2,
.py-2 {
  padding-bottom: 0.5rem !important;
}


/* list
------------------------------*/
ul{
	list-style-type: none;
}
ul.comment_list{
	padding-left: 1em;
	text-indent: -1.3em;
	/* text-indent: -1em; */
	font-size: 0.875rem;
}
ul.common_list li:not(:last-child){
	margin-bottom: .5rem;
}
ul.comment_list li:not(:last-child){
	margin-bottom: .2rem;
}
.comment_list li::before{
	content: "※ ";
	/* content: "・"; */
}

ul.common_list{
	padding-left: 1em;
	text-indent: -1.2em;
}
.common_list li > ul li::before {
	content: "※";
}
.common_list li::before{
	content: "・";
	width: 20px;
}

/* box
------------------------------*/
.box_oubo{
    background-color: #f7f7f7;
    border: 1px solid #bcbcbc;
    padding: 1.5rem;
}






#pan,#pan a {
	color: #555;
}
#pan a:hover {
	color: #555;
	text-decoration: underline;
}
#second_contents p,
#second_contents ul{
	line-height: 1.6;
}
.bold{
	font-weight: 600;
}
.b_font{
	font-size: 110%;
}
.small{
	font-size: 90%;
}
.small-xs{
	font-size: 60%;
}

.text-left{
	text-align: left;
}
/* //text */
/* list */
section li{
	list-style: none;
    text-align: left;
    background: none;
}

ul.attention_text{
	padding-left: 1em;
	text-indent: -1em;
	margin-left: 7px;
}
ul.attention_text li::before{
	content: "※";
	color: #333;
}
/* //list */

.inner{
	margin: 0 auto;
	background-color: #FFFFFF;
}


.event_outline dl {
	padding: 15px 0;
	border-bottom: 1px solid #ccc;
}
.event_outline dt{
	font-weight: 600;
}





/* button */
.button_area{
	text-align: center;
	padding: 1.5rem 0 1rem;
}
.button {
	display: inline-block;
	text-align: center;
	text-decoration: none;
	outline: none;
}
.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
a.oubo_button {
	color: #FFF;
}
.oubo_button {
	width: 100%;
    /* height: 64px; */
    /* line-height: 64px; */
    background-color: #338b28;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    border-radius: 10px;
    padding: 1.5rem 0.5rem;
}
.oubo_button:hover {
	background-color: #225c1b;
	text-decoration: none;
	color: #FFF;
}
.reset_button,
.submit_button{
	width: 160px;
    height: 46px;
    line-height: 46px;
	font-size: 14px;
    font-weight: 600;
	margin: .5rem;
}
.reset_button{
    background-color: #e5e5e5;
    color: #51565b;
}
.reset_button:hover {
	background-color: #d0d0d0;
	text-decoration: none;
	color: #51565b;
}

.submit_button{
  background-color: #e40211;
  color: #ffffff;
	letter-spacing: .1em;
	text-indent: .1em;
}
.submit_button:hover{
	background-color: #b2000c;
	text-decoration: none;
	color: #FFF;
}
.reset_button.return-btn ,
.submit_button.return-btn {
	padding: 1rem;
  width: auto;
  height: auto;
  line-height: 1.8;
}

input[type=button],input[type=submit] {
	-webkit-appearance: none;
	outline: none;
	border-radius: 0;
	border: 1px solid #51565b;
	padding: 0;
}
input[type=button]:disabled,input[type=submit]:disabled {
	background-color: #717171;
}
/* //button */






section h2{
	border-top: none;
    border-bottom: none;
}
.lead_text h2{
    background: none;
    line-height: 1.5;
    padding: 1.5rem 0 2rem;
    color: #000000;
    margin: 0!important;
    font-size: 21px;
    font-weight: 600;
}

#second_contents h3.tit_outline{
    text-align: left;
    font-weight: 600;
    font-size: 21px;
    position: relative;
    padding: 0.5rem 0;
    border-bottom: 4px solid #f7698f;
    margin: 0 0 1.5rem;
    color: #348f28;
}
#second_contents h3.tit_outline02{
    text-align: left;
    font-weight: 600;
    font-size: 21px;
    position: relative;
    padding: 0.5rem 0;
    border-bottom: 4px solid #c00015;
    margin: 0 0 1.5rem;
    color: #348f28;
}
#second_contents h3.tit_outline:before {
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 20%;
	height: 4px;
	content: '';
	background: #348f28;
}
#second_contents h3.tit_outline02:before {
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 20%;
	height: 4px;
	content: '';
	background: #348f28;
}
.prize-list {
	display: flex;
    text-indent: 0px;
    margin-left: -20px;
}
.prize img {
	width: 134px;
	padding: 0.5rem 0 0.5rem 1em;
}
.prize-text {
	display: inline-block;
	width: 65%;
}






/* form */
::placeholder {
	color: #CCC;
}
.oubo_table{
	border-collapse:  collapse;
	width: 100%;
}
.oubo_table th {
	background: #eda366; /*#656565;*/
	border: solid 1px #733d09;
	color: #fff;
	padding: 12px 10px;
	width: 30%;
	line-height: 1.8;
	text-align: center;
}
#form.oubo_table th {
	width: 36%;
}
.oubo_table td {
	border: 1px solid #733d09;
	padding: 12px 10px;
	width: auto;
	line-height: 1.8;
}
.form-text {
	height: 2.4em;
    width: 100%;
    padding: 0 16px;
    border-radius: 4px;
    border: none;
    box-shadow: 0 0 0 1px #ccc inset;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.form-text:focus,.form-textarea:focus{
    outline: 0;
    box-shadow: 0 0 0 2px rgb(33, 150, 243) inset;
}
.mandatory{
	font-size: 90%;
	color: #c52929;
}

.contact-size + .contact-size {
    margin-left: 10px;
}

.contact-size-txt {
    margin-left: 5px;
}
.form-textarea {
	height: 200px;
	display: block;
	width: 100%;
	padding: 4px 16px;
	border-radius: 4px;
	border: none;
	box-shadow: 0 0 0 1px #ccc inset;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	resize: vertical;
}
.box_precautions {
	margin: 2em 0;
    background: #f8f8f8;
    border: 1px solid #656565;
}
#second_contents .box_precautions h4.title {
    font-size: 1.2em;
    background: #656565;
    padding: 4px;
    text-align: center;
    color: #FFF;
    font-weight: bold;
	margin: 0;
}
.box_precautions .text_area {
    padding: 15px 20px;
    margin: 0;
}
.filelabel{
	display: inline-block;
	position: relative;
	background-color: #ca722a;
	color: #fff;
	font-size: 16px;
	padding: 10px 20px;
	border-radius: 2px;
	transition: all 0.5s;
	width: 100%;
    max-width: 400px;
	text-align: center;
	margin: .1em 0;
}
.filelabel:hover{
	background-color: #a75c20;
}

.fileinput{
	top: 0;
    left: 50%;
    max-width: 400px;
    transform: translateX(-50%);
	visibility: hidden;
	/* padding: 2px 0; */
	/* display: none; */
}

span.msg {
	color: #e40211;
}

/* //form */


@media screen and (min-width: 581px) {
	.to-top{
		padding-bottom: 1rem;
	}
	.to-top a{
		color: #666!important;
	}

	.event_outline dt {
		clear: left;
		float: left;
		width: 15%;
	}
	.event_outline dd {
		margin-left: 16%;
	}
	.lead_text h2{
		font-size: 32px;
		padding: 3rem 0 2rem;
	}
	/* button */
	.oubo_button {
		width: 60%;
		font-size: 21px;
	}
	ul.attention_text{
		margin-left: 0;
	}
	ul.attention_text.pc-inline {
		margin-left: 16px;
	}
	ul.attention_text.pc-inline li {
		display: inline-block;
		margin-right: 20px;
	}
	/* //button */
	/* form */
	.form-text {
		max-width: 400px;
	}
	.fileinput{
		left: 0;
		transform: none;
		/* display: none; */
	}
	/* //form */
}
@media screen and (max-width: 580px) {
	.text-ps-center{
		text-align: center;
	}
	.inner section{
		padding: 1rem 15px!important;
		width: auto;
		margin: 0;
	}
	.lead_text h2 br{
		/* display: none; */
	}
	.event_outline dl {
		font-size: 16px;
	}
	.event_outline dt{
		font-weight: 600;
		padding: 0 0.5rem;
		border-left: 5px solid #1b19bc;
		margin-bottom: 1rem;
	}
	/* form */
	#second_contents .box_precautions h4.title{
		border: none;
	}
	.last td:last-child {
		border-bottom: solid 1px #a7a7a7;
		width: 100%;
	}
	.oubo_table {
		width: 100%;
	}
	.oubo_table th,
	.oubo_table td {
		border-bottom: none;
		display: block;
		width: 100%;
	}
	#form.oubo_table th {
		width: 100%;
	}
	#form.oubo_table tr:last-child {
		border-bottom: 1px solid #a7a7a7;
	}
	.reset_button.return-btn ,
	.submit_button.return-btn {
		padding: 0.5rem 1rem;
	}

	/* //form */

}

/* event css */

.title-name-logo3 {
    width: auto;
    vertical-align: bottom;
    height: 20px;
    margin-left: 5px;
}



/**
 * Closing Style
 */
div.bloc.mrg-15B.nfd h2 {
	text-align:center;
	background:none;
}
.nfd p{
	text-align: center;
}
.nfd-404{
text-align: center;
	line-height: 1!important;
	color: #eeeeee;
}
#pan.closing ,
#pan.closing a ,
#pan.closing span ,
.to-top a.closing {
	color: #666666!important;
}
@media screen and (min-width:581px) {
	div.bloc.mrg-15B.nfd {
		/* width:958px; */
	}

	.nfd{
		box-sizing: border-box;
		padding: 6rem 2rem;
	}
	.nfd-404{
		font-size: 10rem;
	}
}

@media screen and (max-width:580px) {
	div.bloc.mrg-15B.nfd h2 {
		font-size: 1rem;
}
	div.bloc.mrg-15B.nfd {
		width:100%;
	}

	.nfd{
		box-sizing: border-box;
		padding: 3rem 2rem;
	}
	.nfd-404{
		font-size: 7rem;
	}
}


/**
 * Other Style
 */
.position-relative {
	position: relative;
}
.position-absolute {
	position: absolute;
}
.h-100 {
	height: 100%;
}

/* 2026/4/17~5/31 */
.d-blue, .green {
    color: #b50081;
    text-shadow: 3px 3px 0 #fff300;
}
section span.green {
  color: #04863f;
}
.oubo_button {
	width: 100%;
    /* height: 64px; */
    /* line-height: 64px; */
    background-color: #b50081;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    border-radius: 10px;
    padding: 1.5rem 0.5rem;
}
.oubo_button:hover {
	background-color: #900367;
	text-decoration: none;
	color: #FFF;
}
#second_contents h3.tit_outline02{
    text-align: left;
    font-weight: 600;
    font-size: 21px;
    position: relative;
    padding: 0.5rem 0;
    border-bottom: 4px solid #e17ba9;
    margin: 0 0 1.5rem;
    color: #b50081;
}
#second_contents h3.tit_outline02:before {
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 20%;
	height: 4px;
	content: '';
	background: #cc1b75;
}

/* 2026/4/3 */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0;
  font-family: "Helvetica Neue", Arial, "Hiragino Sans", "Yu Gothic", Meiryo, sans-serif;
  color: #1d2433;
  background:
    radial-gradient(circle at top left, rgba(228, 33, 45, 0.10), transparent 24%),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.75), transparent 18%),
    linear-gradient(180deg, #f5f8fc 0%, #eef3f8 100%);
  line-height: 1.7;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

.campaign-page {
  overflow: hidden;
}

.container {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.section {
  padding: 72px 0;
}

.section--light {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(10px);
}

.section--accent {
  background:
    linear-gradient(135deg, #d91f2b 0%, #b3121d 100%);
  color: #fff;
}

.hero {
  position: relative;
  padding: 88px 0 72px;
  background:
    linear-gradient(135deg, rgba(217, 31, 43, 0.96) 0%, rgba(167, 18, 27, 0.96) 100%);
  color: #fff;
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(4px);
  opacity: 0.22;
}

.hero::before {
  width: 360px;
  height: 360px;
  top: -80px;
  left: -100px;
  background: #ffffff;
}

.hero::after {
  width: 260px;
  height: 260px;
  right: -40px;
  bottom: -60px;
  background: #ffcf57;
}

.hero__inner {
  position: relative;
  z-index: 1;
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.hero__eyebrow {
  margin: 0 0 16px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.82);
}

.hero__title {
  margin: 0;
  font-size: clamp(2rem, 5vw, 4.4rem);
  line-height: 1.12;
  font-weight: 900;
  letter-spacing: 0.01em;
}

.hero__title span {
  color: #ffe36e;
  text-shadow: 0 3px 14px rgba(0, 0, 0, 0.18);
}

.hero__lead {
  margin: 18px 0 0;
  max-width: 720px;
  font-size: 1.05rem;
  color: rgba(255,255,255,0.92);
}

.hero__info {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 32px;
}

.hero-chip {
  padding: 18px 20px;
  border-radius: 18px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.2);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.12);
}

.hero-chip__label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.72);
}

.hero-chip strong {
  font-size: 1.05rem;
  line-height: 1.5;
}

.hero__cta {
  margin-top: 28px;
}

.cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 0 28px;
  border-radius: 999px;
  background: linear-gradient(180deg, #ffe36e 0%, #ffca2d 100%);
  color: #7a1018;
  font-size: 1rem;
  font-weight: 900;
  box-shadow: 0 16px 28px rgba(0,0,0,0.16);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 34px rgba(0,0,0,0.2);
}

.cta-button--large {
  min-height: 64px;
  padding: 0 34px;
  font-size: 1.05rem;
}

.section-heading {
  margin-bottom: 30px;
	margin: 0 10px 30px 10px;
}

.section-heading__sub {
  margin: 0 0 8px;
  color: #d91f2b;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

.section-heading h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3.5vw, 1.2rem);
  line-height: 1.2;
  font-weight: 900;
  color: #142033;
}

.section-heading--white .section-heading__sub,
.section-heading--white h2 {
  color: #fff;
}

.summary-grid,
.step-grid,
.prize-grid {
  display: grid;
  gap: 22px;
}

.summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.step-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.prize-grid {
  grid-template-columns: 1.2fr 1fr;
}

.summary-card,
.step-card,
.prize-card,
.info-panel,
.contact-box,
.final-cta__box {
  border-radius: 26px;
  box-shadow: 0 18px 40px rgba(14, 31, 53, 0.10);
}

.summary-card,
.step-card {
  padding: 26px 24px;
  background: #fff;
  border: 1px solid rgba(18, 35, 55, 0.08);
}

.summary-card h3,
.step-card h3 {
  margin: 0 0 12px;
  font-size: 1.1rem;
  line-height: 1.4;
  font-weight: 800;
  color: #16243a;
}

.summary-card p,
.step-card p {
  margin: 0;
  color: #4a5568;
}

.step-card {
  position: relative;
  padding-top: 72px;
}

.step-card__num {
  position: absolute;
  top: 20px;
  left: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, #d91f2b 0%, #ff6f3c 100%);
  color: #fff;
  font-weight: 900;
  font-size: 1rem;
}

.note-box {
  margin-top: 22px;
	margin-bottom: 22px;
  padding: 18px 20px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid rgba(20, 32, 51, 0.08);
  color: #4d5b70;
}

.note-box p {
  margin: 0;
}

.note-box p + p {
  margin-top: 6px;
}

.prize-card {
  padding: 30px 28px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(10px);
}

.prize-card--main {
  background: linear-gradient(135deg, rgba(255,255,255,0.20), rgba(255,255,255,0.10));
}

.prize-card__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  min-height: 34px;
  padding: 0 14px;
  margin: 0 0 14px;
  border-radius: 999px;
  background: #fff;
  color: #c21724;
  font-weight: 900;
  font-size: 1.9rem;
}

.prize-card h3 {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  line-height: 1.25;
  font-weight: 900;
}

.prize-card__count {
  margin: 14px 0 10px;
  font-size: 1.2rem;
  font-weight: 800;
  color: #fab424;
}

.prize-card__text {
  margin: 0;
  color: rgba(255,255,255,0.84);
}

.info-panel {
  padding: 26px 24px;
  background: #fff;
  border: 1px solid rgba(20, 32, 51, 0.08);
}

.info-list {
  margin: 0;
  padding-left: 1.2em;
}

.info-list li + li {
  margin-top: 8px;
}

.contact-box {
  margin-top: 22px;
  padding: 24px;
  background: linear-gradient(135deg, #1d2a3f 0%, #2f4567 100%);
  color: #fff;
}

.contact-box h3 {
  margin: 0 0 10px;
  font-size: 1.1rem;
}

.contact-box p {
  margin: 0;
}

.contact-box p + p {
  margin-top: 4px;
}

.final-cta {
  padding-top: 0;
}

.final-cta__box {
  padding: 34px 28px;
  text-align: center;
  background: #fff;
  border: 1px solid rgba(20, 32, 51, 0.08);
}

.final-cta__box h2 {
  margin: 0 0 10px;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.25;
  color: #142033;
}

.final-cta__box p {
  margin: 0 0 18px;
  color: #536277;
}

.sp-only {
  display: none;
}

@media (max-width: 900px) {
  .summary-grid,
  .step-grid,
  .prize-grid,
  .hero__info {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .section {
    padding: 52px 0;
  }

  .container,
  .hero__inner {
    width: min(100% - 20px, 1120px);
  }

  .hero {
    padding: 60px 0 52px;
  }

  .hero__lead {
    font-size: 0.98rem;
  }

  .hero-chip {
    padding: 16px;
    border-radius: 16px;
  }

  .summary-card,
  .step-card,
  .prize-card,
  .info-panel,
  .contact-box,
  .final-cta__box {
    border-radius: 20px;
  }

  .summary-card,
  .step-card,
  .prize-card,
  .info-panel,
  .contact-box {
    padding: 20px 18px;
  }

  .final-cta__box {
    padding: 28px 18px;
  }

  .sp-only {
    display: inline;
  }
}

/* ========================================
   Responsive
======================================== */

/* タブレット以下 */
@media (max-width: 1024px) {
  .container,
  .hero__inner,
  .sns-wrap,
  .sponsor-wrap {
    width: min(100% - 32px, 1120px);
  }

  .hero {
    padding: 64px 0 56px;
  }

  .hero__title {
    font-size: clamp(2rem, 5.8vw, 3.4rem);
    line-height: 1.2;
  }

  .hero__lead {
    font-size: 1rem;
  }

  .hero__info {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .summary-grid,
  .step-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .prize-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .section {
    padding: 56px 0;
  }
}


/* スマホ */
@media (max-width: 767px) {
  html {
    font-size: 15px;
  }

  body {
    line-height: 1.7;
  }

  .container,
  .hero__inner,
  .sns-wrap,
  .sponsor-wrap {
    width: min(100% - 20px, 1120px);
  }

  .hero {
    padding: 48px 0 40px;
  }

  .hero__eyebrow {
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    margin-bottom: 12px;
  }

  .hero__title {
    font-size: clamp(1.8rem, 8vw, 2.6rem);
    line-height: 1.25;
  }

  .hero__lead {
    margin-top: 14px;
    font-size: 0.95rem;
  }

  .hero__info {
    margin-top: 20px;
    gap: 10px;
  }

  .hero-chip {
    padding: 14px 14px;
    border-radius: 14px;
  }

  .hero-chip strong {
    font-size: 0.95rem;
    line-height: 1.5;
  }

  .hero__cta {
    margin-top: 20px;
  }

  .cta-button,
  .cta-button--large {
    width: 100%;
    min-height: 54px;
    padding: 0 16px;
    font-size: 0.96rem;
  }

  .section {
    padding: 44px 0;
  }

  .section-heading {
    margin-bottom: 22px;
  }

  .section-heading__sub {
    font-size: 0.72rem;
    margin-bottom: 6px;
    letter-spacing: 0.12em;
  }

  .section-heading h2 {
    font-size: clamp(1.45rem, 6.8vw, 2rem);
    line-height: 1.35;
  }

  .summary-grid,
  .step-grid,
  .prize-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .summary-card,
  .step-card,
  .prize-card,
  .info-panel,
  .contact-box,
  .final-cta__box {
    border-radius: 18px;
  }

  .summary-card,
  .step-card,
  .prize-card,
  .info-panel,
  .contact-box {
    padding: 18px 16px;
  }

  .step-card {
    padding-top: 64px;
  }

  .step-card__num {
    top: 16px;
    left: 16px;
    min-width: 46px;
    height: 46px;
    font-size: 0.95rem;
    border-radius: 12px;
  }

  .summary-card h3,
  .step-card h3,
  .prize-card h3,
  .contact-box h3 {
    font-size: 1rem;
    line-height: 1.5;
  }

  .summary-card p,
  .step-card p,
  .prize-card__text,
  .note-box,
  .info-list,
  .contact-box p,
  .final-cta__box p {
    font-size: 0.92rem;
  }

  .note-box {
    margin-top: 16px;
    padding: 14px 16px;
    border-radius: 14px;
		margin-bottom: 16px;
  }

  .prize-card {
    padding: 22px 16px;
  }

  .prize-card__label {
    min-width: 60px;
    min-height: 30px;
    font-size: 0.8rem;
    margin-bottom: 10px;
  }

  .prize-card h3 {
    font-size: 1.35rem;
    line-height: 1.35;
  }

  .prize-card__count {
    margin: 10px 0 8px;
    font-size: 1.05rem;
  }

  .info-panel {
    padding: 18px 16px;
  }

  .info-list {
    padding-left: 1.1em;
  }

  .info-list li + li {
    margin-top: 6px;
  }

  .contact-box {
    margin-top: 16px;
  }

  .final-cta__box {
    padding: 24px 16px;
  }

  .final-cta__box h2 {
    font-size: 1.4rem;
    line-height: 1.45;
  }

  .sp-only {
    display: inline;
  }
}


/* 極小スマホ */
@media (max-width: 374px) {
  .hero__title {
    font-size: 1.65rem;
  }

  .section-heading h2 {
    font-size: 1.3rem;
  }

  .cta-button,
  .cta-button--large {
    font-size: 0.9rem;
  }
}

@media (max-width: 580px) {
	.section-heading__sub.pre {
	  margin: 0 0 8px;
	  color: #fff;
	  font-size: 0.8rem;
	  font-weight: 800;
	  letter-spacing: 0.14em;
	}
	.prize-card__text {
	  margin: 0;
	  color: rgba(255,255,255,0.84);
	}

}
@media (min-width: 581px) {
	.prize-card__text {
	  margin: 0;
	  color: rgba(55,55,55,0.84);
	}

}

/* 2026/4/15 */
/* キャンペーン概要修正 */
.summary-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-bottom: 22px;
}

.summary-bottom {
  display: block;
}

.summary-card--products {
  width: 100%;
}

.summary-products-image {
  margin-top: 14px;
  text-align: center;
}

.summary-products-image img {
  display: block;
  width: 100%;
  max-width: 900px;
  height: auto;
  margin: 0 auto;
  border-radius: 16px;
}

/* スマホ */
@media (max-width: 767px) {
  .summary-top {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 14px;
  }

  .summary-products-image img {
    max-width: 100%;
  }
}
#second_contents h3 {
	/* color:#ffffff; */
}
/* 2026/4/16 */
/* h2アンダーライン */
@media screen and (min-width: 581px) {
	*, *::before, *::after {
	    box-sizing: border-box;
	}
	h2.underbar {
		position: relative;
    padding: 0.5rem 0;
		background: none;
		border-bottom: 4px solid #f08b27;
    margin: 0 0 1.5rem;
	}
	h2.underbar:before {
		position: absolute;
    bottom: -4px;
    left: 0;
    width: 20%;
    height: 4px;
    content: '';
    background: #e62310;
	}
	span.note {
		color: rgba(55, 55, 55, 0.84);
	}
}
/* =========================
   beljois campaign LP tune
========================= */

.section--lead {
  background:
    linear-gradient(180deg, #fff7ef 0%, #fffdf9 100%);
}

.appeal-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.appeal-card {
  position: relative;
  padding: 28px 22px 24px;
  border-radius: 24px;
  background: #fff;
  border: 1px solid rgba(20, 32, 51, 0.08);
  box-shadow: 0 18px 40px rgba(14, 31, 53, 0.08);
  overflow: hidden;
}

.appeal-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 6px;
  background: linear-gradient(90deg, #ff8e3c 0%, #ffd15c 100%);
}

.appeal-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  height: 56px;
  margin-bottom: 16px;
  border-radius: 16px;
  background: linear-gradient(135deg, #ff8e3c 0%, #ffb347 100%);
  color: #fff;
  font-weight: 900;
  font-size: 1rem;
  box-shadow: 0 10px 18px rgba(255, 126, 60, 0.22);
}

.appeal-card h3 {
  margin: 0 0 10px;
  font-size: 1.22rem;
  line-height: 1.45;
  font-weight: 800;
  color: #16243a;
}

.appeal-card p {
  margin: 0;
  color: #4a5568;
  line-height: 1.85;
}

.bonus-banner {
  margin-top: 26px;
  padding: 24px 22px;
  border-radius: 26px;
  background: linear-gradient(135deg, #ff7a18 0%, #ff4d4f 100%);
  color: #fff;
  text-align: center;
  box-shadow: 0 18px 36px rgba(255, 102, 0, 0.22);
}

.bonus-banner__lead {
  margin: 0 0 8px;
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.85);
}

.bonus-banner__text {
  margin: 0;
  font-size: clamp(1.3rem, 3vw, 2rem);
  line-height: 1.4;
  font-weight: 900;
}

.bonus-banner__text span {
  display: inline-block;
  margin-left: 0.2em;
  color: #fff36a;
  text-shadow: 0 3px 10px rgba(0,0,0,0.16);
}

.mid-cta {
  margin-top: 26px;
  text-align: center;
}

/* campaign summary custom */
.summary-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-bottom: 22px;
}

.summary-bottom {
  display: block;
}

.summary-card--products {
  width: 100%;
}

.summary-card__note {
  margin: 0 0 14px !important;
  color: #4a5568;
}

.summary-products-image {
  text-align: center;
}

.summary-products-image img {
  display: block;
  width: 100%;
  max-width: 980px;
  height: auto;
  margin: 0 auto;
  border-radius: 18px;
  /* box-shadow: 0 14px 28px rgba(0,0,0,0.10); */
}

/* prize */
.prize-card--main {
  position: relative;
  overflow: hidden;
}

.prize-card--main::after {
  content: "SPECIAL";
  position: absolute;
  top: 18px;
  right: -30px;
  padding: 6px 34px;
  background: rgba(255,255,255,0.18);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  transform: rotate(35deg);
}

/* reassure */
.section--reassure {
  padding-top: 0;
}

.reassure-box {
  padding: 34px 28px;
  border-radius: 28px;
  background:
    linear-gradient(135deg, #fff7ef 0%, #ffffff 100%);
  border: 1px solid rgba(20, 32, 51, 0.08);
  box-shadow: 0 18px 40px rgba(14, 31, 53, 0.08);
  text-align: center;
}

.reassure-box h2 {
  margin: 0 0 12px;
  font-size: clamp(1.7rem, 3.2vw, 2.5rem);
  line-height: 1.3;
  color: #16243a;
  font-weight: 900;
}

.reassure-box p {
  margin: 0 0 20px;
  color: #536277;
  line-height: 1.9;
}

/* subtle LP polish */
.hero__title {
  text-shadow: 0 6px 18px rgba(0,0,0,0.18);
}

.hero__lead {
  max-width: 760px;
}

.cta-button {
  position: relative;
}

.cta-button::after {
  content: "→";
  margin-left: 0.6em;
  font-weight: 900;
}

/* tablet */
@media (max-width: 1024px) {
  .appeal-grid {
    grid-template-columns: 1fr;
  }

  .summary-top {
    grid-template-columns: 1fr;
  }
}

/* smartphone */
@media (max-width: 767px) {
  .appeal-card,
  .bonus-banner,
  .reassure-box {
    border-radius: 20px;
  }

  .appeal-card {
    padding: 22px 16px 20px;
  }

  .appeal-card__icon {
    min-width: 48px;
    height: 48px;
    border-radius: 12px;
    margin-bottom: 12px;
  }

  .bonus-banner {
    margin-top: 18px;
    padding: 18px 16px;
  }

  .bonus-banner__text {
    font-size: 1.35rem;
    line-height: 1.5;
  }

  .mid-cta {
    margin-top: 18px;
  }

  .summary-top {
    gap: 14px;
    margin-bottom: 14px;
  }

  .summary-products-image img {
    max-width: 100%;
    border-radius: 14px;
  }

  .reassure-box {
    padding: 24px 16px;
  }

  .reassure-box h2 {
    font-size: 1.45rem;
    line-height: 1.4;
  }

  .reassure-box p {
    font-size: 0.94rem;
  }
}
.cta-button {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  max-width: 320px;
}
@media (max-width: 576px) {
    section h2 {
        margin: 0;
        padding: 7px 10px;
        font-size: 1em;
        color: #3F2121;
        text-shadow: 0 -1px 1px #fff;
        /* background: #e22092 -webkit-gradient(linear, 0% 0%, 0% 100%, from(#ffb6bd), to(#ff9d9d)); */
        background: #ffeeb6 linear-gradient(#ffe6b2, #ffbc9d)!important;
        border-top: 1px solid #ffca81;
        border-bottom: 1px solid #ffca81;
        height: auto;
    }
}



.appeal-card__image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.appeal-card__body {
  padding: 16px;
}

.appeal-card__num {
  font-weight: bold;
  color: #ff6b00;
  margin-bottom: 6px;
}

.bonus-banner {
  margin-top: 30px;
  padding: 24px;
  text-align: center;
  border-radius: 20px;
  background: linear-gradient(135deg, #ff5f2e, #ff8a00);
  color: #fff;
  font-weight: bold;
  font-size: 22px;
}

.bonus-banner span {
  display: block;
  font-size: 32px;
  margin-top: 5px;
}

.mid-cta {
  margin-top: 30px;
  text-align: center;
}
@media (max-width: 580px) {
	section .contents-text, section li, section p {
        font-size: 1.2em;
    }
	.cta-button, .cta-button--large {
		font-size: 1.2em;
	}
	.summary-card h3, .step-card h3, .prize-card h3, .contact-box h3 {
		font-size: 1.22rem;
		line-height: 1.5;
	}
	.summary-card p, .step-card p, .prize-card__text, .note-box, .info-list, .contact-box p, .final-cta__box p {
			font-size: 1.2em;
	}
	section .contents-text, section li, section p {
      font-size: 1.2em;
  }
	.reassure-box p {
        font-size: 1.2em;
  }
	.reassure-box h2 {
			line-height: 1.4;
			font-size: clamp(1.45rem, 6.8vw, 2rem);
	}
	#page_back a, .to-top a {
		width: 100%;
		display: block;
		padding: 20px 0;
		color: #ffffff !important;
		font-size: 1.2em;
		background-color: #ED7D91;
}
}
