.calendar-date-area{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;margin:-8px -8px 8px;border-radius:var(--radius) var(--radius) 0 0;cursor:pointer;transition:background .2s}.calendar-date-area:hover{background:var(--bg-primary)}.calendar-date-area.has-events:hover{background:#eff6ff}.reservation-count{background:var(--primary);color:#fff;font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.timeline-list-section{margin-top:24px;border-top:2px solid var(--border);padding-top:20px}.timeline-list-table{width:100%;border-collapse:collapse;font-size:.875rem}.timeline-list-table th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);border-bottom:2px solid var(--border);text-transform:uppercase}.timeline-list-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.timeline-list-row{cursor:pointer;transition:background .2s}.timeline-list-row:hover{background:var(--bg-primary)}.list-row-pending{background:#fffbeb;border-left:3px solid #f59e0b}.list-row-pending:hover{background:#fef3c7}.list-row-confirmed{background:#eff6ff;border-left:3px solid #3b82f6}.list-row-confirmed:hover{background:#dbeafe}.list-row-completed{background:#f0fdf4;border-left:3px solid #22c55e}.list-row-completed:hover{background:#dcfce7}.list-customer{font-weight:600;color:var(--text-primary);min-width:80px}.list-rooms{color:var(--text-secondary);font-size:.8rem;max-width:300px}.list-count{text-align:center;font-weight:500}.list-amount,.list-deposit{text-align:right;font-weight:600;font-family:Pretendard,monospace}.list-note{color:var(--text-secondary);font-size:.8rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-edit{text-align:center}.edit-btn{padding:6px 12px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.75rem;font-weight:500;cursor:pointer;transition:background .2s}.edit-btn:hover{background:var(--primary-dark)}.staff-memo-row{background:#f8fafc}.staff-memo-row.morning{background:#fff7ed;border-left:3px solid #f97316}.staff-memo-row.afternoon{background:#fdf4ff;border-left:3px solid #a855f7}.memo-label{font-weight:600;color:var(--text-secondary);font-size:.8rem;white-space:nowrap}.memo-content{color:var(--text-secondary);font-size:.85rem;font-style:italic}.timeline-event .event-room{display:none}@media(max-width:768px){.timeline-list-section{margin-top:16px;padding-top:12px}.timeline-list-table{font-size:.8rem}.timeline-list-table td{padding:8px 10px}.list-rooms{max-width:none;font-size:.75rem}.list-note{max-width:none;white-space:normal;font-size:.75rem}.edit-btn{padding:4px 8px;font-size:.7rem}.staff-memo-row td{padding:8px 10px}}.public-booking{max-width:640px;margin:0 auto;padding:0 16px 32px;min-height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.public-booking-header{text-align:center;padding:32px 0 16px}.public-booking-header h1{font-size:24px;font-weight:700;color:#1e293b;letter-spacing:2px;margin:0}.public-booking-header p{font-size:14px;color:#64748b;margin:4px 0 0}.step-indicator{display:flex;align-items:center;justify-content:center;gap:8px;margin:20px 0 24px}.step{display:flex;align-items:center;gap:6px}.step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;background:#e2e8f0;color:#94a3b8;transition:all .2s}.step.active .step-num{background:#2563eb;color:#fff}.step.done .step-num{background:#22c55e;color:#fff}.step-label{font-size:13px;color:#94a3b8}.step.active .step-label{color:#2563eb;font-weight:600}.step.done .step-label{color:#22c55e}.step-line{width:24px;height:2px;background:#e2e8f0}.public-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:16px}.public-warning{display:flex;gap:8px;padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;font-size:14px;margin-bottom:16px}.public-warning ul{margin:4px 0 0;padding-left:16px}.public-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 1px 3px #0000000f}.public-section h2{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 16px;display:flex;align-items:center;justify-content:space-between}.public-form-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:480px){.public-form-grid{grid-template-columns:1fr 1fr}}.public-field{display:flex;flex-direction:column;gap:4px}.public-field label{font-size:13px;font-weight:500;color:#475569}.public-field input,.public-field select,.public-section textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#1e293b;background:#fff;transition:border-color .2s;width:100%;box-sizing:border-box}.public-field input:focus,.public-field select:focus,.public-section textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.public-section textarea{resize:vertical}.room-card{border:1px solid #e2e8f0;border-radius:10px;padding:14px;margin-bottom:12px;background:#f8fafc}.room-card-header{display:flex;align-items:center;gap:6px;margin-bottom:12px;font-size:14px;font-weight:500;color:#475569}.room-remove-btn{margin-left:auto;background:none;border:none;color:#ef4444;font-size:13px;cursor:pointer;padding:2px 8px}.room-card-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(min-width:480px){.room-card-fields{grid-template-columns:1fr 1fr 1fr 80px}}.room-card-price{display:flex;align-items:center;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid #e2e8f0;font-size:13px;color:#64748b}.room-price-amount{margin-left:auto;font-weight:600;color:#2563eb;font-size:15px}.room-card-notice{margin-top:8px;padding:8px 12px;background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;font-size:13px;color:#92400e}.public-add-btn{background:none;border:1px solid #d1d5db;border-radius:6px;padding:4px 12px;font-size:13px;color:#475569;cursor:pointer}.public-add-btn:hover{background:#f1f5f9}.price-summary-public{background:#fff;border-radius:12px;padding:16px 20px;margin-bottom:16px;box-shadow:0 1px 3px #0000000f}.price-row-public{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.price-row-public:first-child{font-weight:600;font-size:17px}.price-row-public.sub{font-size:14px;color:#64748b}.price-amount{font-weight:700;color:#2563eb}.public-submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.public-submit-btn:hover{background:#1d4ed8}.public-submit-btn:disabled{background:#94a3b8;cursor:not-allowed}.public-back-btn{display:flex;align-items:center;gap:4px;padding:14px 20px;background:#fff;color:#475569;border:1px solid #d1d5db;border-radius:12px;font-size:15px;cursor:pointer}.payment-step-actions{display:flex;gap:12px;margin-top:8px}.payment-step-actions .public-submit-btn{flex:1}.booking-summary{display:flex;flex-direction:column;gap:8px}.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:4px 0}.summary-row span:first-child{color:#64748b}.summary-row.total{border-top:1px solid #e2e8f0;padding-top:12px;margin-top:4px;font-size:16px;font-weight:600}.payment-options{display:flex;flex-direction:column;gap:12px}.payment-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s}.payment-option.selected{border-color:#2563eb;background:#eff6ff}.payment-option input[type=radio]{margin-top:4px;accent-color:#2563eb}.option-content{flex:1}.option-content strong{font-size:15px;color:#1e293b}.option-amount{display:block;font-size:20px;font-weight:700;color:#2563eb;margin:4px 0}.option-content p{font-size:13px;color:#64748b;margin:2px 0 0}.option-note{color:#f59e0b!important;font-weight:500}.public-complete-step{text-align:center;padding:24px 0}.complete-icon{width:80px;height:80px;border-radius:50%;background:#22c55e;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 16px}.public-complete-step h2{font-size:20px;color:#1e293b;margin:0 0 8px}.complete-message{color:#64748b;font-size:15px;margin:0 0 24px}.bank-info-card{background:#fff;border-radius:12px;padding:20px;margin:0 auto 20px;max-width:400px;text-align:left;box-shadow:0 1px 3px #0000000f}.bank-info-card h3{font-size:15px;color:#475569;margin:0 0 12px;text-align:center}.bank-info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;border-bottom:1px solid #f1f5f9}.bank-info-row:last-child{border-bottom:none}.bank-info-row span:first-child{color:#64748b}.bank-info-row.account span:last-child{display:flex;align-items:center;gap:6px;font-weight:600;font-size:15px}.bank-info-row.highlight{background:#eff6ff;margin:4px -12px;padding:10px 12px;border-radius:8px;border-bottom:none}.pay-amount{font-size:18px;font-weight:700;color:#2563eb}.copy-btn{background:none;border:none;cursor:pointer;color:#64748b;padding:4px;display:flex;align-items:center}.copy-btn:hover{color:#2563eb}.complete-notice{padding:16px;background:#fefce8;border-radius:10px;max-width:400px;margin:0 auto}.complete-notice p{font-size:13px;color:#92400e;margin:4px 0}.public-footer{text-align:center;padding:24px 0;color:#94a3b8;font-size:13px}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--secondary: #64748b;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--purple: #8b5cf6;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-sidebar: #1e293b;--text-primary: #1e293b;--text-secondary: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-dark: #cbd5e1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: 8px;--radius-lg: 12px}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.logo{padding:24px;border-bottom:1px solid rgba(255,255,255,.1)}.logo h1{font-size:1.5rem;font-weight:700;letter-spacing:2px}.logo span{font-size:.75rem;color:var(--text-light);letter-spacing:4px}.nav-menu{padding:16px 0;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;color:var(--text-light);text-decoration:none;transition:all .2s}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#ffffff1a;color:#fff;border-left:3px solid var(--primary)}.sidebar-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.1);font-size:.75rem;color:var(--text-light)}.main-content{flex:1;margin-left:240px;padding:24px;min-height:100vh}.page-header{margin-bottom:24px}.page-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary)}.page-date{color:var(--text-secondary);margin-top:4px}.page-description{color:var(--text-secondary);font-size:.875rem}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}.stat-icon{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.stat-blue .stat-icon{background:#dbeafe;color:var(--primary)}.stat-green .stat-icon{background:#dcfce7;color:var(--success)}.stat-yellow .stat-icon{background:#fef3c7;color:var(--warning)}.stat-red .stat-icon{background:#fee2e2;color:var(--danger)}.stat-purple .stat-icon{background:#ede9fe;color:var(--purple)}.stat-content h3{font-size:.875rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-subtext{font-size:.75rem;color:var(--text-light)}.dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:24px}.calendar-section,.upcoming-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.calendar-section h2,.upcoming-section h2{font-size:1.125rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.calendar{width:100%}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-title{font-size:1.125rem;font-weight:600}.calendar-nav-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.calendar-nav-btn:hover{background:var(--bg-primary);border-color:var(--border-dark)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:8px}.calendar-body{display:flex;flex-direction:column;gap:4px}.calendar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-cell{min-height:100px;border:1px solid var(--border);border-radius:var(--radius);padding:8px;cursor:pointer;transition:all .2s}.calendar-cell:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.calendar-cell.other-month{background:var(--bg-primary);opacity:.5}.calendar-cell.today{border-color:var(--primary);background:#eff6ff}.calendar-cell.selected{border-color:var(--primary);background:#dbeafe}.highlight-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary);margin-left:4px;vertical-align:middle}.calendar-highlight-label{font-size:.65rem;color:var(--primary);background:#eff6ff;padding:1px 5px;border-radius:3px;border-left:2px solid var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:2px}.calendar-highlight-label.highlight-done{color:#16a34a;background:#f0fdf4;border-left-color:#16a34a}.calendar-highlight-label .done-check{font-weight:700;font-size:.6rem;flex-shrink:0}.calendar-date{font-size:.875rem;font-weight:500;display:block;margin-bottom:4px}.calendar-events{display:flex;flex-direction:column;gap:2px}.calendar-event{font-size:.7rem;padding:2px 6px;border-radius:4px;border-left:2px solid;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:transform .1s}.calendar-event:hover{transform:scale(1.02)}.event-time{font-weight:600;margin-right:4px}.event-name{font-weight:500}.calendar-more{font-size:.7rem;color:var(--text-secondary);padding:2px 4px}.upcoming-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:400px;overflow-y:auto}.upcoming-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-primary);border-radius:var(--radius);cursor:pointer;transition:all .2s;border-left:3px solid transparent}.upcoming-item:hover{background:#f1f5f9}.upcoming-item.status-pending{border-left-color:var(--warning)}.upcoming-item.status-confirmed{border-left-color:var(--primary)}.upcoming-date{text-align:center;min-width:50px}.upcoming-date .date{display:block;font-size:.75rem;color:var(--text-secondary)}.upcoming-date .time{display:block;font-weight:600;font-size:.875rem}.upcoming-info{flex:1}.upcoming-info .name{display:block;font-weight:500}.upcoming-info .room{display:block;font-size:.75rem;color:var(--text-secondary)}.upcoming-info .pending-issue-text{display:block;font-size:.75rem;color:#dc2626;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.stat-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;transition:all .2s ease}.empty-message{text-align:center;color:var(--text-secondary);padding:24px}.reservation-list{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.list-controls{display:flex;gap:12px;margin-bottom:16px}.search-box{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px}.search-box input{flex:1;border:none;background:none;outline:none;font-size:.875rem}.search-box svg{color:var(--text-secondary)}.filter-toggle{display:flex;align-items:center;gap:8px;background:none;border:1px solid var(--border);border-radius:var(--radius);padding:8px 16px;cursor:pointer;font-size:.875rem;transition:all .2s}.filter-toggle:hover,.filter-toggle.active{background:var(--bg-primary);border-color:var(--primary)}.filter-toggle .rotated{transform:rotate(180deg)}.filter-panel{display:flex;gap:16px;padding:16px;background:var(--bg-primary);border-radius:var(--radius);margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.filter-group select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--bg-secondary);cursor:pointer}.list-summary{font-size:.875rem;color:var(--text-secondary);margin-bottom:12px}.table-container{overflow-x:auto}.reservation-table{width:100%;border-collapse:collapse}.reservation-table th,.reservation-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border)}.reservation-table th{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;background:var(--bg-primary)}.reservation-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.reservation-table th.sortable:hover{color:var(--text-primary)}.sort-indicator{display:inline-block;margin-left:4px;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent}.sort-indicator.asc{border-bottom:5px solid currentColor}.sort-indicator.desc{border-top:5px solid currentColor}.reservation-table tbody tr{transition:background .2s}.reservation-table tbody tr.clickable{cursor:pointer}.reservation-table tbody tr:hover{background:var(--bg-primary)}.reservation-table .customer-name{font-weight:500}.reservation-table .amount{font-weight:600;text-align:right}.empty-state{text-align:center;padding:48px;color:var(--text-secondary)}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.badge-sm{padding:2px 6px;font-size:.7rem}.badge-pending{background:#fef3c7;color:#92400e}.badge-confirmed{background:#dbeafe;color:#1e40af}.badge-completed{background:#dcfce7;color:#166534}.badge-cancelled{background:#f3f4f6;color:#6b7280}.badge-unpaid{background:#fee2e2;color:#991b1b}.badge-deposit{background:#e0e7ff;color:#3730a3}.badge-fullpaid{background:#d1fae5;color:#065f46}.badge-refunded{background:#f3e8ff;color:#6b21a8}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.detail-section:last-child{margin-bottom:0}.detail-section h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.detail-badges{display:flex;gap:8px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;gap:12px;align-items:flex-start}.detail-item svg{color:var(--text-secondary);flex-shrink:0;margin-top:2px}.detail-item label{display:block;font-size:.75rem;color:var(--text-secondary)}.detail-item span{font-weight:500}.detail-note{display:flex;gap:12px;padding:12px;background:var(--bg-primary);border-radius:var(--radius)}.detail-note svg{color:var(--text-secondary);flex-shrink:0}.detail-note p{color:var(--text-primary);font-size:.875rem}.payment-info{background:var(--bg-primary);border-radius:var(--radius);padding:16px}.payment-row{display:flex;justify-content:space-between;padding:8px 0;font-size:.875rem}.payment-row:not(:last-child){border-bottom:1px solid var(--border)}.payment-row .amount{font-weight:600}.payment-row .paid{color:var(--success);font-weight:600}.payment-row .refund{color:var(--danger);font-weight:600}.payment-row.total{font-weight:600;font-size:1rem;margin-top:8px;padding-top:12px}.sms-sent,.gcal-synced{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#dcfce7;color:#166534;border-radius:var(--radius);font-size:.875rem}.gcal-synced{background:#dbeafe;color:#1e40af}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-full{width:100%;justify-content:center}.calendar-page .calendar-container{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.calendar-cell{min-height:80px}}@media(max-width:768px){.hamburger-btn{display:flex!important}.sidebar{width:240px;transform:translate(-100%);transition:transform .3s ease;z-index:110}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{margin-left:0;padding:60px 12px 16px}.stats-section{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.calendar-cell{min-height:60px;padding:4px}.calendar-event{font-size:.6rem}.modal-overlay{padding:0;align-items:stretch}.modal-content{max-width:100%;max-height:none;border-radius:0;width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.modal-content .modal-header{padding:12px 16px;flex-shrink:0;z-index:2;background:var(--bg-secondary);position:relative}.modal-content .modal-header h2{font-size:1.1rem;padding-right:40px}.modal-content .modal-close{z-index:3}.modal-content .modal-body{flex:1 1 0;min-height:0;overflow-y:auto;overflow-x:hidden;padding:12px;-webkit-overflow-scrolling:touch}.modal-content .modal-footer{flex-wrap:wrap;gap:6px;padding:10px 12px;flex-shrink:0;z-index:2;background:var(--bg-secondary);border-top:1px solid var(--border)}.modal-footer .btn{flex:1 1 calc(50% - 6px);min-width:0;white-space:nowrap;font-size:.78rem;padding:8px;justify-content:center}.modal-large{max-width:100%;max-height:none;height:100vh;height:100dvh;border-radius:0}.btn,.nav-item,.sort-btn,.preset-btn,.filter-toggle,.toggle-btn,.modal-close,.calendar-nav-btn{min-height:44px}.btn-sm{min-height:40px;padding:8px 14px}.detail-section{margin-bottom:16px}.detail-section h3{font-size:.8rem;margin-bottom:8px}.payment-info{padding:10px}.payment-row{font-size:.8rem;padding:6px 0;flex-wrap:wrap}.room-booking-item{flex-wrap:wrap!important;gap:6px!important;padding:6px 8px!important}}.text-red-500{color:#ef4444}.text-blue-500{color:#3b82f6}.page-header-content{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.view-toggle{display:flex;gap:4px;background:var(--bg-primary);padding:4px;border-radius:var(--radius)}.toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.calendar-view-container{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.calendar-hint{text-align:center;color:var(--text-secondary);font-size:.875rem;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.timeline-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.timeline-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:1200px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.timeline-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--bg-primary);position:relative}.timeline-date-display{display:flex;align-items:center;gap:12px}.timeline-date-display svg{color:var(--primary)}.current-date{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.today-badge{background:var(--primary);color:#fff;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:4px}.timeline-header-actions{display:flex;align-items:center;gap:12px}.timeline-summary{font-size:.875rem;color:var(--text-secondary)}.timeline-legend{display:flex;gap:20px;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary)}.legend-color{width:12px;height:12px;border-radius:3px}.legend-color.pending{background:#fef3c7;border:1px solid #f59e0b}.legend-color.confirmed{background:#dbeafe;border:1px solid #3b82f6}.legend-color.completed{background:#dcfce7;border:1px solid #22c55e}.timeline-scroll-container{flex:1;overflow:auto;padding:16px 24px 24px}.timeline-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}.timeline-grid-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:16px 24px 0}.timeline-table{width:100%;border-collapse:collapse;table-layout:fixed}.timeline-table th,.timeline-table td{border:1px solid var(--border)}.timeline-room-header{width:140px;padding:12px;text-align:center;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);text-transform:uppercase}.timeline-hours-header{padding:0;background:var(--bg-primary)}.hours-grid{display:flex}.hour-label{flex:1;text-align:center;padding:12px 4px;font-size:.7rem;font-weight:500;color:var(--text-secondary);border-left:1px solid var(--border)}.hour-label:first-child{border-left:none}.timeline-room-cell{width:140px;padding:8px 12px;background:var(--bg-primary);vertical-align:middle}.room-label{font-size:.8rem;font-weight:600;color:var(--text-primary)}.room-count{display:inline-block;margin-left:8px;background:var(--primary);color:#fff;font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:10px}.timeline-events-cell{padding:0;height:48px;position:relative}.events-track{position:relative;height:100%;width:100%}.hours-background{display:flex;height:100%;position:absolute;top:0;left:0;right:0}.hour-slot{flex:1;border-left:1px solid var(--border);background:var(--bg-secondary)}.hour-slot:first-child{border-left:none}.hour-slot:nth-child(odd){background:var(--bg-primary)}.timeline-event{position:absolute;top:4px;bottom:4px;border-radius:4px;padding:4px 8px;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;justify-content:center;transition:transform .1s,box-shadow .1s;z-index:1}.timeline-event:hover{transform:scale(1.02);box-shadow:var(--shadow-md);z-index:2}.timeline-event-pending{background:#fef3c7;border:1px solid #f59e0b;color:#92400e}.timeline-event-confirmed{background:#dbeafe;border:1px solid #3b82f6;color:#1e40af}.timeline-event-completed{background:#dcfce7;border:1px solid #22c55e;color:#166534}.timeline-event-default{background:#f3f4f6;border:1px solid #9ca3af;color:#4b5563}.event-customer{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-time{font-size:.65rem;opacity:.8}.btn-sm{padding:6px 12px;font-size:.8rem}@media(max-width:1024px){.timeline-modal{max-width:95vw}.timeline-room-header,.timeline-room-cell{width:100px}.hour-label{font-size:.6rem;padding:8px 2px}}@media(max-width:768px){.page-header-content{flex-direction:column;align-items:flex-start;gap:12px}.timeline-modal-overlay{padding:0}.timeline-modal{max-width:100vw;max-height:100vh;height:100vh;border-radius:0;margin:0;display:flex;flex-direction:column}.timeline-modal-header{flex-direction:column;gap:6px;align-items:flex-start;padding:10px 12px;flex-shrink:0}.timeline-modal-header .modal-close{position:absolute;top:8px;right:8px}.timeline-date-display{gap:8px}.current-date{font-size:1rem}.timeline-summary{font-size:.8rem}.timeline-header-actions{display:flex;align-items:center;gap:8px}.timeline-legend{padding:8px 12px;gap:12px;flex-wrap:wrap;flex-shrink:0;font-size:.7rem}.timeline-body{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}.timeline-grid-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:8px 8px 0}.timeline-list-section{overflow-x:hidden;padding:12px 8px 8px}.timeline-scroll-container{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;padding:8px}.timeline-table{min-width:600px}.timeline-room-header,.timeline-room-cell{width:60px;min-width:60px;position:sticky;left:0;z-index:2;background:var(--bg-primary)}.timeline-room-cell{background:var(--bg-primary)}.room-label{font-size:.65rem}.event-customer{font-size:.6rem}.event-time{display:none}.hour-label{font-size:.55rem;padding:6px 1px}.timeline-list-section{margin-top:16px;padding-top:12px}.timeline-list-table thead{display:none}.timeline-list-table tbody tr.timeline-list-row{display:block;padding:10px;margin-bottom:8px;border-radius:var(--radius);border:1px solid var(--border)}.timeline-list-table td{display:flex;justify-content:space-between;align-items:center;padding:2px 0;border-bottom:none;font-size:.8rem}.timeline-list-table .list-customer:before{content:"예약자";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-rooms:before{content:"공간";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-rooms{max-width:none;white-space:normal;text-align:right}.timeline-list-table .list-count:before{content:"인원";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-amount:before{content:"금액";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-amount{text-align:right}.timeline-list-table .list-deposit:before{content:"예약금";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-deposit{text-align:right}.timeline-list-table .list-note:before{content:"비고";font-weight:600;font-size:.7rem;color:var(--text-secondary);min-width:50px}.timeline-list-table .list-note{max-width:none;white-space:normal;text-align:right}.timeline-list-table .list-edit{justify-content:flex-end}.staff-memo-row td{display:block;padding:4px 8px}.staff-memo-row td.memo-label{border-bottom:none;padding-bottom:0}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a);padding:24px}.login-container{width:100%;max-width:400px;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.login-header{text-align:center;padding:40px 24px 32px;background:linear-gradient(135deg,#1e3a5f,#1e293b);color:#fff}.login-logo{width:64px;height:64px;background:var(--primary);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 12px #2563eb66}.logo-icon{font-size:2rem;font-weight:700;color:#fff}.login-header h1{font-size:1.5rem;font-weight:700;margin-bottom:4px}.login-header p{font-size:.875rem;color:#ffffffb3}.login-form{padding:32px 24px}.login-error{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:var(--radius);font-size:.875rem;margin-bottom:20px;display:flex;align-items:center;gap:8px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.password-input{position:relative}.password-input input{padding-right:48px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text-primary)}.login-button{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.login-button:hover:not(:disabled){background:var(--primary-dark)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;padding:16px 24px 24px;border-top:1px solid var(--border)}.login-footer p{font-size:.75rem;color:var(--text-secondary)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg-primary)}.loading-screen p{color:var(--text-secondary)}.loading-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.large{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-user{padding:16px 24px;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-avatar{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem}.user-details{flex:1;min-width:0}.user-name{display:block;font-size:.875rem;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{display:block;font-size:.7rem;color:var(--text-light)}.logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#ffffff1a;border:none;border-radius:var(--radius);color:var(--text-light);font-size:.8rem;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ffffff26;color:#fff}@media(max-width:768px){.sidebar-user{padding:16px 24px}}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center}.loading-container p,.error-container p{color:var(--text-secondary);font-size:.9rem}.error-message{color:var(--danger)}.loading-spinner{animation:spin 1s linear infinite;color:var(--primary)}.event-room{font-size:.6rem;opacity:.7;display:none}.timeline-event:hover .event-room{display:block}.modal-large{max-width:800px;max-height:90vh;overflow-y:auto}.form-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;resize:vertical;font-family:inherit}.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;background:#fff;cursor:pointer}.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-error,.form-warning{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:.875rem}.form-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.form-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.form-warning ul{margin:4px 0 0 16px;padding:0}.form-warning li{margin:2px 0}.multi-room-selector{margin-top:16px}.room-bookings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.room-bookings-header label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.empty-bookings{text-align:center;padding:32px;background:var(--bg-primary);border-radius:var(--radius);border:2px dashed var(--border)}.empty-bookings p{color:var(--text-secondary);margin-bottom:16px}.room-bookings-list{display:flex;flex-direction:column;gap:12px}.room-booking-row{display:flex;align-items:flex-end;gap:12px;padding:16px;background:var(--bg-primary);border-radius:var(--radius);border:1px solid var(--border)}.booking-field{display:flex;flex-direction:column;gap:4px}.booking-field label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase}.booking-field select,.booking-field input{padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:.875rem;background:#fff}.booking-field select:focus,.booking-field input:focus{outline:none;border-color:var(--primary)}.room-type-field{flex:2}.time-field{flex:1;min-width:90px}.guest-field{width:70px}.guest-field input{width:100%}.booking-hours{display:flex;align-items:center;gap:4px;padding:8px 12px;background:var(--primary);color:#fff;border-radius:6px;font-size:.75rem;font-weight:500;white-space:nowrap}.remove-booking-btn{padding:8px;background:none;border:none;color:var(--danger);cursor:pointer;border-radius:6px;transition:all .2s}.remove-booking-btn:hover{background:#fee2e2}.price-summary{background:var(--bg-primary);border-radius:var(--radius);padding:20px!important;border:none!important;margin-bottom:0!important}.price-grid{display:flex;flex-direction:column;gap:8px}.price-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:.9rem}.price-row:first-child{font-size:1.1rem;font-weight:600;padding-bottom:12px;border-bottom:1px solid var(--border)}.price-value{font-weight:600;color:var(--primary)}.price-detail{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);padding:4px 0}.room-booking-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background-color:#f8fafc;border-radius:6px;margin-bottom:6px;flex-wrap:wrap}.room-booking-amount{margin-left:auto;color:#6366f1}.add-reservation-btn{display:flex;align-items:center;gap:8px}@media(max-width:768px){.room-booking-row{flex-wrap:wrap}.room-type-field{flex:1 1 100%}.time-field{flex:1}.guest-field{width:60px}.booking-hours{flex:1;justify-content:center}.room-booking-row{padding:10px;gap:8px}}.payment-form-modal{max-width:480px}.payment-summary{background:var(--bg-primary);border-radius:var(--radius);padding:16px;margin-bottom:20px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.summary-row:last-child{border-bottom:none}.summary-row span:first-child{color:var(--text-secondary)}.summary-row span:last-child{font-weight:500}.summary-row .paid{color:var(--success)}.summary-row.highlight{background:#eef2ff;margin:8px -16px -16px;padding:12px 16px;border-radius:0 0 var(--radius) var(--radius);border-bottom:none}.summary-row.highlight span:last-child{font-size:1.1rem;font-weight:600;color:var(--primary)}.amount-input-group{display:flex;align-items:center;gap:8px}.amount-input-group input{flex:1;text-align:right;font-size:1.25rem;font-weight:600}.amount-suffix{color:var(--text-secondary);font-size:1rem}.amount-quick-buttons{display:flex;gap:8px;margin-top:8px}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{background:var(--bg-primary);border-color:var(--primary);color:var(--primary)}.btn-sm{padding:6px 12px;font-size:.875rem}.payment-method-options{display:flex;gap:12px}.payment-method-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s}.payment-method-btn:hover{border-color:var(--primary)}.payment-method-btn.active{border-color:var(--primary);background:#eef2ff;color:var(--primary)}.payment-method-btn svg{color:var(--text-secondary)}.payment-method-btn.active svg{color:var(--primary)}.payment-method-btn span{font-size:.875rem;font-weight:500}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.page-header-left{display:flex;align-items:center;gap:16px}.add-reservation-btn{display:flex;align-items:center;gap:6px}.customers-page .search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:8px 16px;margin-bottom:16px}.customers-page .search-bar input{border:none;outline:none;flex:1;font-size:.9rem;background:transparent}.sort-options{display:flex;align-items:center;gap:8px;margin-bottom:16px}.sort-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.sort-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .15s}.sort-btn.active{border-color:var(--primary);color:var(--primary);background:#eff6ff}.sort-btn .sort-asc{transform:rotate(180deg)}.table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-bottom:16px}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.data-table td{padding:12px 16px;font-size:.9rem;border-bottom:1px solid #f1f5f9}.data-table tbody tr{cursor:pointer;transition:background .15s}.data-table tbody tr:hover{background:#f8fafc}.customer-row.revisit-highlight{background:#f0fdf4}.customer-row.revisit-highlight:hover{background:#dcfce7}.customer-name-cell{display:flex;align-items:center;gap:8px}.badge-revisit{background:#dcfce7;color:#15803d;font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:600}.text-center{text-align:center}.text-right{text-align:right}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}.pagination-info{font-size:.9rem;color:var(--text-secondary)}.customer-detail-modal{max-width:640px;max-height:85vh;overflow-y:auto}.detail-section{margin-bottom:24px}.detail-section h3{font-size:1rem;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-item{display:flex;align-items:flex-start;gap:10px}.detail-item svg{color:var(--text-light);margin-top:2px;flex-shrink:0}.detail-item label{display:block;font-size:.75rem;color:var(--text-light);margin-bottom:2px}.detail-item span{font-size:.9rem}.customer-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.customer-stat-card{text-align:center;padding:16px;background:#f8fafc;border-radius:var(--radius)}.customer-stat-card .stat-value{display:block;font-size:1.25rem;font-weight:700;color:var(--primary)}.customer-stat-card .stat-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:4px}.reservation-history{display:flex;flex-direction:column;gap:8px}.history-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);background:#f8fafc;font-size:.85rem}.history-item.status-cancelled{opacity:.5}.history-date{display:flex;align-items:center;gap:4px;color:var(--text-secondary);white-space:nowrap}.history-info{flex:1;display:flex;flex-direction:column;gap:2px}.history-room{font-weight:500}.history-time{font-size:.8rem;color:var(--text-light)}.history-payment{display:flex;align-items:center;gap:4px;font-weight:500;white-space:nowrap}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-light);gap:12px}.statistics-page .page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:24px}.date-range-picker{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.preset-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .15s}.preset-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.custom-date-inputs{display:flex;align-items:center;gap:6px}.custom-date-inputs input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem}.statistics-page .stats-section{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.chart-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px}.chart-card h3{font-size:1rem;font-weight:600;margin-bottom:16px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-header h3{margin-bottom:0}.chart-toggle{display:flex;gap:4px;background:var(--bg-primary);border-radius:var(--radius);padding:2px}.toggle-btn{padding:4px 12px;border:none;border-radius:var(--radius);background:transparent;cursor:pointer;font-size:.8rem;color:var(--text-secondary);transition:all .15s}.toggle-btn.active{background:var(--primary);color:#fff}.page-header-actions{display:flex;gap:8px;align-items:center}.chart-wide{grid-column:1 / -1}.empty-message{text-align:center;color:var(--text-light);padding:40px 0;font-size:.9rem}.heatmap-container{overflow-x:auto}.heatmap-grid{display:grid;grid-template-columns:40px repeat(15,1fr);gap:2px;min-width:500px}.heatmap-hour-label{text-align:center;font-size:.7rem;color:var(--text-light);padding:4px 0}.heatmap-day-label{display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:500;color:var(--text-secondary)}.heatmap-cell{aspect-ratio:1;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#fff;font-weight:600;min-height:28px}@media(max-width:1024px){.statistics-page .stats-section{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}}@media(max-width:640px){.statistics-page .stats-section,.detail-grid,.customer-stats{grid-template-columns:1fr}}.users-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.user-name-cell{display:flex;align-items:center;gap:8px}.badge-me{background:var(--primary);color:#fff;font-size:.65rem;padding:2px 6px;border-radius:10px}.role-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.role-super_admin{background:#fef3c7;color:#92400e}.role-admin{background:#dbeafe;color:#1e40af}.role-staff{background:#f3f4f6;color:#374151}.status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.status-active{background:#d1fae5;color:#065f46}.status-inactive{background:#fee2e2;color:#991b1b}.inactive-row{opacity:.55}.action-buttons{display:flex;gap:4px}.btn-success-outline{border:1px solid #10b981;color:#10b981;background:transparent}.btn-success-outline:hover{background:#ecfdf5}.btn-danger-outline{border:1px solid #ef4444;color:#ef4444;background:transparent}.btn-danger-outline:hover{background:#fef2f2}.user-form-modal{max-width:480px}.user-form-modal .modal-body{display:flex;flex-direction:column;gap:16px}.form-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:var(--radius);font-size:.85rem;border:1px solid #fecaca}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px}.hamburger-btn{display:none;position:fixed;top:12px;left:12px;z-index:150;background:var(--bg-sidebar, #1e293b);color:#fff;border:none;border-radius:var(--radius, 8px);padding:8px;cursor:pointer;min-width:44px;min-height:44px;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:100}@media(max-width:768px){.reservation-list{padding:12px}.reservation-table thead{display:none}.reservation-table tbody tr{display:block;background:var(--bg-secondary, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 8px);padding:10px;margin-bottom:8px}.reservation-table tbody tr:hover{border-color:var(--primary, #6366f1)}.reservation-table td{display:flex;justify-content:space-between;align-items:center;padding:3px 0;border-bottom:none;font-size:.82rem}.reservation-table td:before{content:attr(data-label);font-weight:600;font-size:.72rem;color:var(--text-secondary, #64748b);min-width:55px;flex-shrink:0}.reservation-table td:nth-child(6),.reservation-table td:nth-child(7){display:none}.list-controls{flex-direction:column;gap:8px}.search-box{width:100%}.filter-panel{flex-direction:column}.customers-page .data-table thead{display:none}.customers-page .data-table tbody tr{display:block;padding:10px;margin-bottom:8px;border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 8px);background:var(--bg-secondary, #f8fafc)}.customers-page .data-table td{display:flex;justify-content:space-between;align-items:center;padding:3px 0;border-bottom:none;font-size:.82rem}.customers-page .data-table td:before{content:attr(data-label);font-weight:600;font-size:.72rem;color:var(--text-secondary, #64748b);min-width:55px;flex-shrink:0}.sort-options{flex-wrap:wrap;gap:4px}.users-table thead{display:none}.users-table tbody tr{display:block;padding:10px;margin-bottom:8px;border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 8px);background:var(--bg-secondary, #f8fafc)}.users-table td{display:flex;justify-content:space-between;align-items:center;padding:3px 0;border-bottom:none;font-size:.82rem}.users-table td:before{content:attr(data-label);font-weight:600;font-size:.72rem;color:var(--text-secondary, #64748b);min-width:55px;flex-shrink:0}.statistics-page .page-header{flex-direction:column;align-items:flex-start;gap:12px}.date-range-picker{width:100%;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.preset-buttons{flex-wrap:wrap}.custom-date-inputs{flex-wrap:wrap;gap:8px}.chart-toggle{flex-wrap:wrap}.heatmap-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.page-header-actions{width:100%}.dashboard-grid{grid-template-columns:1fr}.page-header h1{font-size:1.3rem}.form-grid{grid-template-columns:1fr}.form-section{margin-bottom:16px;padding-bottom:16px}.form-section h3{font-size:.95rem;margin-bottom:10px}.payment-method-options{flex-direction:column}.payment-method-options label{width:100%}.payment-form-modal{max-width:100%;height:100vh;border-radius:0}.customer-detail-modal{max-width:100%;max-height:100vh;height:100vh;border-radius:0;display:flex;flex-direction:column}.customer-detail-modal .modal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.customer-stats{grid-template-columns:1fr 1fr 1fr;gap:8px}.customer-stat-card{padding:10px}.customer-stat-card .stat-value{font-size:1.1rem}.history-item{flex-wrap:wrap;gap:6px;padding:8px 10px;font-size:.8rem}.calendar-view-container{padding:12px}.calendar-header{margin-bottom:10px}.calendar-title{font-size:1rem}.price-summary{padding:12px!important}.price-row{font-size:.85rem;padding:6px 0}.price-row:first-child{font-size:1rem}.price-detail{font-size:.75rem}}@media(max-width:480px){.main-content{padding:56px 8px 12px}.stats-section{grid-template-columns:1fr}.customer-stats{grid-template-columns:repeat(3,1fr)}.page-header{flex-direction:column;align-items:flex-start!important;gap:8px}.page-header h1{font-size:1.15rem}.modal-footer .btn{font-size:.72rem;padding:7px 6px;flex:1 1 calc(50% - 4px)}.timeline-room-header,.timeline-room-cell{width:50px;min-width:50px}.room-label{font-size:.6rem}.timeline-events-cell{height:40px}.stat-card{padding:12px;gap:10px}.stat-icon{width:36px;height:36px}.stat-value{font-size:1.2rem}.stat-content h3{font-size:.75rem}}.log-page{padding:0}.log-page .page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.log-search-bar{display:flex;align-items:center;gap:8px}.log-search-input{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;width:200px;background:var(--bg-secondary);color:var(--text-primary)}.log-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:20px}.log-calendar-section,.log-detail-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.daily-tasks-panel{margin-bottom:16px;padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius)}.daily-tasks-header{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.85rem;color:#92400e;margin-bottom:10px}.daily-tasks-grid{display:flex;gap:20px;flex-wrap:wrap}.daily-tasks-group{display:flex;flex-direction:column;gap:4px;min-width:160px}.daily-tasks-group-label{font-weight:600;font-size:.8rem;color:#78350f;margin-bottom:2px}.daily-task-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#44403c;cursor:pointer}.daily-task-item input[type=checkbox]{accent-color:#d97706}.daily-task-item .task-done{text-decoration:line-through;color:#a8a29e}.log-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.log-detail-header h2{font-size:1rem;font-weight:600}.log-form{display:flex;gap:8px;align-items:center;margin-bottom:16px;padding:12px;background:var(--bg-primary);border-radius:var(--radius);flex-wrap:wrap}.log-form-input{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--bg-secondary);color:var(--text-primary)}.log-form-input:first-child{width:120px}.log-form-content{flex:1;min-width:150px}.log-form-actions{display:flex;gap:4px}.log-list{display:flex;flex-direction:column;gap:8px}.log-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-primary);border-radius:var(--radius);border:1px solid var(--border);gap:12px}.log-item-date{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;min-width:70px}.log-item-content{flex:1;font-size:.875rem}.log-item-name{font-weight:600}.log-item-dash{color:var(--text-secondary)}.log-item-checkbox{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.log-item-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.log-item-done{background:var(--bg-secondary)}.log-item-actions{display:flex;gap:4px}.btn-icon{background:none;border:none;cursor:pointer;padding:4px;border-radius:var(--radius);color:var(--text-secondary);display:flex;align-items:center}.btn-icon:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-icon-danger:hover{color:#dc2626;background:#fef2f2}.btn-sm{padding:4px 10px;font-size:.8rem;display:flex;align-items:center;gap:4px}@media(max-width:768px){.log-grid{grid-template-columns:1fr}.log-search-input{width:140px}.log-form{flex-direction:column;align-items:stretch}.log-form-input:first-child{width:100%}}
