:root{
    --background-color:#3359A6;
    --brand-blue:#3359A6;
    --cta-pink-start:#FF708A;
    --cta-pink-end:#F05774;
    --cta-blue-start:#F1F8FF;
    --cta-blue-end:#D2E7FF;
}
html{scroll-behavior:smooth}
body{margin:0;padding:0;box-sizing:border-box;font-family:'ヒラギノ角ゴシック','Hiragino Sans','メイリオ',Meiryo,sans-serif}

#background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1}
#background img{width:100vw;height:100vh;object-fit:cover}
.section_title{margin:60px 0 25px;text-align:center;letter-spacing:2px;font-size:28px;font-weight:600;color:#333}
.section_title span{display:block;color:var(--brand-blue);font-size:18px;font-weight:600}
.section_description{margin:10px 20px;text-align:center;color:#333;font-size:14px;font-weight:600;letter-spacing:2px}

.cta_button_outer{position:relative}
.cta_button{display:inline-block;width:calc(100% - 104px);margin:20px;padding:24px 32px;font-size:20px;font-weight:500;color:#fff;background:linear-gradient(180deg,var(--cta-pink-start) 0%,var(--cta-pink-end) 100%);border-radius:64px;text-decoration:none;box-shadow:0 10px 24px rgba(240,87,116,.35);letter-spacing:4px;text-align:center}
.cta_button_outer .cta_speech_bubble{position:absolute;background:#fff;border:2.5px solid var(--brand-blue);border-radius:30px;padding:10px 20px;color:var(--brand-blue);font-size:16px;font-weight:500;top:-25px;left:50%;transform:translateX(-50%);width:240px;text-align:center}
.cta_button_outer .cta_speech_bubble::after{content:"";position:absolute;bottom:-11px;left:50%;width:16px;height:16px;background:#fff;border-right:2.5px solid var(--brand-blue);border-bottom:2.5px solid var(--brand-blue);transform:translateX(-50%) rotate(45deg);border-bottom-right-radius:2.5px;z-index:11}
.contact_button{display:inline-block;width:calc(100% - 104px);margin:20px;padding:24px 32px;font-size:20px;font-weight:500;color:#fff;background:linear-gradient(180deg,#48C7FF 0%,#2DA1C8 100%);border-radius:64px;text-decoration:none;box-shadow:0 10px 24px rgba(45,161,200,.35);letter-spacing:4px;text-align:center}

#operation .section_description{font-weight:400;text-align:left}
#pc_nav{position:fixed;top:103px;left:60px;width:260px;background:#fff;border-radius:24px;padding:28px 32px;box-shadow:0 16px 40px rgba(0,0,0,.18);z-index:10}

#pc_nav .menu_title{display:flex;align-items:center;gap:16px;font-weight:700;font-size:23px;color:var(--brand-blue)}
#pc_nav .menu_title>span:first-child{letter-spacing:2px}
#pc_nav .border_line{display:block;flex:1;height:0;border-top:3px solid transparent;border-image:repeating-linear-gradient(to right,var(--brand-blue) 0 18px,transparent 18px 26px) 6 stretch;opacity:.9;margin:6px 0}
#pc_nav .menu_list{list-style:none;padding:0;margin:18px 0 22px}
#pc_nav .menu_list li{position:relative;padding-left:20px;margin:9px 0;font-size:18px;font-weight:600;color:var(--font-color)}
#pc_nav .menu_list li::before{content:"";position:absolute;left:0;top:.9em;width:10px;height:10px;background:var(--brand-blue);transform:translateY(-50%)}
#pc_nav .menu_list a{color:inherit;text-decoration:none}
#pc_nav .menu_list a:hover{color:var(--brand-blue)}

#pc_nav .cta_note{width:calc(100% - 70px);display:inline-block;color:var(--brand-blue);font-weight:600;font-size:16px;padding:10px 22px;margin:15px 10px 0;border:3px solid var(--brand-blue);border-radius:999px;background:#fff;position:relative;text-align:center;z-index:10}
#pc_nav .cta_note::after{content:"";position:absolute;left:50%;bottom:-11px;width:16px;height:16px;background:#fff;border-right:3px solid var(--brand-blue);border-bottom:3px solid var(--brand-blue);transform:translateX(-50%) rotate(45deg);border-bottom-right-radius:3px;z-index:11}
.view_stable_button{display:block;text-align:center;padding:18px 24px;font-size:20px;font-weight:500;color:#fff;background:linear-gradient(180deg,var(--cta-pink-start) 0%,var(--cta-pink-end) 100%);border-radius:64px;text-decoration:none;box-shadow:0 10px 24px rgba(240,87,116,.35)}
.view_stable_button:hover{transform:scale(1.05);transition:transform .3s ease}



main{background:linear-gradient(180deg,var(--cta-blue-start) 0%,var(--cta-blue-end) 100%);max-width:500px;border-radius:24px;margin:103px calc((100vw - 500px) * 0.35) 103px calc((100vw - 500px) * 0.65);min-height:100vh;overflow:hidden}
#index{background:#fff;padding-top:20px}
#index #index_inner{margin:0 20px;padding-bottom:80px;background:linear-gradient(180deg,var(--cta-blue-start) 0%,var(--cta-blue-end) 100%)}
#index #index_title{width:280px;margin:0 auto;padding-top:65px;text-align:center}
#index #index_title img{width:280px;height:auto;display:block}
#index img#index_horses{width:280px;margin:10px calc((100% - 280px) / 2)}
#index #index_catchphrase{text-align:center;font-size:17px;font-weight:600;color:var(--brand-blue);margin:5px 0 20px;letter-spacing:1px}

#index #index_cta_area{position:absolute;top:-60px;left:0;width:calc(100% - 63px);margin:0 27.5px;padding-top:30px;border-radius:20px;border:var(--brand-blue) 4px solid;background:#fff;text-align:center;box-shadow:0 8px 24px rgba(51,89,166,.18)}
#index #index_cta_area #index_cta_note{display:block;font-size:16px;font-weight:600;color:#333;padding:14px 20px 0;letter-spacing:2px}
#index #index_cta_area #index_cta_note_main span{color:var(--brand-blue)}
#index #index_cta_area #index_cta_note_sub{display:block;font-size:14px;font-weight:500}
#index #index_cta_area #speech_bubble{position:absolute;top:-30px;right:20px;width:calc(100% - 40px);border-radius:30px;padding:15px 0;background:var(--brand-blue);color:#fff;font-size:16px;font-weight:500;text-align:center;letter-spacing:2px}
#index #index_cta_area #speech_bubble::after{content:"";position:absolute;bottom:-7.5px;left:50%;transform:translateX(-50%);width:20px;height:10px;background:var(--brand-blue);clip-path:polygon(0 0,100% 0,50% 100%)}

#index_bottom_spacer{position:relative;width:100%;height:200px}

#why_section h2{margin:60px 10px 10px;font-size:24px;font-weight:500;letter-spacing:2px;text-align:center;color:#333;}
#why_section ul{display:flex;flex-direction:column;gap:12px;margin:0 15px 15px; background-color: #fff; border-radius:16px; padding:20px;}
#why_section ul li{position:relative;display:flex;align-items:center;justify-content:space-between;list-style:none;padding-left:22px;font-size:18px;font-weight:500;color:#333}
#why_section ul li::before{content:"";position:absolute;left:0;top:50%;width:10px;height:10px;background:var(--brand-blue);transform:translateY(-50%)}
#why_section p {margin:0 20px 40px;font-size:20px;font-weight:400;letter-spacing:1px;color:#333;text-align:center;}

#howto_steps{display:flex;flex-direction:column;gap:20px;margin:0 15px;width:calc(100% - 30px)}
#howto_steps .howto_step{background:#3359A6;color:#fff;border-radius:16px;padding:0 20px;width:calc(100% - 40px)}
#howto_steps .howto_step .howto_step_title{display:block;letter-spacing:1px;font-weight:600;margin:14px 0 0}
#howto_steps .howto_step .howto_step_title_step{display:block;font-size:16px;font-weight:500;letter-spacing:2px}
#howto_steps .howto_step .howto_step_title_step .howto_step_number{display:inline-block;margin-left:2px;font-size:20px;font-weight:600}
#howto_steps .howto_step .howto_step_subtitle{display:block;font-size:22px;font-weight:400;margin-top:6px;letter-spacing:1px}
#howto_steps .howto_step .howto_step_description{margin:0;font-size:16px;font-weight:500}

#howto_steps .howto_step img{display:block;width:90%;margin:20px auto 0}
#howto_steps .howto_step img#step04_image{margin-bottom:15px}
#howto_steps .howto_step #accessory_lists{display:flex;flex-wrap:nowrap;list-style:none;width:100%;gap:10px;padding:0;padding-bottom:30px}
#howto_steps .howto_step #accessory_lists li { position: relative; list-style: none; width: calc(100% / 3 - 20px / 3);text-align: center;}
#howto_steps .howto_step #accessory_lists li .background {width: 100%; aspect-ratio: 1; top: 0; left: 0; z-index: -1; overflow: hidden;}
#howto_steps .howto_step #accessory_lists li .background svg {width: 100%;height: 100%;}
#howto_steps .howto_step #accessory_lists li .background img {position: absolute; top: 50%;left: 50%;transform: translate(-50%, -50%);width: 100%;margin: 0;}
#howto_steps .howto_step #accessory_lists li span {display: block;width: 150%;position: absolute;top: calc(100% + 6px);left: 50%;transform: translateX(-50%);text-align: center;}

#try_free_inner{position:relative;background:repeating-linear-gradient(-67deg,#3359A6,#3359A6 20px,rgb(81,114,179) 20px,rgb(81,114,179) 45px);border-radius:16px;margin:80px 0 0;padding:40px 20px;text-align:center;color:#fff}
#try_free_inner img#try_free_horse{width:123px;position:absolute;top:-70px;right:20px}
#try_free_inner #try_free_header .try_free_title,#try_free_feature .try_free_title{margin:10px 0;font-weight:500;font-size:30px;letter-spacing:1px}
#try_free_inner #try_free_header .try_free_title .hiragana,#try_free_feature .try_free_title .hiragana{font-size:26px;margin-left:2px}
#try_free_inner #try_free_header .try_free_title .number,#try_free_feature .try_free_title .number{font-style:italic;font-size:32px}
#try_free_inner #try_free_header .try_free_title .days,#try_free_feature .try_free_title .days{font-size:28px}
#try_free_feature .try_free_title .sub_title{
    display:block;
    font-size:18px;
    font-weight:500;
}
#try_free_inner #try_free_header #try_free_subtitle{font-size:14px;font-weight:500;margin:0 0 40px;letter-spacing:1px}
#try_free_inner #try_free_example{display:flex;justify-content:center;gap:10px;margin-bottom:40px;list-style:none;padding:0}
#try_free_inner #try_free_example li{width:calc((100% - 10px) / 2)}
#try_free_inner #try_free_example li img{display:block;width:100%;margin:0}
#try_free_inner #try_free_example li .voice_box{display:block;position:relative;background:#fff;width:calc(100% - 20px);border-radius:8px;padding:10px;margin:0 0 10px;font-size:17px;color:#333;font-weight:500}
#try_free_inner #try_free_example li .voice_box::after{content:"";position:absolute;bottom:-10px;left:20px;width:16px;height:10px;background:#fff;clip-path:polygon(0 0,100% 0,50% 100%)}
#try_free_inner #try_free_dress_up{width:calc(100% - 48px);margin:0;padding:16px 24px;background:#fff;border-radius:24px;text-align:center;color:var(--brand-blue)}
#try_free_inner #try_free_dress_up #try_free_dress_up_title{font-size:24px;font-weight:600;margin:10px 0 6px}
#try_free_inner #try_free_dress_up #try_free_dress_up_subtitle{font-size:14px;font-weight:500;margin:0 0 12px}
#try_free_inner #try_free_dress_up #try_free_dress_up_examples{display:flex;flex-direction:column;justify-content:center;gap:5px;list-style:none;padding:0;width:80%;margin:5px auto 20px;min-width: 250px}
#try_free_inner #try_free_dress_up #try_free_dress_up_examples li{position:relative;display:flex;align-items:center;gap:10px;font-size:22px;font-weight:500;width:100%;color:#333}
#try_free_inner #try_free_dress_up #try_free_dress_up_examples li .background{width:72px;height:72px;position:relative;overflow:hidden}
#try_free_inner #try_free_dress_up #try_free_dress_up_examples li .background svg{width:100%;height:100%}
#try_free_inner #try_free_dress_up #try_free_dress_up_examples li .background img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;margin:0; object-fit: cover;}

#try_free_feature #try_free_feature_inner{position:relative;background:linear-gradient(86.38deg,#48C7FF -5.93%,#2DA1C8 152.29%);color:#fff;text-align:center;padding:20px 0 35px;margin-top:80px}
#try_free_feature #try_free_feature_inner h2{margin:20px 0}
#try_free_feature #try_free_feature_list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;list-style:none;padding:20px 20px 30px;background:#fff;margin:0 20px;border-radius:24px;color:#333}
#try_free_feature #try_free_feature_list li{display:flex;gap:4px;align-items:center;justify-content:start;padding:10px 0;font-size:16px;font-weight:600}
#try_free_feature #try_free_feature_list li:nth-child(odd){width:calc((100% - 10px) * .65)}
#try_free_feature #try_free_feature_list li:nth-child(even){width:calc((100% - 10px) * .35)}
#try_free_feature img#try_free_feature_horse{position:absolute;top:-120px;left:-100px}
#try_free_feature img#try_free_feature_horse2{position:absolute;bottom:0;right:50%;transform:translateX(50%)}

#try_free_feature #after_free_period_note{padding:30px 0}
#try_free_feature #after_free_period_note .speech_bubble{display:block;position:relative;background:var(--brand-blue);color:#fff;padding:12px 20px;border-radius:30px;font-size:24px;font-weight:500;letter-spacing:2px;margin:0 25px 20px;width:calc(100% - 90px);text-align:center}
#try_free_feature #after_free_period_note .speech_bubble::after{content:"";position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:20px;height:10px;background:var(--brand-blue);clip-path:polygon(0 0,100% 0,50% 100%)}
#try_free_feature #after_free_period_note ul{padding:0;width:calc(100% - 40px);margin:0 20px}
#try_free_feature #after_free_period_note ul li{position:relative;display:flex;align-items:center;justify-content:space-between;list-style:none;padding-left:22px;margin:10px 0;font-size:16px;font-weight:500;color:#333}
#try_free_feature #after_free_period_note ul li::before{content:"";position:absolute;left:0;top:50%;width:10px;height:10px;background:var(--brand-blue);transform:translateY(-50%)}
#try_free_feature #after_free_period_note ul li .title{font-weight:500;font-size:24px}
#try_free_feature #after_free_period_note ul li .description{font-size:16px}
#try_free_feature #after_free_period_note ul li .description .number{display:inline-block;margin-right:3px;font-weight:600;font-size:40px;font-family:Helvetica,Arial,sans-serif;color:var(--brand-blue)}
#try_free_feature #after_free_period_note #note_description{font-size:20px;font-weight:300;color:#333;margin: 0 10px 8px 10px;text-align:center}
#try_free_feature #after_free_period_copy{padding:30px 20px;background:var(--brand-blue);color:#fff;text-align:center}
#try_free_feature #after_free_period_copy .line{display:block;font-size:24px}
#try_free_feature #after_free_period_copy .line .hiragana{font-size:20px;margin:0 1px}
#try_free_feature #after_free_period_copy .line .number{font-style:italic}

#purpose ol{display:flex;flex-direction:column;gap:6px;padding:0;margin:0 20px}
#purpose ol li{display:flex;align-items:top;list-style:none;background:#fff;padding:15px;border-radius:16px}
#purpose ol li .purpose_number{display:block;width:32px;color:var(--brand-blue);font-size:20px;font-weight:700;font-family:Helvetica,Arial,sans-serif}
#purpose ol li .purpose_description{display:block;width:calc(100% - 38px);font-size:16px;font-weight:600;letter-spacing:2.5px;color:var(--brand-blue)}
#purpose ol li .purpose_description .note{display:block;font-size:12px;font-weight:300; letter-spacing: 0.5px}
#purpose .purpose_message{margin:25px 0;font-size:12px;font-weight:400;text-align:center;letter-spacing:2px}

#cta{position:relative}
#cta img{width:100%}
#cta .cta_button_outer{display:block;position:absolute;bottom:45px;width:100%}
#operation #for_organizations{width:100%;margin:20px 0;padding:0;border-radius:16px;background:#fff;overflow:hidden;text-align:center}
#operation #for_organizations h3{width:calc(100% - 40px);background:var(--brand-blue);margin:0;padding:25px 20px;color:#fff;letter-spacing:2px;font-weight:500;font-size:20px}
#operation #for_organizations h3 .hiragana{font-size:16px}
#operation #for_organizations h3 #for_organizations_subtitle{display:block;font-size:16px;font-weight:400}
#operation #for_organizations p#for_organizations_description{width:calc(100% - 40px);margin:40px 20px;font-size:16px;font-weight:500;color:var(--brand-blue);letter-spacing:2px;text-align:left}
#operation #for_organizations #for_organizations_contact{width:calc(100% - 70px);background:#E8F3FF;margin:20px;padding:10px 15px;border-radius:16px;text-align:left}
#operation #for_organizations #for_organizations_contact ul{display:flex;flex-direction:column;gap:15px;padding:0}
#operation #for_organizations #for_organizations_contact ul li{display:flex;align-items:center;justify-content:space-between;position:relative;list-style:none;padding-left:22px;font-size:17px;font-weight:500;letter-spacing:2px;color:#333}
#operation #for_organizations #for_organizations_contact ul li::before{content:"";position:absolute;left:0;top:50%;width:10px;height:10px;background:var(--brand-blue);transform:translateY(-50%)}
#operation #for_organizations #for_organizations_contact ul li img{width:60px;height:60px}
#operation #for_organizations .marker{display:inline-block;margin:0 auto 20px;font-weight:500;letter-spacing:1px;position:relative;background:linear-gradient(to bottom,transparent 70%,#44C1F64D 70%);text-align:center}
#operation #for_organizations #contact{width:calc(100% - 40px);margin:20px;background:linear-gradient(90deg,#48C7FF 0%,#2DA1C8 100%);border-radius:20px;padding:0 2px 2px 2px;overflow:visible}
#operation #for_organizations #contact h4{background:linear-gradient(90deg,#48C7FF 0%,#2DA1C8 100%);color:#fff;font-size:22px;font-weight:500;padding:20px 0;margin:0;letter-spacing:1px;border-radius:20px 20px 0 0}
#operation #for_organizations #contact h4 span{display:block;font-size:18px;letter-spacing:2px}
#operation #for_organizations #contact #contact_contents{background:#E4F8FF;margin:0 1px 1px;border-radius:0 0 17px 17px;box-shadow:0 8px 20px rgba(72,199,255,.25)}
#operation #for_organizations #contact #contact_contents p{text-align:left;padding-top:20px;margin:0 15px 10px;letter-spacing:2px;font-weight:500}

#voice ul#voice_list{display:flex;overflow-x:auto;gap:10px;padding:0;width:100%;margin:0}
#voice ul#voice_list li{list-style:none;width:calc(100% - 110px);margin:0 0 20px;background:#fff;border-radius:16px;padding:25px;box-shadow:0 8px 24px rgba(0,0,0,.12);flex-shrink:0}
#voice ul#voice_list li:first-child{margin-left:20px}
#voice ul#voice_list li:last-child{margin-right:20px}
#voice ul#voice_list li .user{display:flex;gap:10px;align-items:center}
#voice ul#voice_list li .user .user_icon{width:80px;height:80px;border-radius:50%;object-fit:cover}
#voice ul#voice_list li .user .user_icon img{width:100%;height:100%;border-radius:50%;object-fit:cover}
#voice ul#voice_list li .user .user_info{width:calc(100% - 90px)}
#voice ul#voice_list li .user .user_info .user_history{display:block;font-weight:500}
#voice ul#voice_list li .user .user_info .user_history .number{display:inline-block;font-size:20px;margin:0 2px 0 4px}
#voice ul#voice_list li .user .user_info .horse{display:block;font-weight:500}
#voice ul#voice_list li .user .user_info .horse .label{margin-right:6px}
#voice ul#voice_list li .user .user_info .user_names{display:block;font-weight:500}
#voice ul#voice_list li .user .user_info .user_names span:first-child{display:inline-block;margin:0 2px 0 0}
#voice ul#voice_list li .user .user_info .user_names span{display:inline-block;margin:0 2px}
#voice ul#voice_list li .voice_comment{font-family:14px;font-weight:300;margin:20px 0 0; line-height:.1.8; color:#333;}

details.faq_item{width:calc(100% - 44px);margin:0 20px 20px;border-radius:8px;background:var(--brand-blue);border:solid 2px var(--brand-blue);padding:0;overflow:hidden}
details.faq_item summary.faq_question{display:flex;align-items:center;gap:10px}
details.faq_item summary.faq_question span{display:block}
details.faq_item summary.faq_question::after{content:'+';font-size:28px;font-weight:400;position:absolute;right:20px;top:50%;transform:translateY(-50%)}
details[open].faq_item summary.faq_question::after{content:'-';font-weight:400;font-size:28px;position:absolute;right:20px;top:50%;transform:translateY(-50%)}
details.faq_item summary.faq_question{color:#fff;font-weight:400;font-size:16px;padding:15px 40px 15px 15px;position:relative}
.faq_answer{background:#fff;padding:20px;color:#333;font-size:15px;font-weight:400;line-height:1.6}
details summary{list-style:none;cursor:pointer}
details summary::-webkit-details-marker{display:none}

#final_cta{position:relative;width:100%;height:490px;background:#AFE7FF}
#final_cta img#final_cta_logo{position:absolute;width:132px;top:21px;left:50%;transform:translateX(-50%)}
#final_cta img#final_cta_smartphone{position:absolute;width:295px;bottom:0;left:50%;transform:translateX(-50%)}
#final_cta img#final_cta_horse{position:absolute;top:21px;right: -90px}
#final_cta img#final_cta_horse2{position:absolute;width:137px;top:13px;left:6px}
#final_cta .cta_button_outer{position:absolute;top:366px;left:50%;transform:translateX(-50%);width:100%}
#footer{margin-top:30px;background:var(--brand-blue);width:100%;padding:20px 0;text-align:center;color:#fff}
#footer p{margin:0;font-size:10.5px;font-weight:200}
#footer a{display:inline-block;border:solid 1px #fff;color:#fff;text-decoration:none;padding:5px;font-size:10.5px;font-weight:200;margin:15px 0}

#stable_community{writing-mode:vertical-rl;overflow:hidden;height:100vh;position:fixed;right:0;top:0}
#stable_community span{display:block;animation:scroll 10s linear infinite;transform:translateY(0);color:#fff;font-weight:600;font-size:80px;padding:0 60px;user-select:none}
@keyframes scroll{0%{transform:translateY(100%)}100%{transform:translateY(-100%)}}
@media screen and (max-width:1120px){#pc_nav,#stable_community{display:none}main{margin:103px auto;float:none}}
@media screen and (max-width:550px){main{width:100%;margin:0;border-radius:0}}