
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;700&display=swap');

:root {
    --primary-color: #264653;
    --primary-hover: #223f4a;
    --secondary-color: #264653;
    --background-color: #ffffff;
    --text-color: #264653;
    --border-color: #d6d6d6;
    --navbar-background-color: #008cb4;
    --white: #ffffff;
    --danger-color: #a0586b;

    --font-headings: 'Open Sans', sans-serif;
    --font-body: 'Open Sans', sans-serif;
}

/*
 * Styles Généraux
 */
body {
    background-color: var(--background-color);
    color: var(--text-color);
    font-family: var(--font-body);
}

h1, h2, h3, h4, h5, .display-4 {
    font-family: var(--font-headings);
    font-weight: 300;
}

/*
 * Barre de Navigation
 */
.navbar {
    background-color: var(--navbar-background-color) !important;
    border-bottom: 1px solid var(--border-color);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.navbar-brand, .nav-link {
    color: var(--white) !important;
    transition: color 0.3s ease;
}

.navbar-brand:hover, .nav-link:hover {
    color: #f0f0f0 !important; /* Light grey for hover */
}

/*
 * Boutons
 */
.btn-dark {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--white);
    transition: all 0.3s ease;
}

.btn-dark:hover {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    transform: translateY(-2px);
}

.btn-danger {
    background-color: var(--danger-color);
    border-color: var(--danger-color);
}

.btn-secondary {
     background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

/*
 * Cartes (Produits)
 */
.card {
    border: 1px solid var(--border-color);
    background-color: var(--white);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

.card-img-top {
    width: 100%;
    height: 280px;
    object-fit: cover;
}

/*
 * Bandeau d'accueil
 */
.bg-body-secondary {
    background-color: var(--white) !important;
    border: 1px solid var(--border-color);
}

/*
 * Badges et liens
 */
.badge.bg-secondary {
    background-color: var(--secondary-color) !important;
}

a {
    color: var(--primary-color);
}

a:hover {
    color: var(--primary-hover);
}

/*
 * Bordures
 */
.border-bottom {
    border-bottom-color: var(--border-color) !important;
}

.border-top {
    border-top-color: var(--border-color) !important;
}

.unavailable-price {
    text-decoration: line-through;
    color: #999 !important;
}
