/*basic-set*/
input[type=text],
input[type=password],
textarea
{
    -webkit-box-sizing :border-box;‌​
    -moz-box-sizing :border-box;
    box-sizing :border-box;
	line-height:auto;
	vertical-align:top;
}
select { background: #fff; }
* { position:relative; word-break:keep-all; }
#wrap * { transition:all ease-in-out 0.3s; }
a.off { opacity:0.4; -webkit-opacity:0.4; pointer-events:none; cursor:default; }
.bt_ov { position:absolute; top:0; left:0; right:0; bottom:0; text-indent:-9999px; }
.pu_bg { position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,0.8); z-index:98; display:none; transition:none; }
.pu { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); background:#fff; border:1px solid #d3d3d3; border-radius:5px; box-shadow:0 5px 10px rgba(0,0,0,0.2); z-index:99; display:none; transition:none; }


/* layout */
body { background: #f7f6f0; }
.pc_banner { position: fixed; top: 150px; left: 50%; transform: translateX(-488px); z-index: 10; }
#wrap { max-width: 600px; margin: 0 auto; background: #f0f0f3; box-shadow: 0 0 10px rgba(0,0,0,0.2); transform: translateX(188px); }
header { position: sticky; top: 0; left: 0; right: 0; background: #fff; z-index: 20; height: 59px; border-bottom: 1px solid #f0f0f3; }
header h1 { text-align: center; line-height: 59px; }
header h1 a { display: inline-block; width: 144px; height: 17px; background: url(/_image/logo.png) 0/100% 100%; text-indent: -9999px; vertical-align: middle; }
@media screen and (max-width:996px) {
.pc_banner { display: none; }
#wrap {transform: none; }
}
.section { background: #fff; margin-bottom: 10px; padding: 45px 20px; }
.section:last-child { margin: 0; }
.section h2 { font-size: 20px; font-weight: 500; padding-left: 27px; background: no-repeat 0 center/18px; }
.fix_area { position: sticky; bottom: 0; left: 0; right: 0; background: #fff; border-top: 1px solid #f0f0f3; padding: 12px 20px; display: flex; gap: 10px; z-index: 20; }
.fix_area .bt_call { width: 63px; height: 63px; border: 1px solid #e9e9ec; border-radius: 10px; background: url(/_image/ic_phone.png) no-repeat center center/20px; text-indent: -9999px; }
.fix_area .bt_y_block { width: calc(100% - 73px); line-height: 65px; background: #f7ee23; border-radius: 10px; font-size: 20px; font-weight: 500; text-align: center; }
.fix_area .bt_c_block { width: calc(100% - 73px); line-height: 65px; background: #f7ee23; border-radius: 10px; font-size: 20px; font-weight: 500; text-align: center; }

/* main */
.mt_img img { width: 100%; }

.mt_guide { padding: 35px 20px; font-size: 16px; line-height: 25px; }
.mt_guide h2 { padding: 0; margin-bottom: 18px; }
.mt_guide p { line-height: 21px; margin: 2px 0; }

.date_time_select h2.fullbooking { margin-bottom: 50px; background-image: url(/_image/ic_error.png); font-size:15px; }
.date_time_select h2 { margin-bottom: 50px; background-image: url(/_image/ic_cal.png); }

.calendar .c_header { text-align: center; margin-bottom: 40px; }
.calendar .c_header > * { display: inline-block; vertical-align: middle; }
.calendar .c_header span { font-size: 20px; font-weight: 500; margin: 0 20px; }
.calendar .c_header a { width: 6px; height: 10px; text-align: left; text-indent: -9999px; background-size: 100% 100%; }
.calendar .c_header a.bt_prev { background-image: url(/_image/cal_bt_prev.png); }
.calendar .c_header a.bt_next { background-image: url(/_image/cal_bt_next.png); }

.tb_calendar { width: 100%; font-size: 16px; font-weight: 500; text-align: center; }
.tb_calendar th,
.tb_calendar td { width: 14.2857%; padding: 1px 0; height: 60px; vertical-align: top; }
.tb_calendar th { height: 40px; font-weight: 500; }
.tb_calendar td a { display: block; width: 40px; line-height: 40px; border-radius: 10px; margin: 0 auto; }
.tb_calendar td a:hover { text-decoration: none; }
.tb_calendar td.off a, .tb_calendar td.holiday a, .tb_calendar td.disabled a { color: #acacac; pointer-events: none; cursor: none; }
.tb_calendar td span { display: block; font-size: 12px; line-height: 14px; }
.tb_calendar td.off span, .tb_calendar td.holiday span { color: #acacac; }
.tb_calendar td.on a { background: #f7ee23; }

.tb_calendar td.sun a { color: #ff0000 !important; }
.tb_calendar td.sat a { color: #0000ff !important; }

.date_time_select .time { border-top: 1px solid #e9e9ec; padding-top: 25px; margin-top: 40px; }
.date_time_select .time dl { margin-bottom: 25px; }
.date_time_select .time dl:last-child { margin: 0; }
.date_time_select .time dl dt { font-size: 18px; margin-bottom: 18px; }
.date_time_select .time dl dd ul { display: flex; flex-wrap: wrap; gap: 8px; }
.date_time_select .time dl dd ul li { width: calc(25% - 6px); }
.date_time_select .time dl dd ul li input { display: none; }
.date_time_select .time dl dd ul li input + label { display: block; line-height: 38px; border: 1px solid #ebebee; border-radius: 10px; font-size: 14px; text-align: center; }
.date_time_select .time dl dd ul li input:checked + label { background: #f7ee23; border-color: #f7ee23; }
.date_time_select .time dl dd ul li input:disabled + label { color: #acacac; }

.cb input { display: none; }
.cb input + label::before { content: ''; display: inline-block; width: 20px; height: 20px; background: url(/_image/cb.png) 0/100%; }
.cb input:checked + label::before { background-image: url(/_image/cb_on.png); }

.menu_select h2 { margin-bottom: 45px; background-image: url(/_image/ic_select.png); }
.menu_select ul li { border-top: 1px solid #e9e9ec; padding: 20px 0; }
.menu_select ul li label { display: block; padding-left: 29px; }
.menu_select ul li label::before { position: absolute; top: 2px; left: 0; }
.menu_select ul li label span { display: block; }
.menu_select ul li label .tit { font-size: 20px; font-weight: 500; margin-bottom: 5px; }
.menu_select ul li label .c_tx { font-size: 16px; line-height: 21px; color: #acacac; margin-bottom: 10px; }
.menu_select ul li label .price { font-size: 16px; }

.user_info h2 { margin-bottom: 45px; background-image: url(/_image/ic_user_info.png); }
.user_info .name { margin-bottom: 10px; }
.user_info input[type=text] { width: 100%; height: 60px; border: 1px solid #e9e9ec; border-radius: 10px; padding: 0 15px; font-size: 18px; }
.user_info .phone { display: flex; gap: 5px; }
.user_info .phone input { text-align: center; }
.user_info .sel { width: 100%; }
.user_info .sel::after { content: ''; position: absolute; top: 50%; right: 15px; width: 7px; height: 6px; transform: translateY(-50%); background: url(/_image/arr_sel.png) 0/100% 100%; }
.user_info .sel select { width: 100%; height: 60px; border: 1px solid #e9e9ec; border-radius: 10px; appearance: none; padding: 0 15px; font-size: 18px; }

.noti h2 { padding: 0; margin-bottom: 20px; }
/*.noti textarea { width: 100%; height: 130px; padding: 16px; font-size: 18px; background: #f0f0f3; border: 0; border-radius: 10px; }*/
/*.noti #notice {max-width: 100%; height: 130px; padding: 16px; font-size: 18px; background: #f0f0f3; border: 0; border-radius: 10px; white-space: pre-wrap;}*/
.noti #notice {max-width: 100%;height: 130px;padding: 16px;font-size: 18px;background: #f0f0f3;border: 0;border-radius: 10px;overflow-y: auto;white-space: pre-wrap;word-break: break-word;-webkit-overflow-scrolling: touch;scroll-behavior: smooth;}

/* sub */
.info_confirm h2 { padding: 0; margin-bottom: 20px; }
.info_confirm .reserve { line-height: 58px; border: 1px solid #e9e9ec; border-radius: 10px; padding: 0 20px; font-size: 18px; /*display: flex;*/ gap: 29px; margin-bottom: 30px; }

.info_confirm .reserve .ticket p, .info_confirm .reserve .info p, .info_confirm .reserve .schedule p { display:inline-block; color: #acacac; }

.info_confirm .reserve dt { color: #acacac; }
.info_confirm .date_time { line-height: 58px; border: 1px solid #e9e9ec; border-radius: 10px; padding: 0 20px; font-size: 18px; display: flex; gap: 29px; margin-bottom: 30px; }
.info_confirm .date_time dt { color: #acacac; }

.info_confirm .menu { font-size: 16px; display: flex; gap: 30px; }
.info_confirm .menu .name { width: 70%; }
.info_confirm .menu .price { text-align: right; width: 30%; }
.agree { padding: 45px; text-align: center; font-size: 20px; font-weight: 500; }
.agree a { color: #acacac; }
.agree label::before { display: inline-block; vertical-align: middle; margin: -3px 8px 0 0; }

.reservation_confirm { height: calc(100vh - 150px); background: #fff; display: flex; flex-direction: column; justify-content: center; text-align: center; }
.reservation_confirm dt { font-size: 25px; font-weight: 500; margin-bottom: 25px; }
.reservation_confirm dt::before { content: ''; display: block; width: 50px; height: 50px; margin: 0 auto 40px; background: url(/_image/ic_reservation_confirm.png) 0/100%; }
.reservation_confirm dd { font-size: 18px; line-height: 28px; }

.event { height: calc(100vh - 150px); background: #fff; display: flex; flex-direction: column; justify-content: center; text-align: center; }
.event dt { font-size: 25px; font-weight: 500; margin-bottom: 25px; }
.event dt::before { content: ''; display: block; width: 50px; height: 50px; margin: 0 auto 40px; background: url(/_image/ic_event.png) 0/100%; }
.event dd { font-size: 18px; line-height: 28px; }

@keyframes fade {
	from { opacity: 1.0; }
	50% { opacity: 0.5; }
	to { opacity: 1.0; }
}                                                                                                                                                                                                                                  

@-webkit-keyframes fade {
	from { opacity: 1.0; }
	50% { opacity: 0.5; }
	to { opacity: 1.0; }
}

.today span {
  animation:fade 1000ms infinite;
  -webkit-animation:fade 1000ms infinite;
}

/* addition style */
.popup-wrapper { position: fixed; inset: 0; z-index: 9999; display: none; }
.popup-wrapper.show { display: block; }
.dimmed-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); }
.bottom-banner { position: fixed; bottom: 0; left: 0; right: 0; background: white; border-radius: 16px 16px 0 0; padding: 20px; text-align: center; transform: translateY(100%); transition: transform 0.3s ease-out; }
.bottom-banner .title { font-size: 16px; font-weight: bold; margin-bottom: 12px; }
.cta-btn { background-color: black; color: white; padding: 10px 20px; margin-bottom: 16px; border-radius: 6px; border: none; }
.popup-actions { display: flex; justify-content: space-around; font-size: 14px; }
.popup-actions button { background: none; border: none; color: #666; }
.toast-container { position: fixed; z-index: 9999; display: flex; flex-direction: column; gap: 10px; pointer-events: none; }
.toast { color: #fff; padding: 12px 20px; border-radius: 6px; font-size: 14px; opacity: 0; transform: translateY(20px); transition: opacity 0.3s ease, transform 0.3s ease; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2); pointer-events: auto; }
.toast-container.pc { bottom: 30px; left: 50%; transform: translateX(-50%); align-items: center; }
@media screen and (max-width: 768px) {
	.toast-container.mobile { bottom: 80px; left: 16px; right: 16px; transform: none; align-items: flex-start; }
	.toast.mobile { width: 90%; border-radius: 12px; font-size: 15px; margin: 0 auto;}
}
.toast.success { background-color: #2ecc71; }
.toast.info { background-color: #3498db; }
.toast.danger { background-color: #e74c3c; }
.toast.show { opacity: 1; transform: translateY(0); }

#popup-wrapper {position: fixed;top: 0;left: 0;width: 100%;height: 100%;z-index: 999;opacity: 0;visibility: hidden;transition: opacity 0.4s ease, visibility 0.4s;}
#popup-wrapper.show {opacity: 1;visibility: visible;}
#popup-wrapper .dimmed-overlay {position: absolute;top: 0;left: 0;width: 100%;height: 100%;background-color: rgba(0, 0, 0, 0.6);}
#popup-wrapper #popup-container {position: fixed;bottom: 0;left: 50%;transform: translateX(-50%) translateY(100%);width: 100%;max-width: 500px;background-color: white;box-shadow: 0 -4px 15px rgba(0,0,0,0.1);z-index: 1000;border-top-left-radius: 15px;border-top-right-radius: 15px;transition: transform 0.4s ease-in-out;}
#popup-wrapper.show #popup-container {transform: translateX(-50%) translateY(0%);}
#popup-container .popup-content {padding: 24px;}
#popup-container .title {font-size: 16px;line-height: 1.6;margin-bottom: 24px;color: #333;}
#popup-container a.cta-btn {display: block !important;width: 50% !important;padding: 12px !important;background-color: #333 !important;color: white !important;text-align: center !important;text-decoration: none !important;border-radius: 8px !important;margin-bottom: 15px !important;font-weight: bold !important;border: none !important;box-sizing: border-box !important;margin:0 auto;}
#popup-container a.cta-btn:hover {opacity: 0.85;}
#popup-container .popup-footer {display: flex;gap: 8px;}
#popup-container .popup-action-btn {flex: 1;border: none;padding: 10px 12px;cursor: pointer;border-radius: 8px;font-size: 14px;font-weight: 500;}
#popup-container #dismiss-today {background-color: #f1f3f5;color: #555;}
#popup-container #popup-close {background-color: #868e96;color: white;}

.event-error::before {content: ''; display: block; width: 50px; height: 50px; margin: 0 auto 40px; background: url(/_image/ic_error.png) 0/100%;}

dl.event > dd img {max-width: 100%;height: auto;display: block;}
.table tbody td img {width: 100px !important;height: auto !important;}