body{background-color:#f9fafb;flex-direction:column;min-height:100vh;margin:0;padding:0 0 80px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}a{color:inherit;text-decoration:none}.site-header{color:#fff;background-color:#111827;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;box-shadow:0 2px 4px #0000001a}.site-header h1{letter-spacing:.05em;margin:0;font-size:1.5rem}.header-nav{gap:1rem;display:flex}.nav-link{color:#fff;border-radius:4px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:background-color .2s}.nav-link:hover{background-color:#374151}.nav-link.active{color:#e5e7eb;pointer-events:none;cursor:default;background-color:#6b7280}.site-footer{color:#fff;text-align:center;background-color:#111827;padding:1rem 0}.main-body{box-sizing:border-box;flex:1;justify-content:center;align-items:flex-start;height:calc(100vh - 160px);padding:1rem;display:flex}.reservation-container{box-sizing:border-box;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;width:100%;max-width:700px;height:100%;padding:1.5rem;display:flex;box-shadow:0 4px 6px #0000001a}.reservation-container h2{text-align:center;margin-top:0}.form-group{margin-bottom:1.25rem}label{margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}select,input[type=text],input[type=tel]{box-sizing:border-box;border:1px solid #d1d5db;border-radius:4px;width:100%;min-height:48px;padding:.75rem;font-family:inherit;font-size:16px}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.step-content{flex-direction:column;height:100%;display:none}.step-content.active{display:flex}.step2-header-sticky{background-color:#fff;border-bottom:1px solid #f3f4f6;flex-shrink:0;margin-top:1.5rem;margin-bottom:10px;padding-top:5px;padding-bottom:5px}.selected-menu-info{top:var(--sticky-menu-top,48px);z-index:100;position:sticky;box-shadow:0 4px 6px #0000000d}.schedule-wrapper{border:1px solid #e5e7eb;flex:1;width:100%;min-height:0;margin-bottom:1.5rem;overflow-y:auto}table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:600px;font-size:13px}th,td{text-align:center;box-sizing:border-box;border:1px solid #e5e7eb;padding:4px 2px}th{z-index:10;vertical-align:middle;background-color:#fff;position:sticky}#schedule-header-month th{top:var(--sticky-table-header-month-top,0px);height:28px;box-shadow:inset 0 1px #e5e7eb}#schedule-header-month th[rowspan]{box-shadow:inset 0 1px #e5e7eb,inset 0 -1px #e5e7eb}#schedule-header th{top:var(--sticky-table-header-date-top,28px);box-shadow:inset 0 -1px #e5e7eb}#schedule-header-month th:first-child,#schedule-body td:first-child{width:60px}.th-year-month{color:#4b5563;font-size:.8rem;font-weight:700}.th-date-num{margin-bottom:2px;font-size:1.1rem;font-weight:700}.th-day-of-week{color:#6b7280;font-size:.75rem}.holiday{color:#9ca3af;background-color:#f9fafb}.time-slot-btn{cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:50%;width:32px;height:32px;padding:0;line-height:30px}.time-slot-btn.selected{color:#fff;background-color:#2563eb;border-color:#2563eb}tbody tr:nth-child(2n) td:not(.holiday):not(.booked-cell){background-color:#f9fafb}tbody tr:nth-child(odd) td:not(.holiday):not(.booked-cell){background-color:#fff}.holiday-text{color:#ef4444}.date-jump-input{color:#0000;cursor:pointer;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;width:44px;height:44px;padding:0;position:relative}.date-jump-input::-webkit-datetime-edit{display:none}.date-jump-input::-webkit-calendar-picker-indicator{cursor:pointer;background-position:50%;background-size:20px;width:100%;height:100%;margin:0;padding:0;position:absolute;top:0;left:0}.control-wrapper{margin-top:1.5rem}.schedule-nav{justify-content:space-between;align-items:center;padding:0 0 .5rem;display:flex}.nav-btn{cursor:pointer;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:.5rem 1.5rem;font-weight:700;transition:background-color .2s}.nav-btn:hover:not(:disabled){background-color:#e5e7eb}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.selection-summary{text-align:center;background-color:#f3f4f6;border-radius:4px;margin-bottom:1.25rem;padding:1rem;font-size:.95rem;font-weight:700}.selection-summary p{margin:0}.submit-btn{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:4px;width:100%;padding:1rem;font-size:1rem;font-weight:700;transition:opacity .2s}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.status-message{text-align:center;border-radius:4px;margin-bottom:1rem;padding:.5rem;font-size:.85rem;font-weight:700}.toast-message{color:#991b1b;z-index:1000;text-align:center;pointer-events:none;background-color:#fee2e2f2;border-radius:8px;width:max-content;max-width:80vw;padding:1rem 1.5rem;font-weight:700;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.modal-overlay{z-index:2000;background-color:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{box-sizing:border-box;background-color:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.clickable-cell{cursor:pointer;transition:background-color .2s}.clickable-cell:hover{background-color:#e5e7eb}@media (width<=600px){body{background-color:#fff}.site-header{flex-direction:column;gap:1rem;padding:1rem}.main-body{height:auto;padding:1rem}.reservation-container{box-shadow:none;background-color:#0000;border:none;height:auto;padding:0}.step-content{height:auto}table{min-width:auto}.schedule-wrapper{overflow:visible}th{z-index:10}td{height:56px}.time-slot-btn{width:44px;height:44px;line-height:42px}}.step-indicator{z-index:100;background-color:#fff;border-bottom:1px solid #e5e7eb;justify-content:center;align-items:center;gap:.5rem;padding:1rem;font-size:.85rem;font-weight:700;display:flex;position:sticky;top:0}.step{color:#9ca3af;transition:opacity .2s}.step.active{color:#2563eb}.step-arrow{color:#d1d5db}.category-title{color:#111827;text-align:center;justify-content:center;align-items:center;gap:.4rem;margin-top:1.5rem;margin-bottom:.75rem;padding-left:.5rem;font-size:1.7rem;display:flex}.category-icon{color:#4b5563}.menu-card{cursor:pointer;background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;margin-bottom:.75rem;padding:1rem;transition:all .2s;display:block}.menu-card:hover{background-color:#eff6ff;border-color:#93c5fd}.menu-card input[type=radio]{display:none}.menu-card input[type=radio]:checked+.menu-details{color:#1e3a8a}.menu-card:has(input[type=radio]:checked){background-color:#eff6ff;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.menu-details{justify-content:space-between;align-items:center;font-weight:600;display:flex}.menu-name{font-size:1rem}.menu-price{color:#4b5563;font-size:1rem}.menu-card:has(input[type=radio]:checked) .menu-price{color:#2563eb}.sticky-footer{box-sizing:border-box;z-index:1000;background-color:#000c;border-top:1px solid #ffffff1a;justify-content:space-between;align-items:center;width:100%;min-height:70px;padding:.75rem 1rem;display:flex;position:fixed;bottom:0;left:0}.footer-back-btn{color:#fff;cursor:pointer;background-color:#0000;border:1px solid #ffffff4d;border-radius:4px;justify-content:center;align-items:center;gap:.25rem;padding:.5rem 1rem;font-size:1rem;font-weight:700;transition:background-color .2s,border-color .2s;display:flex}.footer-back-btn:hover{background-color:#ffffff1a;border-color:#ffffff80}.footer-action-wrapper{flex-shrink:0}.tax-text{color:#e5e7eb;margin-left:4px;font-size:.8rem;font-weight:400}.footer-btn{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;transition:background-color .2s;box-shadow:0 2px 4px #2563eb33}.footer-btn:hover{background-color:#1d4ed8}.footer-btn:disabled{cursor:not-allowed;box-shadow:none;background-color:#9ca3af}
