@charset "UTF-8";

#friend * {
	font-family: "Noto Sans JP", "Roboto", "Zen Kaku Gothic New", "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
}

#friend {
	max-width: 755px;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	color: #222;
    letter-spacing: 0.1em;	
}

#friend div,
#friend p,
#friend span,
#friend h1,
#friend h2,
#friend h3,
#friend ul,
#friend li,
#friend a {
	box-sizing: border-box;
	text-decoration: none;
}

#friend img {
	display: block;
	max-width: 100%;
	width: auto;
	height: auto;
	margin: 0 auto;
}

#friend .header {
	margin: 0 auto 0%;
}

#friend .catch {
	margin: 0 auto 10%;
	font-size: min(3.7vw, 16px);
	font-weight: bold;
	letter-spacing: .15em;
	line-height: 2;
	text-align: center;
}
#friend .kome_aka {
	margin: 2% auto 5%;
	font-size: min(3.4vw, 14px);
	font-weight: bold;
	color: #F9070B;
	line-height: 2;
	text-align: center;
}

#friend .point {
	max-width: 800px;
	width: 83.33%;
	margin: 0 auto;
}

#friend .pointup_text {
	margin: -5% 0 8% 0;
	color: #f00000;
	font-size: min(4vw, 14px);
	font-weight: bold;
	text-align: center;
}

#friend .point_wrap {
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#friend .point_character {
	max-width: 368px;
	width: 46%;
	margin: 0 auto;
}

#friend .point_name {
	background: #129a68;
	color: #fff;
	font-size: min(3.1vw, 15px);
	font-weight: bold;
	letter-spacing: .12em;
	margin: 0 auto 7%;
	padding: 6.9% 0;
	text-align: center;
}

#friend .point_name.orange {
	background: #feac0f;
}

#friend .point_img {
	margin: 0 auto 18%;
}

#friend .point_text {
	font-size: min(3.1vw, 14px);
	font-weight: bold;
	letter-spacing: .14em;
	line-height: 2;
	margin: 0 auto min(15%, 50px);
}

#friend .point_text .green { color: #129a68; }
#friend .point_text .orange { color: #feac0f; }

#friend .point_btn,
#friend .btn_friend {
	max-width: 800px;
	width: 83.33%;
	margin: 0 auto min(17%, 60px);
}

#friend .point_btn a,
#friend .btn_friend a {
	position: relative;
	color: #fff;
	display: block;
	background: #fb8f22;
	padding: min(5%, 15px) 0;
	font-size: min(3.7vw, 16px);
	font-weight: bold;
	letter-spacing: .15em;
	text-align: center;
	border-radius: 4px;
}

#friend .point_btn a:before,
#friend .btn_friend a:before {
	content: "";
	border: solid transparent;
	border-width: min(0.5em, 6px); 
	border-left-width: min(0.6em, 8px);
	border-left-color: #fff;
	position: absolute;
	right: 4%;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
}

#friend .howto {
	position: relative;
	background: #f1f8e6;
	margin: 0 auto 11%;
	padding: 10% 0 6%;
}

#friend .howto_title {
	max-width: 233px;
	width: 24.27%;
	margin: 0 auto 10%;
}

#friend .howto_deco {
	max-width: 180px;
	width: 18.75%;
	position: absolute;
	right: 6%;
	top: -2%;
}

#friend .howto_subtitle {
	position: relative;
	background: #82be27;
}

#friend .howto_title_step {
	position: absolute;
	left: 5%;
	top: 50%;
	transform: translateY(-50%);
	max-width: 120px;
	width: min(12.5%, 70px);
}

#friend .howto_title_text {
	color: #fff;
	font-size: min(3.7vw, 15px);
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1;
	padding: 4% 0 4% 21%;
}

#friend .howto_content {
	max-width: 864px;
	width: 90%;
	margin: min(4%, 20px) auto min(2.8%, 15px);
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

#friend .howto_icon {
	max-width: 84px;
	width: 10.8%;
	margin: 0 7.7% 0 0;
}

#friend .howto_text {
	margin: 0;
	font-size: min(3.4vw, 14px);
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.8;
}

#friend .howto_note {
	width: 80%;
	margin: 0 0 2.5% 17%;
	font-size: min(2.8vw, 12px);
	font-weight: 500;
	line-height: 1.8;
	letter-spacing: .15em;
}

#friend .btnlist {
	max-width: 800px;
	width: 83.33%;
	margin: 0 auto 12%;
}

#friend .btnlist li {
	width: auto;
	margin: 0 auto 5%;
	border: solid min(0.2em, 3px) #82be27;
	border-radius: 5px;
	text-align: center;
	list-style: none;
}

#friend .btnlist li a {
	position: relative;
	display: block;
	padding: 3.4% 0;
	color: #82be27;
	background: #fff;
	font-size: min(3.4vw, 15px);
	font-weight: bold;
	letter-spacing: .15em;
}

#friend .btnlist li a:before {
	content: "";
	border: solid transparent;
	border-width: min(0.5em, 6px);
	border-left-width: min(0.6em, 8px);
	border-left-color: #82be27;
	position: absolute;
	right: 4%;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
}

#friend .roboto { font-family: 'Roboto', sans-serif; letter-spacing: 0.12em; }
#friend .roboto_num { font-family: 'Roboto', sans-serif; letter-spacing: 0; }

#friend .tokuten_title {
    background: #82be27;
    color: #fff;
    text-align: center;
    padding: min(3%, 15px) 0;
    font-size: min(5vw, 24px);
    font-weight: bold;
    letter-spacing: 0.1em;
    margin-bottom:6%;
}

#friend .condition_area {
    width: 90%;
    margin: 0 auto 8%;
}

#friend .condition_item {
    text-align: center;
    margin-bottom: 8%;
}

#friend .label_img {
    width: min(50%, 250px); 
    margin: 0 auto 4%;
}

#friend .condition_item .text {
    font-size: min(3.8vw, 17px);
    line-height: 1.8;
    letter-spacing: 0.1em;
    font-weight: 500;
    color: #222;
}

#friend .point_wrap {
    display: flex;
    justify-content: center; 
    gap: min(2vw, 10px);    
    width: 100%;
    max-width: 755px;       
    margin: 0 auto;
}

#friend .point_main_img {
    flex: 1;                
    max-width: 370px;       
}

#friend .point_main_img img {
    width: 100%;
    height: auto;
    display: block;
}

#friend .point_main_img {
    line-height: 0;
    font-size: 0;
}

#friend .recommend_ttl_img {
    width: 64%;
    margin: 0 auto 6%;
}

#friend .recommend_section {
    background-color: #e6f7f0;
    padding: 10% 0;
	margin: 8% auto;
    overflow: hidden; 
}

#friend .recommend_ftr_img { 
	width: 64%; 
	margin: 0 auto 0%; 
}

#friend .recommend_slider {
    width: 100%;
    margin-bottom: 8%;
}

#friend .recommend_slider .recommend_card {
    padding: 0 0.5%;
    box-sizing: border-box;
    outline: none;
}

#friend .recommend_card img {
    width: 100%;
    height: auto;
    display: block;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

#friend .fuan_section {
    background-color: #fffde6; 
    padding: 10% 0;
    margin-bottom: 12%;
    overflow: hidden;
}

#friend .fuan_ttl_img {
    width: 78%;
    margin: 0 auto 6%;
}

#friend .fuan_slider {
    width: 100%;
}

#friend .fuan_slider .fuan_card {
    padding: 0 0.5%;
    box-sizing: border-box;
    outline: none;
}

#friend .fuan_card img {
    width: 100%;
    height: auto;
    display: block;
    border: none;
    box-shadow: none;
}

#friend .howto_step_section {
    background-color: #e6f7f0; 
    padding: 0 0 10%;
    margin-bottom: 12%;
}

#friend .step_header {
    background: #129a68;
    color: #fff;
    text-align: center;
    padding: 2% 0;
    font-size: min(6vw, 27px);
    font-weight: 500;
    letter-spacing: 0.12em;
    margin-bottom: 5%;
}

#friend .step_content {
    width: 90%;
    margin: 0 auto;
    text-align: center;
}

#friend .step_num {
	color: #129a68;
    font-size: min(5.7vw, 25px);
    font-weight: bold;
    margin-bottom: 1%;
}

#friend .step_txt {
    font-size: min(4vw, 18px);
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 8%;
    letter-spacing: 0.1em;	
}
#friend .step_txt2 {
    font-size: min(4vw, 18px);
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 2%;
    letter-spacing: 0.1em;	
}

#friend .step_img {
    margin-bottom: 10%;
}

#friend .step_btn {
    width: 85%;
    margin: 0 auto 8%;
}

#friend .step_btn a {
    display: block;
    transition: opacity 0.3s;
}

#friend .step_btn a:hover {
    opacity: 0.9;
}

#friend .step_konomi_container {
    width: 100%;
    max-width: 600px; 
    margin: 0 auto;
    position: relative; 
}

#friend .konomi_badge {
    position: absolute;
    top: -5%;
    right: 1.8%;
    width: 44%;
    z-index: 2;
}

#friend .konomi_badge img {
    width: 100%;
    height: auto;
    display: block;
}

#friend .konomi_flex {
    display: flex;
    justify-content: space-between; 
    gap: 5%;                     
    width: 100%;
    margin: 0;
    margin: 0 auto 10%;	
}

#friend .konomi_item {
    flex: 1; 
}

#friend .konomi_item img {
    width: 100%; 
    height: auto;
    display: block;
}

#friend .step3_moda{
	margin: 5% auto 2%;
}
#friend .step3_moda2{
	margin: 5% auto 2%;
}
.modal_overlay {
    display: none;
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.6);
    z-index: 1000;
}

.modal_content {
    display: none;
    position: fixed;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 500px;
    background: #fff;
    border-radius: 15px;
    z-index: 1001;
    padding: 40px 20px;
}

.modal_overlay.is-active,
.modal_content.is-active {
    display: block;
}

.modal_inner {
    position: relative;
    text-align: center;
}

.modal_close_btn {
    position: absolute;
    top: -17%;
    right: 0;
    background: none;
    border: none;
    font-size: 23px;
    color: #666;
    cursor: pointer;
}

.modal_title {
    color: #129a68;
    font-size: min(5.5vw, 22px);
    font-weight: bold;
    display: inline-block;
    letter-spacing: 0.1em;	
    padding-bottom: 2%;
    margin-bottom: 5%;
    border-bottom: 2px dotted #129a68; 
}
.modal_title2 {
    color: #feac0f;
    font-size: min(5.5vw, 22px);
    font-weight: bold;
    display: inline-block;
    letter-spacing: 0.1em;	
    padding-bottom: 2%;
    margin-bottom: 5%;
    border-bottom: 2px dotted #feac0f; 
}
.modal_body p {
    font-size: min(3.8vw, 16px);
    line-height: 1.8;
    font-weight: 500;
    margin-bottom: 15px;
}

.modal_note {
    font-size: min(3.4vw, 14px) !important;
    margin-top: 10px;
}

#friend .howto_step_section.is-orange {
    background-color: #fff9e6; 
    letter-spacing: 0.1em;	
}

#friend .howto_step_section.is-orange .step_header {
    background: #feac0f;
}

#friend .howto_step_section.is-orange .step_num {
    color: #feac0f;
}

#friend .howto_step_section.is-orange .item_label {
    color: #feac0f;
    font-weight: bold;
    margin-bottom: 5%;
}

#friend .coupon_img {
    margin: 8% auto;
}

#friend .qa_section {
    width: 100%;
    margin-bottom: 8%;
}

#friend .qa_ttl {
    color: #82be27;
    text-align: center;
    font-size: min(6vw, 28px);
    font-weight: bold;
    letter-spacing: 0.2em;
    margin-bottom: 3%;
}

#friend .qa_container {
    padding: 0 2%;
}

#friend .qa_item {
    border-bottom: 0.2em solid #f4faeb;
}

#friend .qa_head {
    display: flex;
    align-items: center;
    padding: 5% 4%;
    cursor: pointer;
    position: relative;
    background: #fff;
}

#friend .qa_icon_q {
    color: #82be27;
    font-size: min(5vw, 22px);
    font-weight: 900;
    margin-right: 4%;
}

#friend .qa_question {
    flex: 1;
    font-size: min(3.8vw, 16px);
    font-weight: bold;
    line-height: 1.4;
    padding-right: 10%; 
}

#friend .qa_toggle {
    position: absolute;
    right: 4%;
    width: 18px;
    height: 18px;
}

#friend .qa_toggle::before,
#friend .qa_toggle::after {
    content: "";
    position: absolute;
    background-color: #222;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#friend .qa_toggle::before {
    width: 100%;
    height: 2px;
}

#friend .qa_toggle::after {
    width: 2px;
    height: 100%;
    transition: transform 0.3s;
}

#friend .qa_item.is-active .qa_toggle::after {
    transform: translate(-50%, -50%) rotate(90deg);
    opacity: 0;
}

#friend .qa_body {
    display: none; 
    background: #f4faeb; 
}

#friend .qa_body_inner {
    display: flex;
    padding: 5% 4%;
}

#friend .qa_icon_a {
    color: #82be27;
    font-size: min(5vw, 22px);
    font-weight: 900;
    margin-right: 4%;
}

#friend .qa_answer p {
    font-size: min(3.7vw, 15px);
    line-height: 1.8;
    font-weight: 500;
    margin-bottom: 3%;
}

#friend .qa_link {
    color: #82be27;
    font-weight: bold;
    text-decoration: underline;
    font-size: min(3.7vw, 15px);
}

#friend .qa_icon_q,
#friend .qa_icon_a {
    font-family: "Futura PT", "Futura", "Roboto", sans-serif;
}

#friend .qa_item:last-child {
    border-bottom: none;
}

#friend .ate_section li{
    line-height: 1.8;
    font-size: min(3.8vw, 16px);
    font-weight: bold;
    letter-spacing: 0.1em;
    margin-bottom: 1%;
    padding: 0px 7%;
}

#friend .point_footer_section {
    width: 100%;
    margin-top: 5%;
}

#friend .footer_inner {
    background-color: #f4faeb;
    padding: 8% 0 11%;
    margin: 12% auto;
}

#friend .footer_btn_list {
    width: 85%;
    margin: 0 auto;
}

#friend .footer_btn_list a {
    display: block;
    margin-bottom: 6%; 
}

#friend .footer_btn_list a:last-child {
    margin-bottom: 0;
}

#friend .main_action_btn {
    width: 85%;
    margin: 0 auto 15%;
}
#friend .main_action_btn2 {
    width: 85%;
    margin: 8% auto;
}
#friend .main_action_btn2 img{
    width: 100%;
    height: auto;
}

#friend .main_action_btn img,
#friend .footer_btn_list img {
    width: 100%;
    height: auto;
}

#friend .point_footer_section a {
    transition: opacity 0.3s;
}

#friend .point_footer_section a:hover {
    opacity: 0.9;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulseBtn {
    0% { transform: scale(1); }
    50% { transform: scale(1.03); }
    100% { transform: scale(1); }
}

.ani-fade {
    opacity: 1; 
}

.is_sp_view .ani-fade {
    opacity: 0;
}

.ani-fade.is-show {
    animation: fadeInUp 0.8s ease-out forwards;
}

.ani-pulse {
    animation: pulseBtn 2s infinite ease-in-out;
}

.delay-1 { animation-delay: 0.2s; }
.delay-2 { animation-delay: 0.4s; }


/* --- 追従バナー：中央固定の修正版 --- */
#friend .fixed_bnr {
    display: none;
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 500px; 
    z-index: 10;
    pointer-events: none;
}

#friend .fixed_bnr_btn {
    position: relative;
    width: 100%;
    margin: 0;
    pointer-events: auto; 
}

#friend .fixed_bnr_btn img {
    max-width: inherit;
    width: 100%;
    display: block;
}

#friend .fixed_bnr_btn_close {
    background-color: #fff;
    border: 0.3vw solid #fb8f22;
    border-radius: 100px;
    box-sizing: border-box;
    font-size: 0;
    height: 6vw;
    width: 6vw;
    max-height: 40px; 
    max-width: 40px;
    position: absolute;
    right: 1%;
    top: -1vw;
    cursor: pointer;
}

/* 閉じるボタンの「×」印 */
#friend .fixed_bnr_btn_close::before,
#friend .fixed_bnr_btn_close::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 2px;
    height: 50%;
    background: #fb8f22;
}
#friend .fixed_bnr_btn_close::before { transform: translate(-50%, -50%) rotate(45deg); }
#friend .fixed_bnr_btn_close::after { transform: translate(-50%, -50%) rotate(-45deg); }

/* 既存のappendtext */
.appendtext {
    position: fixed;
    top: 50%;
    left: 0;
    width: 100%;
    padding: 15px 0;
    background-color: #444444;
    font-size: 14px;
    line-height: 1;
    color: #ffffff;
    text-align: center;
    z-index: 2147483647;
    transform: translateY(-50%);
}

#scroll-pagetop {
	position: fixed;
	bottom: 2%;
	right: 10px;
	width: 100%;
    z-index: 3;	
	box-sizing: border-box;
	width: 50px;
	height: 50px;
	filter: drop-shadow(0px 0px 1px rgba(255, 255, 255, 0.8));
}