@charset "UTF-8";

/*  
Theme Name: 　tokutokuwedding
*/


body {
  opacity: 0;
  transition: opacity 1.5s ease;
}
body.page-loaded {
  opacity: 1;
}


* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
    /* visibility: hidden; */
}

body {
    font-family: "Fraunces", 'Noto Sans JP', sans-serif;
    font-size: clamp(1.4rem, 1.6vw, 1.6rem);
    font-weight: 400;
    color: #2f4272;
    line-height: 1.8;
}

html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;  /* 横スクロール禁止 */
  width: 100vw;
}


li {
    list-style: none;
}

ul {
    padding-left: 0;
}

.pt_18 {
    font-size: 1.8rem;
}

.pt_20 {
    font-size: 2.0rem;
}

.pt_24 {
    font-size: 2.4rem;
}

.bold {
  font-weight:700;
}

.bold.txt_bu {
  font-size:1.6rem;
}

span.spl {
    font-size: 1.2rem;
}

a {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

a:active {
    color: inherit;
}

.ltsp {
    letter-spacing: -0.5rem;
}


.sp_br {
    display: none;
}

@media (min-width:500px) {
    body {
        background: url("assets/img/all_bg.webp") center center / cover no-repeat fixed;
    }
}

@media (max-width:500px) {
    .pt_24 {
        font-size: 2.0rem;
    }

    body {
        font-size: clamp(1.4rem, 1.6vw, 1.6rem);
    }

    .sp_br {
        display: block;
    }
	
	.bold.txt_bu {
  font-size:1.4rem;
}


}


@media (max-width:375px) {
    .pt_24 {
        font-size: 1.8rem;
    }

}






/*****************************

        header

*****************************/

.header {
    width: 100%;
    max-width: 500px;
    height: 80px;
    position: fixed;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 1000;
    display: block;

}

.header_inner {
    display: flex;
    align-items: center;
    height: 100%;
}

.header_logo {
    flex: 1;
}

.header_logo h1 {
    display: flex;
    font-size: 1.2rem;
    color: #333;
}

.header .cv_btn {
    flex: 2;
    text-align: center;
}

.header_ham {
    flex: 1;
    text-align: right;
    position: relative;
}

/* hamburger menu */

.ham_ol {
    position: absolute;
    z-index: 1001;
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    top: -25px;
    right: 20px;
}

.ham_ol_line {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: block;
    width: 26px;
    height: 2px;
    background-color: #2f4272;
    transition: all .3s ease;
}

.ham_ol_line:nth-of-type(1) {
    top: 12px;
}

.ham_ol_line:nth-of-type(2) {
    top: 19px;
}

.ham_ol_line:nth-of-type(3) {
    top: 26px;
}

.ham_ol.active .ham_ol_line {
    background-color: #2f4272;
}

.ham_ol.active .ham_ol_line:nth-of-type(1) {
    transform: translateX(-50%) translateY(7px) rotate(-45deg);
}

.ham_ol.active .ham_ol_line:nth-of-type(2) {
    opacity: 0;
}

.ham_ol.active .ham_ol_line:nth-of-type(3) {
    transform: translateX(-50%) translateY(-7px) rotate(45deg);
}

.nav_ol {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #87c4c8;
    visibility: hidden;
    opacity: 0;
    transition: all .3s ease;
    z-index: 999;
    pointer-events: none;
}



.nav_ol.active {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.nav_ol_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 50%;
    text-align: center;
}

.nav_ol_list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.nav_ol_item {
    position: relative;
    margin-bottom: 20px;
    text-align: center;
    opacity: 0;
    transform: translateY(20px);
    transition: all .3s ease;
}

/* アクティブ時のアニメーション */
.nav_ol.active .nav_ol_item {
    opacity: 1;
    transform: translateY(0);
}

/* 各アイテムに遅延を追加 */
.nav_ol.active .nav_ol_item:nth-child(1) {
    transition-delay: .1s;
}

.nav_ol.active .nav_ol_item:nth-child(2) {
    transition-delay: .2s;
}

.nav_ol.active .nav_ol_item:nth-child(3) {
    transition-delay: .3s;
}

.nav_ol.active .nav_ol_item:nth-child(4) {
    transition-delay: .4s;
}

.nav_ol.active .nav_ol_item:nth-child(5) {
    transition-delay: .5s;
}

.nav_ol.active .nav_ol_item:nth-child(6) {
    transition-delay: .6s;
}


.nav_ol_link {
    display: inline-block;
    color: #2f4272;
    font-size: 1.8rem;
    text-decoration: none;
    transition: color .3s ease;
    font-weight: 600;
    padding: 10px;
      background-image: linear-gradient(#2f4272, #2f4272);
  background-repeat: no-repeat;
  background-position: bottom right; /* 下線の初期位置 */
  background-size: 0 1px; /* 下線のサイズ（横幅、高さ） */
  transition: background-size 0.3s;
}

.nav_ol_link:hover {
  background-position: bottom left; /* 下線のホバー時位置 */
  background-size: 100% 1px; /* 下線の横幅を100%にする */
}

.nav_ol_link span {
    display: block;
    font-size: 1.2rem;
    font-weight: 400;
    opacity: 0.8;
}

.nav_ol {
    background-color: rgba(255, 255, 255, 0.3);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
}

/* レスポンシブ */

@media (min-width: 500px) {

.nav_ol {
    width: 102%;
}
}

@media (max-width: 500px) {
    .nav_ol_content {
        width: 80%;
    }
}

@media (max-width: 375px) {
    .nav_ol_link {
        font-size: 1.6rem;
    }
}



/*****************************

common

*****************************/



.container {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
}

.section {
    width: 100%;
}

.section .sec_fv img {
    max-width: 100%;
    max-height: 100%;
    margin: auto;
    display: block;
}


/* .sec_fv {
    margin-top: 70px;
} */

.section img {
    max-width: 100%;
    margin: auto;
    display: block;
}

.sec_pd {
    padding: 80px 30px 85px;
}

.sec_title {
    position: relative;
    font-size: 3.5rem;
    color: #512516;
    display: inline-block;
    padding: 0 30px;
    margin-bottom: 30px;
    line-height: 1.3;
}

.sec_subtitle {
    display: block;
    font-size: 1.2rem;
    letter-spacing: 0.1rem;
    /* color: #CB6381; */
}

.pc_menu_left .sec_title::before {
    bottom: 7px;
    background: repeating-linear-gradient(-45deg, transparent 0 2px, #CB6381 2px 4px);
    content: '';
    left: 0;
    height: 7px;
    position: absolute;
    width: 100%;
    opacity: 0.5;
}

.sec_title_wrap {
    text-align: center;
}

.dot_ashirai {
    position: relative;
}

.dot_ashirai::after {
    content: "";
    position: absolute;
    top: 60px;
    left: 0px;
    width: 100%;
    aspect-ratio: 100 / 21;
    mix-blend-mode: soft-light;
    background: url(assets/img/asirai_dot.png) center top / contain no-repeat;
}


@media (min-width:500px) {

    .container {
        box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
    }

    .sec_title {
        margin-bottom: 20px;
    }
}


@media (max-width:500px) {
    .sec_title {
        font-size: 2.8rem;
    }

    .sec_pd {
        padding: 60px 20px;
    }

    .dot_ashirai::after {
        top: 50px;
    }

    .section.sec_worry.sec_pd.dot_ashirai::after,
    .section.sec_cv.sec_pd.dot_ashirai::after {
        top: 65px;
        opacity: 0.8;
    }
}






/*****************************

fv

*****************************/



.swiper-slide img {
    height: auto;
    width: 100%;
}

.section.sec_fv {
    background-color: rgb(215 227 248);
    position: relative
}

.section.sec_fv::before {
    content: "";
    background: url(assets/img/fv_title.svg) no-repeat top center / cover;
    position: absolute;
    top: 70px;
    left: 40px;
    width: 100%;
    aspect-ratio: 60/23;
    z-index: 3;
    max-width: 200px;
}

.fv_link_wrap {
    width: 100%;
}

.fv_links {
    display: flex;
    justify-content: center;
    gap: 25px;
    position: absolute;
    bottom: 0;
    z-index: 2;
    width: 100%;
}


.fv_link {
    width: 25%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.fv_link_img {
    width: 100%;
    min-height: 115px;
}

.fv_link_img.msg {
    background: url(assets/img/link_m_01.webp) no-repeat top center / contain;
}

.fv_link_img.at {
    background: url(assets/img/link_a_02.webp) no-repeat top center / contain;
}

.fv_link_img.ev {
    background: url(assets/img/link_s_01.webp) no-repeat top center / contain;
}

.fv_link_img.msg:hover,
.fv_link_img.msg.clicked {
    background: url(assets/img/link_m_02.webp) no-repeat center / contain;
}

.fv_link_img.at:hover,
.fv_link_img.at.clicked {
    background: url(assets/img/link_a_01.webp) no-repeat top center / contain;
}

.fv_link_img.ev:hover,
.fv_link_img.ev.clicked {
    background: url(assets/img/link_s_02.webp) no-repeat top center / contain;
}

.fv_link h2 {
    font-size: 1.8rem;
    text-align: center;
}

@media (max-width:500px) {

    .section.sec_fv::before {
        top: 55px;
        left: 35px;
    }

    .fv_link_img {
        min-height: 85px;
    }

    .fv_link h2 {
        font-size: 1.6rem;
    }
}

@media (max-width:375px) {
    .section.sec_fv::before {
        max-width: 180px;
    }

    .section.sec_fv::before {
        top: 50px;
    }

    .fv_link h2 {
        font-size: 1.4rem;
    }

}


/*****************************

message

*****************************/

.section.sec_msg {
    /* background-color: rgba(145, 186, 243, 0.4); */
    background-color: #d7e3f8;
    position: relative
}

.sec_msg_title {
    max-width: 240px;
    margin: auto;
    margin-bottom: 30px;
}

.sec_msg_item h2 {
    color: #f28e86;
    font-size: 2.4rem;
    line-height: 1.4;
    text-align: center;
    margin-bottom: 30px;
    position: relative
}

.sec_msg_item h2 span {
    font-size: 1.3rem;
    display: block;
}

.sec_msg_item h2::after {
    content: "";
    background-image: url(assets/img/globe.webp);
    width: 120px;
    background-size: contain;
    position: absolute;
    aspect-ratio: 71 / 82;
    background-repeat: no-repeat;
    top: -90px;
    right: -25px;
}

.sec_msg_item h2::after {
    transform-origin: center bottom;
    animation: yurayura 3s linear infinite;
}

@keyframes yurayura {

    0%,
    100% {
        transform: rotate(5deg);
    }

    50% {
        transform: rotate(-5deg);
    }
}


.sec_msg_item {
    background-color: #fff;
    padding: 60px 15px;
}

.sec_msg_item p {
    font-size: 1.4rem;
    text-align: center;
    margin-bottom: 30px;
    line-height: 2.4;
}

@media (max-width:500px) {

    .sec_msg_title {
        max-width: 220px;
    }

    .sec_msg_item h2::after {
        width: 100px;
        top: -100px;
        right: -15px;
    }

    .sec_msg_item {
        padding: 50px 10px;
    }
}

@media (max-width:375px) {

    .sec_msg_title {
        max-width: 200px;
    }

    .sec_msg_item p {
        font-size: 1.3rem;
    }

    .sec_msg_item {
        padding: 40px 10px;
    }

    .sec_msg_item h2::after {
        top: -65px;
    }
}

/*****************************

manner

*****************************/

.sec_ttl_wrap {
    margin-bottom: 30px;
}

.sec_ttl {
    max-width: 180px;
    margin: auto;
}

.sec_sub_ttl {
    display: block;
    text-align: center;
    font-size: 1.3rem;
    margin-top: 20px;
}

.sec_manner .sec_ttl {
    background: url(assets/img/manner_ttl.png) no-repeat top center / contain;
    aspect-ratio: 298 / 88;
}

.sec_manner .sec_sub_ttl {
margin-top:10px;
  margin-bottom:40px;
}


.section.sec_manner {
    background-color: #f7edd7;
}

.manner_card {
    margin-bottom: 45px;
	position:relative;
}

.manner_card::before {
  content: "";
  width: 45px;
  height: 45px;
  position: absolute;
  left: 50%;
  top: -20px;
  transform: translateX(-50%);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
}

/* 各クラスごとに背景画像を変える */
.manner_card.num01::before {
  background-image: url(/wp-content/uploads/2025/08/num_01.webp);
}

.manner_card.num02::before {
  background-image: url(/wp-content/uploads/2025/08/num_02.webp);
}

.manner_card.num03::before {
  background-image: url(/wp-content/uploads/2025/08/num_03.webp);
}

.manner_card:last-child {
    margin-bottom: 0px;
}

.manner_card_top {
    background-color: #fff;
    border-radius: 20px 20px 0 0;
    padding: 30px;
}

.manner_card_top h3 {
    font-size: 2.2rem;
    margin-bottom: 20px;
    text-align: center;
    padding-bottom: 10px;
    line-height: 1.4;
	font-family: 'Noto Serif JP', serif;
}

.dashed-underline {
  position: relative;
  display: block; /* ← インラインだとwidth:100%が効かないのでblockに */
  padding-bottom: 4px; /* 下線との余白調整 */
}

.dashed-underline::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-image: repeating-linear-gradient(
    to right,
    #2f4272,
    #2f4272 4px,
    transparent 4px,
    transparent 8px
  );
}

.manner_card_top p {
    font-size: 1.4rem;
    line-height: 2.2;
}

.manner_card_btm {
    background-color: #f1d194;
    border-radius: 0 0 20px 20px;
    padding: 15px 30px;
    font-size: 1.2rem;
    color: #604c3f;
	line-height: 1.6;
}

@media (max-width:500px) {
    .sec_ttl {
        max-width: 160px;
    }
}

/*****************************

info

*****************************/


.section.sec_info {
    /* background-color: rgba(242, 142, 134, 0.4); */
    background-color: #f5d4d0;
}


.info_wrap {
    /*background: url(assets/img/info_bg.webp) no-repeat top center / contain;*/
	background: url(/wp-content/uploads/2025/08/info-1.webp) no-repeat top center / contain;
    aspect-ratio: 830 / 2089;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding-bottom: 30%;
}

.info_wrap::before {
    content: "";
    background: url(assets/img/clock.webp) no-repeat top center / contain;
    position: absolute;
    top: 170px;
    right: -28px;
    width: 100%;
    aspect-ratio: 71 / 82;
    z-index: 3;
    max-width: 100px;
}

.info_wrap::before {
    transform-origin: center bottom;
    animation: yurayura 3s linear infinite;
}

@keyframes yurayura {

    0%,
    100% {
        transform: rotate(5deg);
    }

    50% {
        transform: rotate(-5deg);
    }
}


.info_wrap::after {
    content: "";
    background: url(assets/img/telescope.webp) no-repeat top center / contain;
    position: absolute;
    bottom: 170px;
    left: -35px;
    width: 100%;
    aspect-ratio: 71 / 82;
    z-index: 3;
    max-width: 100px;
}


.info_wrap::after {
    transform-origin: center bottom;
    animation: yurayura 3s linear infinite;
    animation-delay: 1.5s;
}

@keyframes yurayura {

    0%,
    100% {
        transform: rotate(-5deg);
    }

    50% {
        transform: rotate(5deg);
    }
}


.info_map {
    width: 80%;
    aspect-ratio: 2 / 1.2;
    max-width: 320px;
    position: relative;
}


.info_logo {
    max-width: 200px;
    margin: 0 auto;
}

.info_map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media (max-width:500px) {

    .info_wrap {
        padding-bottom: 27%;
    }

    .info_wrap::before {
        right: -17px;
        max-width: 90px;
    }

    .info_wrap::after {
        bottom: 122px;
        left: -23px;
        max-width: 90px;
    }
}


/*****************************

profile

*****************************/


.section.sec_prf {
    /* background-color: rgba(236, 166, 202, 0.4); */
    background-color: #f3dce9;
}

.sec_prf .sec_ttl {
    background: url(assets/img/prf_ttl.png) no-repeat top center / contain;
    aspect-ratio: 298 / 88;
}

.prf_wrap {
    display: flex;
    justify-content: center;
    align-items: end;
    max-width: 380px;
    margin: 30px auto 0;
    position: relative;
}

.prf_wrap::before {
    content: "";
    background: url(assets/img/clickme.webp) no-repeat top center / contain;
    position: absolute;
    top: -40px;
    right: -30px;
    width: 100%;
    aspect-ratio: 213 / 163;
    z-index: 3;
    max-width: 90px;

}

.prf_wrap::after {
    content: "";
    background: url(assets/img/clickme02.webp) no-repeat top center / contain;
    position: absolute;
    top: -10px;
    left: 10px;
    width: 100%;
    aspect-ratio: 213 / 163;
    z-index: 3;
    max-width: 90px;

}



.prf_wrap::before {
    transform-origin: center bottom;
    animation: yurayura 1.5s linear infinite;
}

@keyframes yurayura {

    0%,
    100% {
        transform: rotate(5deg);
    }

    50% {
        transform: rotate(-5deg);
    }
}

.prf_wrap::after {
    transform-origin: center bottom;
    animation: yurayura 1.5s linear infinite;
    animation-delay: 0.75s;
}


@keyframes yurayura {

    0%,
    100% {
        transform: rotate(-5deg);
    }

    50% {
        transform: rotate(5deg);
    }
}


.prf_wrap .name {
    color: #f27e86;
    font-size: 2rem;
    line-height: 1.2;
    text-align: center;
    margin-top: 20px;
}


/*modal*/

.modal-overlay {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    align-items: center;
    justify-content: center;

}


@keyframes drawer-in-left {
    0% {
        transform: translateX(-150px);
        opacity: 0;
    }

    60% {
        transform: translateX(20px);
        opacity: 1;
    }

    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes drawer-in-right {
    0% {
        transform: translateX(150px);
        opacity: 0;
    }

    60% {
        transform: translateX(-20px);
        opacity: 1;
    }

    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

.modal-content {
    background-color: #f8dcea;
    max-width: 500px;
    width: 100%;
    height: 100%;
    position: relative;
    opacity: 0;
    transform: translateX(0);
    display: none;
    padding: 30px;
}

.modal-content.bride-in.active {
    display: block;
    animation: drawer-in-left 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

.modal-content.groom-in.active {
    display: block;
    animation: drawer-in-right 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

.modal-overlay.active {
    display: flex;
}

/* 閉じるボタン */
.modal-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 3rem;
    width: 40px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    background-color: transparent;
    border: none;
    cursor: pointer;
    z-index: 10000;
    color: #2f4272;
}

@media (min-width: 500px) {

.modal-content {
    width: 102%;
}
}

@media (max-width:500px) {
    .modal-content {
        width: 100%;
    }

    .prf_wrap {
        max-width: 300px;
    }

    .prf_wrap::after {
        left: -15px;
    }

    .prf_wrap::before {
        right: -40px;
    }
}


@media (max-width:414px) {

    .prf_wrap::before {
        max-width: 80px;
        right: -25px;
    }

    .prf_wrap::after {
        max-width: 80px;
        left: 4px;

    }
}

@media (max-width:375px) {
.prf_tbl {
  font-size:1.3rem;
}
}


/*****************************

prf_modal

*****************************/

.prf_desc {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    padding: 30px;
}


.prf_top {
    display: flex;
    align-items: center;
    justify-content: center;
}

.prf_top.groom {
    flex-direction: row-reverse;
}

.prf_img img {
    max-width: 200px;
    align-items: center;
}

.prf_name {
    font-size: 3rem;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.prf_name span {
    font-size: 1.2rem;
    display: block;
    text-align: center;
}

.prf_name a img {
    width: 30px;
    height: 30px;
    margin-top: 12px;
}

.prf_btm {
    background-color: #fff;
    border: solid 1px #2f4272;
    padding: 20px;
    border-radius: 10px;
    font-size: 1.4rem;
}

.prf_btm.bride,
.prf_btm.groom {
    position: relative;
}


.prf_btm.bride::before {
    content: "";
    background: url(assets/img/golf.webp) no-repeat top center / contain;
    position: absolute;
    top: -70px;
    right: 7px;
    width: 100%;
    aspect-ratio: 213 / 262;
    z-index: 3;
    max-width: 100px;
}

.prf_btm.groom::before {
    content: "";
    background: url(assets/img/fishing.webp) no-repeat top center / contain;
    position: absolute;
    top: -100px;
    left: 30px;
    width: 100%;
    aspect-ratio: 213 / 262;
    z-index: 3;
    max-width: 100px;

}


.prf_msg {
    background-color: #2f4272;
    color: #fff;
    padding: 10px;
    border-radius: 10px;
    font-size: 1.3rem;
    margin-top: 10px;
}

.prf_tbl div {
    display: flex;
    justify-content: flex-start;
    padding: 10px;
    border-bottom: 1px dotted #c7c7c7;
}

.prf_tbl dt {
    width: 120px;
}

.prf_tbl dd {
    margin-left: 0;
    width: calc(100% - 120px);
}


@media (max-width:500px) {
    .prf_img img {
        max-width: 160px;
    }

    .prf_name {
        font-size: 2.8rem;
        gap: 5px;
    }

    .prf_msg {
        font-size: 1.2rem;
    }

    .prf_name a img {
        width: 25px;
        height: 25px;
    }
}



@media (max-width:375px) {

.prf_img img {
    max-width: 115px;
}

.prf_tbl div {
    padding: 5px;
}

.prf_btm.bride::before{
    max-width: 80px;
}
.prf_btm.groom::before {
max-width: 70px;
    top: -65px;
}

.prf_btm {
    padding: 15px 20px;
}
.prf_msg {
  line-height:1.6;
}

}




/*****************************

フォーム

*****************************/

.container.cf7 {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
    box-shadow: none;
}


/* 出席のスタイル */
.attendance-section {
    text-align: center;
    margin-bottom: 40px;

}

.attendance-title {
    font-size: 32px;
    font-weight: bold;
    color: #e07a7a;
    margin-bottom: 30px;
    text-shadow: 2px 2px 4px rgba(224, 122, 122, 0.2);
}

.attendance-options {
    display: flex;
    justify-content: center;
    gap: 60px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 15px;
}

.attendance-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.attendance-option:hover {
    transform: translateY(-2px);
}

/* ラジオボタンのカスタムスタイル */
.attendance-radio {
    position: relative;
    margin-bottom: 15px;
}

/*ラジオボタンのカスタムスタイル*/


.attendance-radio input[type="radio"] {
    display: none;
}

.attendance-radio .radio-circle {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    border: 4px solid #e07a7a;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: all 0.3s ease;
    cursor: pointer;
}

.attendance-radio input[type="radio"]:checked+.radio-circle {
    background: white;
    border-color: #d06666;

}

.attendance-radio input[type="radio"]:checked+.radio-circle::after {
    content: '';
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: white;
    position: absolute;
}

.attendance-kanji {
    font-size: 28px;
    font-weight: bold;
    color: #2c3e50;
    transition: color 0.3s ease;
}

.attendance-radio input[type="radio"]:checked+.radio-circle .attendance-kanji {
    color: white;
}

.attendance-english {
    font-size: 16px;
    color: #666;
    font-weight: 500;
    margin-top: 8px;
}

/* 名前セクション */
.name-section {
    margin-bottom: 30px;
    padding: 20px;
    background: #f8f9ff;
    border-radius: 10px;
}

.name-title {
    font-size: 18px;
    font-weight: bold;
    color: #2c3e50;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.name-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.name-input {
    padding: 12px;
    border: 2px solid #e1e5e9;
    border-radius: 8px;
    font-size: 14px;
    background: white;
}

.wpcf7 input::placeholder {
    color: #98aee6;
}

.wpcf7 textarea::placeholder {
    color: #98aee6;
}

.kana-section {
    margin-bottom: 30px;
    padding: 20px;
    background: #f0f8ff;
    border-radius: 10px;
}

.kana-title {
    font-size: 18px;
    font-weight: bold;
    color: #2c3e50;
    margin-bottom: 15px;
}

.kana-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

/* 一般的なフォームスタイル */
.form-group {
    margin-bottom: 25px;
}

.form-label {
    display: block;
    font-weight: bold;
    color: #2c3e50;
    margin-bottom: 5px;
    font-size: 16px;
}

.required {
    background: #e74c3c;
    color: white;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 12px;
    margin-left: 5px;
}

input[type="text"],
input[type="tel"],
textarea,
.checkbox-group {
    width: 100%;
    padding: 20px;
    border: none;
    border-radius: 10px;
    font-size: 1.4rem;
    box-sizing: border-box;
    transition: border-color 0.3s ease;
    background-color: rgba(146, 187, 243, 0.3);
    margin-bottom: 10px;
}

input[type="text"]:focus,
input[type="tel"]:focus,
textarea:focus {
    outline: none;
    border-color: #e07a7a;
}

textarea {
    height: 80px;
    resize: vertical;
}

.checkbox-group {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.checkbox-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-weight: normal;
}

.notes {
    margin: 30px 0;
    padding: 20px;
    background: #fff8e1;
    border-radius: 8px;
    border-left: 4px solid #ffa726;
    font-size: 14px;
    line-height: 1.6;
    color: #5d4037;
}

.submit-group {
    text-align: center;
    margin-top: 30px;
}

input[type="submit"] {
    background: #e07a7a;
    color: white;
    padding: 20px;
    border: none;
    border-radius: 50vh;
    font-size: 1.6rem;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease;
    margin: 0 auto;
    display: block;
    max-width: 250px;
    width: 100%;
    margin-top: 20px;
}

input[type="submit"]:hover {
    background: #d06666;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(224, 122, 122, 0.3);
}

.form-row {
  display: flex;
  gap: 1rem; /* 欲しければ間隔を調整 */
}

.form-col {
  flex: 1; /* 50%ずつ */
}

.form-col input[type="text"] {
  width: 100%; /* 入力欄を100%に */
  box-sizing: border-box; /* パディングが幅に含まれるように */
}

@media (max-width: 500px) {
    .attendance-options {
        gap: 40px;
    }

    .name-inputs,
    .kana-inputs {
        grid-template-columns: 1fr;
    }

    .container.cf7 {
        padding: 10px;
    }
}

.sec_form {
    background-color: #fff;
}

.sec_form .sec_ttl {
    background: url(assets/img/att_ttl.webp) no-repeat top center / contain;
    aspect-ratio: 85 / 22;
}

.attendance-options {
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: center;
}


.attendance-options .wpcf7-form-control-wrap {
    position: relative;
}

.attendance-options .wpcf7-radio {
    display: flex;
    gap: 30px;
    justify-content: center;
}

.attendance-options .wpcf7-list-item {
    margin: 0 !important;
    display: inline-block;
    position: relative;
}


.attendance-options input[type="radio"] {
    opacity: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    z-index: 10;
    cursor: pointer;
    left: 0;
}

.attendance-options p {
    font-family: 'Noto Serif JP', serif;
}

.attendance-options .wpcf7-list-item-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 20px;
    border-radius: 50%;
    min-width: 120px;
    min-height: 120px;
    justify-content: center;
    transition: all 0.3s ease;
    border: 3px solid #ddd;
    background: white;
    cursor: pointer;
    font-size: 28px;
    font-weight: 700;
	color:#2c3e50;
    position: relative;
    z-index: 1;
}

/* ホバー効果（デバッグ用に強調） */
.attendance-options .wpcf7-list-item:hover .wpcf7-list-item-label {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    background: #f0f0f0;
}

/* 選択時のスタイル - より確実な指定 */
.attendance-options .wpcf7-list-item input[type="radio"]:checked~.wpcf7-list-item-label,
.attendance-options .wpcf7-list-item input[type="radio"]:checked+.wpcf7-list-item-label {
    border-color: #ff8a80 !important;
    background: #ffffff !important;
    color: #d32f2f !important;
}

/* JavaScript用のクラス */
.attendance-selected {
    border-color: #ff8a80 !important;
    background: #ffffff !important;
    color: #d32f2f !important;
}

.form_spl {
    font-size: 1.3rem;
}

@media (max-width: 375px) {

    .attendance-options .wpcf7-list-item-label {
        min-width: 100px;
        min-height: 100px;
    }

}


/*****************************

footer

*****************************/

footer {
    background: #87c4c8;
    padding: 30px;
}

footer p,
footer h2 {
    text-align: center;
}

footer a,
.footer_copyright {
    color: #fff;
    text-align: center;
    display: block;
}

.footer_copyright {
    font-size: 1.2rem;
    margin-top: 20px;
}

.footer_logo img {
    max-width: 100px;
}


@media (max-width:500px) {
    .footer_logo img {
        max-width: 90px;
    }


}

.pagetop {
    position: fixed;
    bottom: 10px;
    opacity: 0;
    padding-left: 20px;
    z-index: 300;
}

.pagetop img {
    width: 90px;
    height: 90px;
}

.grecaptcha-badge { visibility: hidden; }


/*thanks page*/

.thanks_p {
  background-color:#fff;
  height: 100vh;
  display:flex;
  align-items:center;
}

.thanks_img img {
  max-width:100%;
}

.thanks_p h4 {
font-size:3rem;
text-align:center;
margin-bottom: 50px;
}

.thanks_top {
text-align:center;
}

.thanks_top img {
  width:80px;
  height:80px;
}

.thanks_top .thanks_btn_img {
  transition: opacity 0.6s ease;
}

.thanks_top a:hover .thanks_btn_img {
  content: url("/wp-content/uploads/2025/08/thanks_icon02.webp");
}

.thanks_top p {
font-size:1.4rem;
}


