﻿body {
    font-family: 'Montserrat', sans-serif;
    background-color: #f5f5f5;
}

h1, h2, h3 {
    font-weight: 600;
}



header h1 {
    font-size: 4rem;
    margin-bottom: 50px;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}

header p {
    font-size: 1.5rem;
    margin-bottom: 50px;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.5);
}

.price-box {
    background: rgba(46, 196, 182, 0.15); /* --success-color con trasparenza */
    color: var(--success-dark); /* #1b9b8f */
    border: 1px solid var(--success-dark);
}

.price-boxDark {
    background: var(--dark-light); /* #2d5973 */
    color: var(--light-color); /* #eae2b7 */
    border-left: 3px solid var(--primary-color);
}

html {
    font-size: 16px;
}

:root {
    /* Colori base (mantenendo la tua identità) */
    --primary-color: #d62828; /* Rosso vibrante */
    --primary-dark: #a01d1d; /* 20% più scuro */
    --primary-light: #e84545; /* 15% più chiaro */

    --secondary-color: #f77f00; /* Arancione vivace */
    --secondary-dark: #c16600; /* 20% più scuro */
    --secondary-light: #ff9e36; /* 15% più chiaro */

    --dark-color: #003049; /* Blu notte profondo */
    --dark-medium: #1a4d6b; /* Versione più leggera */
    --dark-light: #2d5973; /* Per hover/effects */

    --light-color: #eae2b7; /* Beige chiaro */
    --light-dark: #d4cc9f; /* Versione più scura */
    /* Nuovi colori moderni */
    --accent-color: #fcbf49; /* Giallo dorato - perfetto per CTA */
    --accent-dark: #e0a825;
    --accent-light: #ffd166;
    --success-color: #2ec4b6; /* Turchese moderno */
    --success-dark: #1b9b8f;
    --danger-color: #e71d36; /* Rosso intenso */
    --danger-light: #ff3366;
    --warning-color: #ff9f1c; /* Arancione brillante */
    /* Scale di grigi moderne */
    --white-color: #ffffff;
    --gray-100: #f8f9fa;
    --gray-200: #e9ecef;
    --gray-300: #dee2e6;
    --gray-400: #ced4da;
    --gray-500: #adb5bd;
    --gray-600: #6c757d;
    --gray-700: #495057;
    --gray-800: #343a40;
    --gray-900: #212529;
    --black-color: #121212; /* Nero più morbido */
    /* Gradienti utili */
    --gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
    --gradient-dark: linear-gradient(135deg, var(--dark-color) 0%, var(--dark-medium) 100%);
    --gradient-accent: linear-gradient(to right, var(--accent-color), var(--warning-color));
    /* Ombre moderne */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.12);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.1);
    --shadow-primary: 0 4px 14px rgba(214, 40, 40, 0.3);
    --shadow-accent: 0 4px 14px rgba(252, 191, 73, 0.3);
    /* Bordi */
    --border-radius-sm: 4px;
    --border-radius-md: 8px;
    --border-radius-lg: 12px;
    --border-radius-xl: 16px;
    --border-radius-full: 9999px;
    /* Transizioni */
    --transition-fast: all 0.15s ease;
    --transition-normal: all 0.3s ease;
    --transition-slow: all 0.5s ease;
}
/* Contenitore delle card */
.cards-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Due colonne */
    gap: 1rem; /* Spazio tra le card */
    padding: 1rem;
}
/* Solo per le card dei prodotti nel menu */
.product-card .card-body {
    font-size: 14px;
}

.product-card .section-titleCard {
    font-size: 1.1rem;
    margin-bottom: 0.75rem;
}

.product-card .card-text {
    font-size: 14px;
    line-height: 1.3;
}

.product-card .text-muted {
    font-size: 12px;
}

.product-card .price-size {
    font-size: 13px;
}

.product-card .badge.price-box {
    font-size: 13px;
    padding: 0.35em 0.65em;
}

.card img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.card-content {
    padding: 1rem;
    text-align: center;
}

    .card-content h3 {
        font-size: 1.25rem;
        margin: 0.5rem 0;
    }

    .card-content p {
        font-size: 0.9rem;
        color: #666;
    }

/* Hover effect */
.card:hover {
    transform: scale(1.05);
}





.span-custom-width {
    width: 50px;
    display: inline-block;
    text-align: center;
    background-color: #366A99;
    color: white;
    padding: 3px;
    border-radius: 10px;
}




.card-image {
    display: none; /* Nasconde l'immagine di default */
    transition: opacity 0.3s ease-in-out; /* Transizione fluida */
    overflow: hidden; /* Nasconde eventuali parti in eccesso dell'immagine */
    height: 150px; /* Imposta un'altezza fissa per il div dell'immagine (puoi modificare questo valore) */
}

.card:hover .card-image {
    display: block;
    opacity: 1;
}

.card-image img {
    height: 125%;
    object-fit: cover;
    width: 280px;
    margin: 0 auto;
}

.header-buttons {
    gap: 1px; /* Spaziatura tra i pulsanti */
}

.card {
    transition: transform 0.5s, height 0.3s; /* Effetto di trasformazione e ridimensionamento */
    padding: 5px;
    margin: 2px;
    max-width: 300px;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    overflow: hidden;
    position: relative;
}

    .card:hover {
        transform: scale(1.05); /* Ingrandisce la card al passaggio del mouse */
        height: auto; /* Mantieni l'altezza automatica per l'adattamento del contenuto */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        transform: scale(1.01);
    }

.card-image img {
    width: 100%; /* L'immagine si adatta alla larghezza del contenitore */
    height: auto; /* Mantiene le proporzioni dell'immagine */
    object-fit: cover; /* Mantiene le proporzioni e ritaglia l'immagine se necessario */
    border-radius: 20px; /* Arrotonda tutti gli angoli */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Aggiunge un'ombra per l'effetto di sfumatura */
}



.card-body {
    position: relative;
    z-index: 1; /* Il contenuto rimane sopra l'immagine */

    width: 100%; /* Occupa tutta la larghezza della card */

    margin: 0; /* Rimuove eventuali margini indesiderati */
    box-sizing: border-box; /* Include padding e bordi nella larghezza totale */
}

/* Immagini diverse per ciascuna card */
.card-pane {
    background-image: url('/images/pane3.webp');
    background-size: cover;
    background-position: center;
}

.card-pizza {
    background-image: url('/images/Pizza18.webp');
    background-size: cover;
    background-position: center;
}

.card-pizza1 {
    background-image: url('/images/Pizza10.webp');
    background-size: cover;
    background-position: center;
}

.card-pizza2 {
    background-image: url('/images/Pizza15.webp');
    background-size: cover;
    background-position: center;
}

.card-pizza3 {
    background-image: url('/images/Pizza18.webp');
    background-size: cover;
    background-position: center;
}

.card-title, .card-text {
    word-wrap: break-word; /* Permette al testo lungo di andare a capo */
}

.card-title {
    font-size: 1em;
    margin: 0;
    margin-bottom: 5px;
    word-wrap: break-word;
    margin-bottom: 8px; /* Spazio tra la linea e gli ingredienti */
    margin-top: 8px; /* Spazio sopra il titolo */
    padding-bottom: 8px; /* Spazio sotto la linea */
    border-bottom: 0.5px solid #ccc; /* Linea sottile grigia sotto il titolo */
    display: block; /* Assicura che si comporti come elemento a blocco */
    width: 100%; /* Estende la linea fino ai bordi della card */
}

.card-text {
    font-size: 0.8em; /* Ridotto un po' per adattarsi meglio */
    margin: 0;
    margin-bottom: 5px;
    text-overflow: ellipsis;
    margin-bottom: 8px; /* Spazio tra la linea e gli ingredienti */
    margin-top: 8px;
}



.bg-custom-gradient {
    background: radial-gradient(circle, rgba(54, 106, 153, 0.8) 10%, rgba(135, 206, 250, 0.8) 80%), linear-gradient(90deg, rgba(54, 106, 153, 1) 0%, rgba(135, 206, 250, 1) 100%);
}

.bg-price-card {
    background-color: rgba(40, 167, 69, 0.4);
    color: white;
}

.hidden {
    display: none;
}

.pizza-subsections {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    padding: 1rem;
}

.subsection {
    font-size: 0.8rem;
    cursor: pointer;
    color: #366A99;
    font-weight: bold;
    padding: 5px 10px;
    border-radius: 5px;
    transition: background-color 0.3s ease;
    display: flex;
    justify-content: center; /* Centro orizzontale */
    margin: 0 auto; /* Centra orizzontalmente */
    text-align: center; /* Centra il testo all'interno delle subsezioni */
    border-bottom: 2px solid #366A99; /* Spessore e colore del bordo inferiore */
    padding: 10px; /* Aggiunge spazio interno per migliorare la visualizzazione */
}

.pizza-list {
    display: flex;
    justify-content: center; /* Centro orizzontale */
    align-items: center; /* Centro verticale */
}

.hidden p {
    display: none; /* Nasconde il testo della categoria */
}

.pizza-list p {
    display: flex;
    justify-content: center;
}
/* Stile per le card */
.cards-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Due colonne su desktop */
    gap: 1rem; /* Spazio tra le card */
    padding: 1rem;
}



/* Hover effect */
.card:hover {
    transform: scale(1.05);
}

.info-section {
    background-color: rgba(234, 226, 183, 0.2); /* --light-color con opacità */
    border: 1px solid var(--light-dark); /* #d4cc9f */
    border-radius: var(--border-radius-lg);
    padding: 1.5rem;
    margin-top: 2rem;
    box-shadow: var(--shadow-sm);
}

.info-title {
    color: var(--dark-color);
    border-bottom: 2px solid var(--accent-color);
    padding-bottom: 0.5rem;
    margin-bottom: 1.5rem;
    font-weight: 700;
}

.info-section h5 {
    color: var(--dark-medium);
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.info-section .text-primary {
    color: var(--primary-color) !important;
}

.info-section .text-warning {
    color: var(--warning-color) !important;
}

.info-section .text-secondary {
    color: var(--secondary-color) !important;
}

.info-section .alert-warning {
    background-color: rgba(255, 159, 28, 0.15); /* --warning-color con opacità */
    border-color: var(--warning-color);
    color: var(--dark-color);
    border-radius: var(--border-radius-md);
}

/* Icone personalizzate */
.info-section i {
    font-size: 1.1em;
    vertical-align: middle;
}


.section-titleCard {
    font-size: 1.5rem;
    color: var(--dark-color);
    margin-bottom: 2rem;
    position: relative;
    display: inline-block;
}
    /*Sezione specialità*/

    .section-titleCard:after {
        content: '';
        position: absolute;
        bottom: -10px;
        left: 0;
        width: 60px;
        height: 4px;
        background: var(--secondary-color);
    }

.section-title {
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    color: var(--dark-color);
    margin-bottom: 3rem;
    position: relative;
    display: inline-block;
}

    /*Sezione specialità*/

    .section-title:after {
        content: '';
        position: absolute;
        bottom: -10px;
        left: 0;
        width: 60px;
        height: 4px;
        background: var(--secondary-color);
    }

.btn-outline-custom {
    --bs-btn-color: var(--dark-color);
    --bs-btn-border-color: var(--dark-color);
    --bs-btn-hover-color: var(--light-color);
    --bs-btn-hover-bg: var(--dark-color);
    --bs-btn-hover-border-color: var(--dark-color);
    --bs-btn-focus-shadow-rgb: 0, 48, 73;
    --bs-btn-active-color: var(--light-color);
    --bs-btn-active-bg: var(--dark-light);
    --bs-btn-active-border-color: var(--dark-light);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: var(--dark-color);
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: var(--dark-color);
    --bs-gradient: none;
}
/* Aggiungi queste regole al tuo foglio di stile */
.modal-lg {
    max-width: 800px;
}

h1, h2, h3 {
    font-weight: 600;
}

.modal-content {
    border-radius: var(--border-radius-xl);
    overflow: hidden;
}

.bg-light-custom {
    background-color: rgba(234, 226, 183, 0.3); /* --light-color con trasparenza */
}
/* Colore di sfondo della navbar  --secondary-color: #f77f00;*/

.navbar {
    background-color: #ffefef;
}

/* Stile per i link con la classe nav-link */
.nav-link {
    padding: 20px 25px; /* Maggiore spaziatura per i link */
    font-size: 1.3rem; /* Aumenta leggermente la dimensione del testo */
    transition: color 0.3s ease-in-out, transform 0.3s ease-in-out;
}

    /* Effetto hover per i link: ingrandimento */
    .nav-link:hover {
        color: #ff4d4d;
        transform: scale(1.1);
    }

/* Allineamento logo e titolo */
.navbar-brand {
    display: flex;
    align-items: center;
    font-size: 1.25rem; /* Aumenta leggermente la dimensione del testo del titolo */
}
.ingredient-icon {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.bg-accent-light {
    background-color: rgba(252, 191, 73, 0.15); /* --accent-color con trasparenza */
    transition: var(--transition-fast);
}

    .bg-accent-light:hover {
        transform: translateY(-3px);
        box-shadow: var(--shadow-sm);
    }
