<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>КоктейльБар</title>
<style>
body {
font-family: Arial, sans-serif;
background: #f8f9fa;
margin: 0;
padding: 20px;
}
h1 {
text-align: center;
color: #333;
margin-bottom: 30px;
}
.cards {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 20px;
max-width: 1200px;
margin: 0 auto;
}
.card {
background: white;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
transition: transform 0.3s;
}
.card:hover {
transform: scale(1.05);
}
.card img {
width: 100%;
height: 260px;
object-fit: cover;
}
.card-body {
padding: 15px;
text-align: center;
}
.card h3 {
margin: 10px 0 15px 0;
color: #222;
font-size: 1.2em;
}
.order-btn {
background: #e74c3c;
color: white;
border: none;
padding: 10px 20px;
border-radius: 6px;
font-size: 16px;
cursor: pointer;
}
.order-btn:hover {
background: #c0392b;
}
</style>
</head>
<body>
<h1>Популярные коктейли</h1>
<div class="cards" id="cocktails"></div>
<script>
const API_URL = "https://www.thecocktaildb.com/api/json/v1/1/filter.php?c=Cocktail";
async function loadCocktails() {
try {
const response = await fetch(API_URL);
const data = await response.json();
const container = document.getElementById('cocktails');
container.innerHTML = '';
data.drinks.forEach(drink => {
const card = document.createElement('div');
card.className = 'card';
card.innerHTML = `
<img src="\( {drink.strDrinkThumb}" alt=" \){drink.strDrink}">
<div class="card-body">
<h3>${drink.strDrink}</h3>
<button class="order-btn" onclick="orderCocktail('${drink.strDrink}')">
Заказать
</button>
</div>
`;
container.appendChild(card);
});
} catch (error) {
document.getElementById('cocktails').innerHTML =
`<p style="color:red;text-align:center;font-size:18px;">
Ошибка загрузки. Проверьте подключение к интернету.
</p>`;
}
}
function orderCocktail(name) {
alert("Заказ принят!\n\nВы заказали: " + name);
}
window.onload = loadCocktails;
</script>
</body>
</html>