@charset "utf-8";

/* =========================================================
	 reset
========================================================= */
html,
body,
div,
span,
applet,
object,
iframe,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
 margin: 0;
 padding: 0;
 border: 0;
 font-style: normal;
 font-weight: normal;
 font-size: 100%;
 vertical-align: baseline;
}

article.btn-Area {
 text-align: right;
 width: 96%;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
 display: block;
}

html {
 overflow-y: scroll;
 font-family: "ヒラギノ角ゴ Pro W3";
}

blockquote,
q {
 quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
 content: '';
 content: none;
}

input,
textarea {
 margin: 0;
 padding: 0;
}

ol,
ul {
 list-style: none;
}

table {
 border-collapse: collapse;
 border-spacing: 0;
}

caption,
th {
 text-align: left;
 vertical-align: middle;
}

a:focus {
 outline: none;
}

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

.cf:after {
 content: ".";
 display: block;
 clear: both;
 height: 0;
 visibility: hidden;
}

.cf {
 min-height: 1px;
}

* html .cf {
 height: 1px;
 /*\*/
 /*/
	height: auto;
	overflow: hidden;
	/**/
}

.both {
 clear: both;
}

.clear {
 clear: both !important;
}

.float_l {
 float: left !important;
}

.float_r {
 float: right !important;
}

.text_l {
 text-align: left !important;
}

.text_r {
 text-align: right !important;
}

.text_c {
 text-align: center !important;
}

.smart_off {
 display: none !important;
}

.libox_photo span,
.de_h2 span,
.room_comment_rec {
 background: #d71718;
}

.room_comment_rec {
 border: none;
}

.libox a h2 {
 background: #f5f5f5;
 font-weight: bold;
}

.de_info th {
 background: #f5f5f5;

}

.search_submit2 {
 bottom: 77px;
}

.pan_wrap {
 margin: 10px 0;
}

.form_pri{
    display: none;
}

/* ----------------------------------------
　共通部分
---------------------------------------- */
.moji_red {
 color: #d71718 !important;
}

.moji_noto {
 font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
 font-optical-sizing: auto;
 font-weight: 700;
 font-style: normal;
}

.sp_off {
 display: none !important;
}

/* =========================================================
	 Body
========================================================= */
html,
body {
 position: relative;
 overflow: hidden;
 margin: 0;
 width: 100%;
 font-size: 6.25%;
 -webkit-text-size-adjust: 100%;
}

html {
 overflow-y: scroll;
 font-size: 6.25%;
}

body {
 position: relative;
 width: 100%;
 color: #333;
 font-family: -apple-system, BlinkMacSystemFont, 'Arial', '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
 font-size: 14rem;
 /* 14px */
 background: #fff;
}

ul,
li {
 margin: 0;
 padding: 0;
 list-style: none;
}

.cf:before,
.cf:after {
 content: '';
 display: block;
 overflow: hidden;
}

.cf:after {
 clear: both;
}

article {
 position: relative;
}

section {
 margin: 0;
}

/*main color #d71718*/
h1 {
 color: #333333;
 padding: 5px 2% !important;
 font-size: 9px !Important;
 width: 55%;
 background-color: #ffffff;
}

.head_title {
 width: 53%;
 color: #333;
 padding: 5px 2%;
}

.fonticon-color {
 color: #d71718;
}

.fonticon-color_inner i {
 color: #d71718;
}

.back-color {
 background: #d71718;
}


.boder-color {
 border-color: #d71718;
}

.boder_top-color {
 border-top-color: #d71718;
}

.boder_left-color {
 border-left-color: #d71718;
}

.headder_boder-color {
 border-top-color: #d71718;
}

.shadow-color {
 box-shadow: #A66400 0px 2px 0px 0px;
 -webkit-box-shadow: #A66400 0px 2px 0px 0px;
 -moz-box-shadow: #A66400 0px 2px 0px 0px;
}

/*sub color*/
.sub_color {
 background: #401000 !important;
}

.sub-border_color {
 border-color: #401000;
}

.sub-border-top_color {
 border-top-color: #401000;
}

.sub-border-bottom_color {
 border-bottom-color: #401000;
}

.tabList li.active {
 background: #401000;
}

.favorite-01 {
 color: #FFBF00;
}

.favorite-02 {
 color: #d71718;
}

.favorite-03 {
 color: #663300;
}

.favorite-04 {
 color: #000;
}

.favorite-05 {
 color: #D93600;
}

.favorite-06 {
 color: #684E02;
}

.favorite-07 {
 color: #465614;
}

.slide_list a i,
.slide_list a i {
 color: #d71718;
}

/* ----------------------------------------
全体のタイトルスタイル統一
---------------------------------------- */
/* H1 */
.rhs_title_h1 {
 width: 96%;
 margin: 15px auto 15px auto;
 padding: 0 0 10px 0;
 position: relative;
 font-size: 4vw;
 line-height: 24px;
 font-weight: bold;
 letter-spacing: 0.03em;
 border-bottom: 2px solid #DDD;
 background: none !important;
 color: #333 !important;
 text-overflow: clip;
 white-space: normal;
 overflow: initial;
}

.de_h2{
	font-size: 4vw !important;
	padding: 0 0 10px 0 !important;
}
.carousel_nav .flickity-slider img{
	object-fit: contain !important;
}
.de_h2 p{
	font-weight: bold;
}

.rhs_title_h1:after {
 position: absolute;
 content: ' ';
 border-bottom: solid 2px #d71718;
 bottom: -2px;
 width: 15%;
 display: block;
 left: 0px;
}

/* H2 */
.rhs_title_h2 {
 width: 96%;
 margin: 15px auto 15px auto;
 padding: 0 0 10px 0;
 position: relative;
 font-size: 4vw;
 line-height: 24px;
 font-weight: bold;
 letter-spacing: 0.03em;
 border-bottom: 2px solid #DDD;
 background: #fff;
 color: #000;
 text-overflow: clip !important;
 white-space: normal !important;
 overflow: initial;
}

.rhs_title_h2:after {
 position: absolute;
 content: ' ';
 border-bottom: solid 2px #d71718;
 bottom: -2px;
 width: 15%;
 display: block;
 left: 0px;
}

/* H3 */
.rhs_title_h3 {
 width: 96%;
 margin: 15px auto 15px auto;
 padding: 0 0 10px 0;
 position: relative;
 font-size: 3.5vw;
 line-height: 24px;
 font-weight: bold;
 letter-spacing: 0.03em;
 border-bottom: 2px solid #DDD;
}

.rhs_title_h3:after {
 position: absolute;
 content: ' ';
 border-bottom: solid 2px #d71718;
 bottom: -2px;
 width: 12%;
 display: block;
 left: 0px;
}

/* ----------------------------------------
　学区検索　表示・非表示
---------------------------------------- */
/*
.gakku_comment , .srch_school , .s-school , .sho_school , .sho_school_text , .list_map_school , .sho_catalog_school, .sho_school_ruiji{
	display:none;
}
*/

/* ----------------------------------------
　来店予約システム
---------------------------------------- */

/* ----------------------------------------
　利用する場合はこちらを読み込む
---------------------------------------- */

.on_raiten {
 display: none !important;
}


/* ----------------------------------------
　利用しない場合はこちらを読み込む
---------------------------------------- */
/*
.off_raiten{
	display:none !important;
}
*/

/* ----------------------------------------
フッター固定
---------------------------------------- */
footer {
 width: 100%;
 margin: 10% 0 0 0;
 padding-bottom: 120px;
 background-color: #f5f5f5;
}

.fixfoot {
 width: 100%;
 position: fixed;
 bottom: -1px;
 background-color: #FFF;
 z-index: 999;
 border-top: 2px solid #d71718;
 margin: 0px;
 padding: 0px;
 background-color: rgba(255, 255, 255, 0.95);
}

.fixfoot ul {
 width: 100%;
 margin: 0px;
 height: 100%;
 padding: 0px;
 list-style: none;
 display: flex;
}

.fixfoot ul li {
 text-align: center;
 vertical-align: middle;
 height: 100%;
 margin: 0px;
 padding: 0px;
 border-right: 1px solid #ddd;
 flex: 1;
 display: block;
}

.fixfoot ul li a {
 display: block;
 width: 100%;
 height: 100%;
 font-size: 13px;
 padding: 12px 0px 8px;
 margin: 0px;
 color: #333;
 font-weight: bold;
}

.fixfoot ul li a img {
 width: 70%;
 max-height: 65px;
}

.fixfoot ul li i {
 width: 100%;
 height: 17px;
 display: block;
 text-align: center;
}

.fixfoot ul li span {
 font-size: 12px;
}

.dra_tl p {
 background: #326598;
 color: #fff;
}

.fixfoot ul li:nth-child(3) i {
 color: #e10000;
}

.fixfoot ul li:nth-child(3) span {
 color: #e10000;
}

.fixfoot p {
 display: block;
 background: #d71718;
 text-align: center;
 color: #fff;
 font-weight: bold;
 font-size: 12px;
 line-height: 16px;
 padding: 3px;
}

/* ----------------------------------------
フッター会員メニュー
---------------------------------------- */
.f_mem_menu {
 background-color: #f5f5f5;
 width: 90%;
 margin: 10px auto 10px auto;
 padding: 0px 0px 15px 0px;
 border-radius: 5px;
 overflow: hidden;
}

.f_mem_menu h2 {
 background-color: #d71718;
 margin: 0 0 10px 0;
 padding: 5px 0;
 font-size: 13px;
 line-height: 20px;
 color: #FFF;
 font-weight: bold;
 text-align: center;
}

.f_mem_menu h3 {
 width: 90%;
 margin: 0px auto 10px auto;
 padding: 10px 0;
 background-color: #FFF;
 border-radius: 3px;
 font-size: 12px;
 line-height: 20px;
 color: #d71718;
 text-align: center;
}

.f_mem_menu ul {
 display: flex;
 flex-wrap: wrap;
 gap: 4px;
 width: 90%;
 list-style: none;
 margin: 0px auto;
 padding: 0px;
}

.f_mem_menu ul li {
 width: calc((100% - 4px)/2);
 margin: 0px;
 padding: 0px;
}

.f_mem_menu ul li a {
 display: flex;
 align-items: center;
 padding: 6px 4px 6px 4px;
 background: #FFF;
 border: 1px solid #d71718;
 border-radius: 3px;
 font-size: clamp(11px, 3vw, 13px);
 line-height: 20px;
 color: #d71718;
 font-weight: bold;
 text-decoration: none;
 position: relative;
}

.f_mem_menu ul li a:hover {
 background: #d71718;
 color: #FFF;
}

.f_mem_menu ul li a i {
 display: flex;
 align-items: center;
 justify-content: center;
 width: 16px;
 font-size: clamp(12px, 3.2vw, 14px);
 margin: 0 5px 0 0;
}

.f_mem_menu ul li a i.fa-calendar-check {
 font-size: clamp(13px, 3.5vw, 15px);
}

.f_mem_menu ul li a i.fa-arrow-right-from-bracket {
 font-size: clamp(11px, 3vw, 13px);
}

.f_mem_menu ul li a:after {
 content: "";
 width: 4px;
 height: 4px;
 box-sizing: border-box;
 margin: auto;
 border: 4px solid transparent;
 border-left: 4px solid #d71718;
 position: absolute;
 top: 0;
 bottom: 0;
 right: 1px;
 transition: all 0.3s;
}

/* ----------------------------------------
レンタルコンテンツのお問合せボタン
---------------------------------------- */
.rental_inq {
 width: 90%;
 margin: 0 auto;
}

.rental_inq a {
 box-sizing: border-box;
 border: 3px solid #ff7f00;
 background: #ff7f00;
 color: #fff;
 position: relative;
 display: block;
 font-size: 5.5vw;
 line-height: 5vh;
 padding: 5% 0;
 text-decoration: none;
 text-align: center;
 font-weight: bold;
 letter-spacing: 1px;
}

.rental_inq a:after {
 position: absolute;
 bottom: -5px;
 content: "";
 vertical-align: middle;
 right: -5px;
 box-sizing: border-box;
 width: 10px;
 height: 10px;
 border: 10px solid transparent;
 border-left: 10px solid #FFF;
 transform: rotate(45deg);
}


/* hamburger header_fix
---------------------------------------- */
.h_con_box {
 display: flex;
 gap: 0px 5px;
 position: absolute;
 top: 8px;
 right: 64px;
}

.h_con_box li {
 width: 40px;
}

.h_con_box li a {
 display: block;
}

header {
 height: 30px;
 box-shadow: 0px 5px 5px -5px rgba(0, 0, 0, 0.15);
}

header .logo {
 overflow: hidden;
 box-sizing: border-box;
 white-space: nowrap;
 text-align: left;
}

header .logo > a {
 display: block;
 width: 150px;
 padding: 0;
 padding-left: 2%;
}

header .logo img {
 display: block;
}

/*ナビメニューのスタイルを指定*/
.header_Toggle {
 display: block;
 position: fixed;
 right: 0px;
 top: 0px;
 width: 55px;
 height: 55px;
 cursor: pointer;
 z-index: 1001;
 background: #d71718;
 text-align: center;
 padding: 0px;
 margin: 0px;
 border: none;
}

.header_Toggle span {
 position: absolute;
 width: 28px;
 border-bottom: solid 2px #fff;
 -webkit-transition: .35s ease-in-out;
 -moz-transition: .35s ease-in-out;
 transition: .35s ease-in-out;
 left: 0px;
 right: 0px;
 margin: auto;
}

.header_Toggle span:nth-child(1) {
 top: 20px;
}

.header_Toggle span:nth-child(2) {
 top: 27.5px;
}

.header_Toggle span:nth-child(3) {
 top: 36px;
}

/* 最初のspanをマイナス45度に */
.acd-check_hamburger:checked ~ .header_Toggle span:nth-child(1) {
 top: 27.5px;
 -webkit-transform: rotate(-45deg);
 -moz-transform: rotate(-45deg);
 transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.acd-check_hamburger:checked ~ .header_Toggle span:nth-child(2),
.acd-check_hamburger:checked ~ .header_Toggle span:nth-child(3) {
 top: 27.5px;
 -webkit-transform: rotate(45deg);
 -moz-transform: rotate(45deg);
 transform: rotate(45deg);
}



nav.header_NavMenu {
 position: fixed;
 z-index: 1000;
 padding-top: 19px;
 top: 0px;
 left: 0;
 background: #fff;
 color: #000;
 text-align: center;
 width: 100%;
 height: 100%;
 transform: translateY(-103%);
 transition: all 0.5s 0s ease;
 overflow: scroll;
}

.header_NavMenu_box {
 background: none !important;
}

nav.header_NavMenu ul.menu_list {
 background: #fff;
 width: 100%;
 padding: 0;
 margin: 0;
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
 border-bottom: none;
 margin-bottom: 20px;
 margin-top: 3px;
}

nav.header_NavMenu ul.menu_list li {
 font-size: 1.1em;
 list-style-type: none;
 padding: 0;
 width: 50%;
 box-sizing: border-box;
}

nav.header_NavMenu ul.menu_list li a {
 display: flex;
 align-items: center;
 font-size: 13px;
 font-weight: normal;
 color: #000;
 text-decoration: none;
 text-align: left;
 line-height: 41px;
 position: relative;
 padding: 0px 11% 0px 5%;
 box-sizing: content-box;
}

nav.header_NavMenu ul.menu_list li a::after {
 content: '\f105';
 font-family: 'Font Awesome 5 Free';
 font-weight: 900;
 position: absolute;
 margin: 0;
 right: 12px;
 font-size: 13px !important;
}

nav.header_NavMenu .menu_list_title {
 font-weight: bold;
 text-align: left;
 line-height: 40px;
 font-size: 13px;
 border-bottom: 1px solid #ccc;
 background-color: #f7f7f7;
 border-top: 1px solid #555;
}

nav.header_NavMenu .menu_list_title i {
 margin-right: 5px;
 margin-left: 10px;
}

.acd-check {
 display: none;
}

.acd-check_hamburger {
 display: none;
}

.acd-label {
 background: #326598;
 color: #fff;
 display: block;
 padding: 10px;
 position: relative;
 text-align: left;
 border: none;
 width: 100%;
 margin: 0px 0px 1px 0px;
 font-size: 14px;
 line-height: 24px;
 border-radius: 0px;
 float: none;
 box-sizing: border-box;
}

.acd-label:after {
 background: #00000026;
 box-sizing: border-box;
 content: '';
 display: block;
 font-family: "Font Awesome 5 Free";
 height: 44px;
 width: 44px;
 padding: 0px;
 position: absolute;
 right: 0;
 top: 0px;
}

.acd-label::before {
 content: '';
 top: 11px;
 right: 14px;
 width: 12px;
 height: 12px;
 border-top: 2px solid #fff;
 border-right: 2px solid #fff;
 -webkit-transform: rotate(45deg);
 transform: rotate(135deg);
 position: absolute;
 z-index: 10;
 transition: 0.2s;
}

.acd-content {
 display: block;
}

.acd-check_hamburger:checked ~ .navmenu_wrap .header_NavMenu {
 transform: translateY(0%);
}

.acd-check:checked + .acd-label:before {
 transform: scale(-1, 1) rotate(315deg);
 top: 17px;
}

.acd-check:checked + .acd-label + .acd-content {
 opacity: 1;
 padding: 20px 10px 0px 10px;
 visibility: visible;
}

.acd-check:checked + .acd-label + .acd-content .menu_list_title {
 line-height: 18px;
 padding-bottom: 10px;
 font-size: 13px;
}

.acd-check:checked + .acd-label + .acd-content .menu_list_title i {
 display: inline-block;
}

.acd-check:checked + .acd-label + .acd-content ul.menu_list {
 margin: 0px auto 20px auto;
 border-left: 1px solid #cccccc;
 border-top: 1px solid #cccccc;

}

.acd-check:checked + .acd-label + .acd-content ul.menu_list li {
 border-bottom: 1px solid #cccccc;
 border-right: 1px solid #cccccc;

}

.acd-check:checked + .acd-label + .acd-content ul.menu_list li a {
 line-height: 20px;
 padding: 15px 16% 15px 6%;
 box-sizing: border-box;
 height: 100%;
 width: 100%;
}

.acd-content_sale {
 margin: 10px 0px 0px 0px;
}

.acd-content_sale ul {
 border-top: solid 1px #ccc;
}

.acd-content_sale ul li {}

.acd-content_sale ul li a {
 display: block;
 text-align: left;
 padding: 12px 0px 12px 10px;
 border-bottom: solid 1px #ccc;
 position: relative;
 font-size: 16px;
 background-color: #f5f5f5;
}

.acd-content_sale ul li a::before {
 content: '';
 top: 20px;
 right: 14px;
 width: 7px;
 height: 7px;
 border-top: 2px solid #333;
 border-right: 2px solid #333;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
 position: absolute;
 z-index: 10;
 transition: 0.2s;
}

/* hamburger header_fix end
---------------------------------------- */
/* ----------------------------------------
header_nav
---------------------------------------- */
header .accordionlist {
 width: 90%;
}

header .accordionlist ul li a::before {
 color: #fff;
}

header .button02 {
 z-index: 100;
}

header .button02 .f_link p {
 border: none;
 height: 30px;
 position: absolute;
 right: 2%;
 top: 22px;
}

header .button02 p span {
 width: 50%;
 padding: 0;
}

header .f_txt ul {
 width: 90%;
 margin: 40px auto;
}

header .f_title {
 text-align: left !important;
 background: #fff !important;
}

header .f_title_wrap {
 position: relative;
}

header .f_btn_block_det a {
 background: #fff !important;
}

header .f_accordionlist {
 margin: 40px auto !important;
}

header .f_accordionlist ul {
 padding: 0 0 15px !important;
}

header .f_accordionlist ul li a span {
 text-align: left !important;
 font-weight: bold;
}

header .f_contact_con {
 position: relative;
 bottom: 0;
 margin-bottom: 60px;
}

header .f_contact_con p {
 display: block;
 height: auto;
 border: none;
}

/* ----------------------------------------
/header_nav
---------------------------------------- */
.h_site_menu {
 border-top: 1px solid #fff;
 background: #d71718;
}

.h_site_menu ul {
 display: flex;
}

.h_site_menu ul li {
 width: 25%;
 text-align: center;
 font-size: 12px;
 padding: 5px 0;
 color: #fff;
 font-weight: bold;
}

.h_site_menu ul li a {
 display: block;
 font-size: 12px;
 color: #fff;
 font-weight: bold;
}

.h_site_menu_in {
 position: relative;
}

.h_site_menu_in::after {
 content: "";
 display: block;
 width: 100%;
 height: 3px;
 background: #F5E538;
 position: absolute;
 bottom: 0;
 left: 0;
}

.h_nav_main_btn a {
 display: block;
 border: 1px solid #d71718;
 color: #d71718;
 width: 80%;
 font-weight: bold;
 line-height: 56px;
 margin: 40px auto;
 border-radius: 40px;
 position: relative;
 font-size: 16px;
}

.h_nav_main_btn a::after {
 content: "";
 width: 6px;
 height: 6px;
 border-top: 2px solid #d71718;
 border-right: 2px solid #d71718;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
 position: absolute;
 right: 30px;
 top: 23px;
}

/* ----------------------------------------
/header_site_menu
---------------------------------------- */
.gallery {
 width: 100%;
 max-width: 620px;
 margin: 10px auto;
}

.gallery-slider {
 width: 100%;
 height: auto;
 margin: 0 0 10px 0;
}

.gallery-slider .swiper-slide {
 width: auto;
 height: auto;
}

.gallery-slider .swiper-slide img {
 display: block;
 width: auto;
 height: 100%;
 margin: 0 auto;
}

.gallery-thumbs {
 width: 100%;
 height: 50px;
 padding: 8px 0 0 0 !important;
 overflow: hidden;
 border-top: 2px solid #555;
}

.gallery-thumbs .swiper-slide {
 width: 90px;
 height: 50px;
 text-align: center;
 overflow: hidden;
 opacity: 0.3;
 text-align: center;
 font-size: 12px;
 font-weight: bold;
}

.gallery-thumbs .swiper-slide-active {
 opacity: 1;
}

.gallery-thumbs .swiper-slide img {
 width: auto;
 height: 100%;
}

.gallery-thumbs i {
 font-size: 20px;
 display: block;
 margin-bottom: 3px;
 line-height: 22px;
}

.swiper-button-next,
.swiper-button-prev {
 display: none;
}

.swiper-container-autoheight .swiper-wrapper {
 min-height: calc(100vh - 140px);
}

/**********
2023.03 マイページ改修
******************************/
/* main_mypage_menu */
.main_mypage_menu {
 margin: 0 0 10% 0;
}

.main_mypage_menu.main_mypage_menu_wide {
 width: 96%;
 margin: 0 auto 5% auto;
}

.main_mypage_menu ul {
 display: flex;
 flex-wrap: wrap;
 gap: 10px 2%;
 margin: 0;
 padding: 0;
 list-style: none;
}

.main_mypage_menu ul li {
 width: 49%;
}

.main_mypage_menu ul li p,
.main_mypage_menu ul li a {
 display: flex;
 align-items: center;
 justify-content: space-between;
 padding: 10px 10px 10px 12px;
 box-sizing: border-box;
 border: 1px solid #d71718;
 border-radius: 3px;
 box-shadow: 0px 1px 0px 0px #d71718;
 font-weight: bold;
 text-decoration: none;
}

.main_mypage_menu ul li a {
 color: #d71718;
}

.main_mypage_menu ul li p,
.main_mypage_menu ul li a.mypage_menu_ac {
 background: #d71718;
 color: #FFF;
}

.main_mypage_menu ul li p i.mypage_menu_icon,
.main_mypage_menu ul li a i.mypage_menu_icon {
 font-size: clamp(12px, 4vw, 16px);
}

.main_mypage_menu ul li p span,
.main_mypage_menu ul li a span {
 padding: 0 5px 0 0;
 font-size: clamp(11px, 3.2vw, 15px);
 line-height: clamp(14px, 5vh, 22px);
 font-weight: bold;
 letter-spacing: 0.05em;
}

.main_mypage_menu ul li p i.fa-angle-right,
.main_mypage_menu ul li a i.fa-angle-right {
 font-size: clamp(11px, 3.5vw, 15px);
 color: #d71718;
}


/* ----------------------------------------
footer
---------------------------------------- */
.f_contact_box {
 background-image: url(/img/sp_common/f_con_bg.webp);
 width: 100%;
 margin: 100px 0px 0px 0px;
 text-align: center;
 box-sizing: border-box;
 padding: 55px 0px 95px 0px;
 background-repeat: no-repeat;
 background-size: cover;
 position: relative;
}

.f_contact_box h2 {
 letter-spacing: 0;
 color: #ffffff;
 font-size: clamp(16px, 4.4vw, 18px);
 line-height: clamp(18px, 2.5vh, 20px);
 font-weight: bold;
}

.f_contact_eng {
 letter-spacing: 0.1em;
 color: #ffffff;
 margin: 7px 0px 0px 0px;
 font-size: clamp(35px, 9.7vw, 38px);
 line-height: clamp(38px, 5.4vh, 42px);
}

.f_contact_text {
 letter-spacing: 0.05em;
 color: #ffffff;
 font-weight: bold;
 font-size: clamp(12px, 3.3vw, 14px);
 line-height: clamp(22px, 3.1vh, 25px);
 margin: 25px 15px 0px 15px;
}

.f_contact_con {
 background-color: #ffffff;
 border-radius: 7px;
 box-sizing: border-box;
 padding: 25px 3% 18px 3%;
 width: 90%;
 box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
 position: absolute;
 bottom: -77px;
 left: 0;
 right: 0;
 margin: 0 auto;
}

.f_contact_con img {
 width: 67%;
}

.f_contact_con > p {
 font-size: clamp(12px, 3.3vw, 14px);
 line-height: clamp(22px, 3.1vh, 25px);
 margin: 5px 0px 0px 0px;
}

.f_contact_con ul {
 display: flex;
 align-items: center;
 justify-content: space-between;
 margin: 10px 0px 0px 0px;
}

.f_contact_con ul li {
 box-sizing: border-box;
 width: calc(calc(100% - 5px) / 2);
}

.f_contact_con ul li a {
 border-radius: 34px;
 letter-spacing: 0;
 font-weight: bold;
 display: block;
 box-sizing: border-box;
 position: relative;
 padding: 0px 0px 0px 10%;
 font-size: clamp(12px, 3.3vw, 14px);
 line-height: clamp(38px, 5.4vh, 42px);
}

.f_contact_con ul li:nth-child(1) a {
 background-color: #d71718;
 color: #ffffff;
 border: 2px solid #d71718;
}

.f_contact_con ul li:nth-child(1) a:before {
 content: "";
 position: absolute;
 top: 0px;
 bottom: 0;
 margin: auto;
 left: 18%;
 width: 13px;
 height: 14px;
 background-repeat: no-repeat;
 background-size: contain;
 background-image: url(/img/common/footer/f_con_btn_icon1.webp);
 transition: all 0.2s;
}

.f_contact_con ul li:nth-child(2) a {
 border: 1px solid #d71718;
 color: #d71718;
}

.f_contact_con ul li:nth-child(2) a:before {
 content: "";
 position: absolute;
 top: 11px;
 left: 27%;
 width: 14px;
 height: 15px;
 background-repeat: no-repeat;
 background-size: contain;
 background-image: url(/img/common/footer/f_con_btn_icon2.webp);
 transition: all 0.2s;
}

.f_contact_con ul li a p {
 font-weight: bold;
}

.f_btn_w {
 background-color: #f5f5f5;
 box-sizing: border-box;
 padding: 170px 0px 40px 0px;
}

.f_btn_in {
 width: 1100px;
 margin: 0 auto;
}

.f_sns_box {
 padding: 125px 0px 0px 0px;
 background-color: #f5f5f5;
}

.f_sns_box_l p {
 letter-spacing: 0.05em;
 margin: 10px 0px 0px 0px;
 font-size: clamp(12px, 3.3vw, 14px);
 line-height: clamp(22px, 3.1vh, 25px);
 text-align: center;
}

.f_sns_box_l a {
 display: block;
 width: 65%;
 margin: 0 auto;
}

.f_sns_box_r {
 display: flex;
 gap: 0px 10px;
 margin: 25px 0px 0px 0px;
 justify-content: center;
}

.f_sns_box_r li a {
 display: flex;
 width: 45px;
 height: 45px;
 background-color: #ffffff;
 border-radius: 50%;
 align-items: center;
 justify-content: center;
 box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
 transition: all 0.2s;
}

.f_sns_box_r li a:hover {
 box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.15);
}

.f_accordionlist .f_title_wrap .f_title {
 background-color: #f5f5f5;
}

.f_accordionlist {
 margin: 35px auto 0px auto;
 width: 90%;
 border-bottom: 1px solid #ccc;
}

.f_accordion_icon span {
 background-color: #d71718;
}

footer > a {
 display: block;
 width: 90%;
 margin: 40px auto 0px auto;
 box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
}

.f_btm_btn {
 display: flex;
 justify-content: center;
 transition: all 0.2s;
 margin: 55px 0px 0px 0px;
}

.f_btm_btn li {
 position: relative;
}

.f_btm_btn li a {
 margin: 0px 12px;
 font-size: clamp(9px, 2.5vw, 10px);
 line-height: clamp(12px, 1.7vh, 14px);
 letter-spacing: 0;
 transition: all 0.2s;
 display: block;
}

.f_btm_btn li:after {
 content: "";
 display: inline-block;
 width: 1px;
 height: 10px;
 background-color: #111111;
 position: absolute;
 top: 0;
 bottom: 0;
 margin: auto;
 right: 0;
}

.f_btm_btn li:last-child:after {
 display: none;
}

.f_copy {
 font-size: 10px;
 line-height: 15px;
 text-align: center;
 color: #aaaaaa;
 margin: 10px 0px 0px 0px;
}

.f_copy a {
 color: #aaa;
 text-decoration: underline;
}

.f_accordionlist ul li a {
 padding: 10px 15px;
}

.f_btn_block_det {
 display: block !important;
}

.f_btn_block_det li a {
 padding: 5px 15px !important;
}

/* ----------------------------------------
査定固定ボタン
---------------------------------------- */
.fix_linebtn {
 background: rgba(0, 0, 0, 0.6);
 position: fixed;
 left: 0;
 bottom: 0;
 padding: 3% 0;
 width: 100%;
 z-index: 500;
 display: none;
}

.fix_linebtn a {
 display: block;
 border: 2px solid #fff;
 width: 90%;
 text-align: center;
 background: #d71718;
 border-radius: 30px;
 font-size: 15px;
 font-weight: bold;
 line-height: 45px;
 color: #fff;
 margin: 0 auto;
 letter-spacing: 0.05em;
 position: relative;
}

.fix_linebtn a::before {
 content: "";
 width: 6px;
 height: 6px;
 border-top: 2px solid #fff;
 border-right: 2px solid #fff;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
 position: absolute;
 right: 25px;
 top: 19px;
}

.fix_linebtn a span {
 display: inline-block;
 background: #fff;
 color: #d71718;
 border-radius: 3px;
 width: 45px;
 line-height: 25px;
 margin-right: 5px;
 font-weight: bold;
 position: absolute;
 left: 5%;
 top: 10px;
}
