@import url("https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap");
.lgb-booking-widget, .lgb-booking-widget * { font-family: "Lato", sans-serif; box-sizing: border-box; }
.lgb-booking-widget { max-width: 900px; margin: 40px auto; padding: 40px; background: #000000; border-radius: 16px; box-shadow: 0 10px 40px rgba(0, 123, 255, 0.3); color: #ffffff; }
.lgb-booking-header { text-align: center; margin-bottom: 40px; padding-bottom: 20px; border-bottom: 3px solid #007bff; }
.lgb-booking-header h2 { font-size: 32px; font-weight: 900; color: #ffffff; margin: 0; text-transform: uppercase; letter-spacing: 2px; }
.lgb-calendar-container { margin-bottom: 40px; background: #1a1a1a; border: 1px solid #333333; border-radius: 12px; padding: 30px; }
.lgb-calendar-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; }
.lgb-calendar-nav { background: linear-gradient(135deg, #007bff 0%, #0056b3 100%); color: white; border: none; width: 50px; height: 50px; border-radius: 50%; cursor: pointer; font-size: 24px; display: flex; align-items: center; justify-content: center; transition: all 0.3s ease; box-shadow: 0 4px 15px rgba(0, 123, 255, 0.3); }
.lgb-calendar-nav:hover { background: linear-gradient(135deg, #0056b3 0%, #004085 100%); transform: scale(1.1); }
.lgb-calendar-title { font-size: 24px; font-weight: 700; color: #ffffff; margin: 0; text-transform: uppercase; letter-spacing: 1px; }
.lgb-calendar-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; margin-bottom: 8px; }
.lgb-weekday { text-align: center; font-weight: 700; padding: 12px 0; background: #2a2a2a; color: #007bff; border-radius: 8px; text-transform: uppercase; font-size: 12px; letter-spacing: 1px; }
.lgb-calendar-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.lgb-calendar-day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; border: 2px solid #333333; border-radius: 8px; cursor: pointer; transition: all 0.3s ease; font-weight: 700; font-size: 16px; background: #1a1a1a; color: #ffffff; }
.lgb-calendar-day:hover:not(.lgb-disabled) { transform: scale(1.1); box-shadow: 0 4px 15px rgba(0, 123, 255, 0.4); border-color: #007bff; }
.lgb-calendar-day.lgb-available { background: linear-gradient(135deg, rgba(40, 167, 69, 0.2) 0%, rgba(40, 167, 69, 0.1) 100%); border-color: #28a745; color: #28a745; }
.lgb-calendar-day.lgb-booked { background: linear-gradient(135deg, rgba(220, 53, 69, 0.2) 0%, rgba(220, 53, 69, 0.1) 100%); border-color: #dc3545; color: #dc3545; cursor: not-allowed; }
.lgb-calendar-day.lgb-selected { background: linear-gradient(135deg, #007bff 0%, #0056b3 100%); border-color: #007bff; color: white; font-weight: 900; }
.lgb-calendar-legend { display: flex; justify-content: center; gap: 30px; margin-top: 25px; flex-wrap: wrap; }
.lgb-legend-item { display: flex; align-items: center; gap: 10px; }
.lgb-legend-color { width: 24px; height: 24px; border-radius: 6px; border: 2px solid; }
.lgb-legend-color.lgb-available { background: rgba(40, 167, 69, 0.2); border-color: #28a745; }
.lgb-legend-color.lgb-booked { background: rgba(220, 53, 69, 0.2); border-color: #dc3545; }
.lgb-date-inputs { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; margin-bottom: 30px; }
.lgb-input-group { display: flex; flex-direction: column; gap: 8px; }
.lgb-input-group label { font-weight: 700; font-size: 14px; color: #007bff; text-transform: uppercase; letter-spacing: 1px; }
.lgb-input-group input { padding: 14px; border: 2px solid #333333; border-radius: 8px; font-size: 16px; background: #1a1a1a; color: #ffffff; transition: all 0.3s ease; font-family: "Lato", sans-serif; font-weight: 600; }
.lgb-input-group input:focus { border-color: #007bff; outline: none; box-shadow: 0 0 0 4px rgba(0, 123, 255, 0.2); }
.lgb-price-display { background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); padding: 30px; border-radius: 12px; margin-bottom: 30px; border: 2px solid #007bff; }
.lgb-price-row { display: flex; justify-content: space-between; padding: 12px 0; font-size: 16px; color: #cccccc; }
.lgb-price-row.lgb-total-row { border-top: 3px solid #007bff; margin-top: 15px; padding-top: 20px; font-size: 24px; font-weight: 900; color: #ffffff; }
.lgb-btn { flex: 1; padding: 16px; border: none; border-radius: 8px; font-size: 16px; font-weight: 900; cursor: pointer; transition: all 0.3s ease; text-transform: uppercase; letter-spacing: 1px; font-family: "Lato", sans-serif; }
.lgb-btn-primary { background: linear-gradient(135deg, #28a745 0%, #218838 100%); color: white; box-shadow: 0 4px 15px rgba(40, 167, 69, 0.3); }
.lgb-btn-primary:hover { background: linear-gradient(135deg, #218838 0%, #1e7e34 100%); transform: translateY(-2px); }
.lgb-btn-secondary { background: linear-gradient(135deg, #007bff 0%, #0056b3 100%); color: white; box-shadow: 0 4px 15px rgba(0, 123, 255, 0.3); }
.lgb-btn-secondary:hover { background: linear-gradient(135deg, #0056b3 0%, #004085 100%); transform: translateY(-2px); }
.lgb-actions { display: flex; gap: 20px; margin-bottom: 20px; }
.lgb-messages { margin-top: 20px; }
.lgb-message { padding: 16px 20px; border-radius: 8px; margin-bottom: 15px; font-weight: 600; border: 2px solid; }
.lgb-message.success { background: rgba(40, 167, 69, 0.2); color: #28a745; border-color: #28a745; }
.lgb-message.error { background: rgba(220, 53, 69, 0.2); color: #dc3545; border-color: #dc3545; }
.lgb-guest-option { margin-bottom: 30px; padding: 20px; background: #1a1a1a; border: 1px solid #333333; border-radius: 12px; }
@media (max-width: 768px) { .lgb-booking-widget { padding: 20px; margin: 20px 10px; } .lgb-date-inputs { grid-template-columns: 1fr; } .lgb-actions { flex-direction: column; } }