/* style.css - COMPLETO CON BOTTONI IN LINEA */

@import url('https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/4.1.5/css/flag-icon.min.css');
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* =========================================
   1. VARIABILI E TEMI
   ========================================= */
:root {
    --bg-body: #f8f9fa;
    --text-main: #212529;
    --card-bg: #ffffff;
    --navbar-bg: #ffffff;
    --bottom-nav-bg: #ffffff;
    --border-color: rgba(0,0,0,0.1);
    --accent: #0d6efd;
    --input-bg: #ffffff;
    --header-height: 85px; /* HEADER ALTO */
}

[data-theme="dark"] {
    --bg-body: #0f172a; --text-main: #ffffff; --card-bg: #1e293b; --navbar-bg: #1e293b; --bottom-nav-bg: #1e293b; --border-color: rgba(255,255,255,0.1); --accent: #60a5fa; --input-bg: #334155;
}
[data-theme="luxury"] {
    --bg-body: #000000; --text-main: #f0f0f0; --card-bg: #111111; --navbar-bg: #0a0a0a; --bottom-nav-bg: #0a0a0a; --border-color: #d4af37; --accent: #d4af37; --input-bg: #1a1a1a;
}

/* =========================================
   2. IMPOSTAZIONI BASE
   ========================================= */
body {
    background-color: var(--bg-body) !important; 
    color: var(--text-main) !important; 
    font-family: 'Poppins', sans-serif; 
    transition: background 0.3s; 
    padding-bottom: 90px; 
    overflow-x: hidden;
    padding-top: var(--header-height) !important; 
    top: 0 !important;
}

h1, h2, h3, h4, h5, h6, a { color: var(--text-main); }
[data-theme="dark"] .text-muted, [data-theme="luxury"] .text-muted { color: rgba(255,255,255,0.7) !important; }

/* =========================================
   3. HEADER E NAVBAR
   ========================================= */
.navbar.fixed-top {
    background-color: var(--navbar-bg) !important;
    color: var(--text-main) !important;
    border-bottom: 1px solid var(--border-color) !important;
    min-height: var(--header-height) !important;
    display: flex;
    align-items: center;
    z-index: 1030;
}

.navbar-logo-img { 
    height: 75px; 
    width: auto; 
    object-fit: contain; 
}
@media (max-width: 768px) { 
    .navbar-logo-img { height: 60px; } 
}

/* =========================================
   4. CARD E PRODOTTI
   ========================================= */
.card, .modal-content, .form-control {
    background-color: var(--navbar-bg) !important; color: var(--text-main) !important; border-color: var(--border-color) !important;
}
.card { background-color: var(--card-bg) !important; box-shadow: 0 4px 6px rgba(0,0,0,0.05); }

.card-title-dynamic { 
    font-weight: 700; font-size: 1rem; 
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; 
}
.cat-img { transition: transform 0.3s; }
.card:hover .cat-img { transform: scale(1.02); }

/* FIX PREZZO */
.product-price { 
    font-weight: 700; 
    font-size: 1.3rem; 
    color: #000000; 
    white-space: nowrap !important; 
    flex-shrink: 0 !important;      
}
[data-theme="dark"] .product-price, [data-theme="luxury"] .product-price { 
    color: #ffc107 !important; 
    text-shadow: 0 0 5px rgba(0,0,0,0.5); 
}
@media (max-width: 768px) {
    .product-price { font-size: 1.1rem; }
}

/* BADGE */
[data-theme="dark"] .badge.bg-warning-lt, [data-theme="luxury"] .badge.bg-warning-lt { background-color: #ffc107 !important; color: #000000 !important; border: 1px solid rgba(255,255,255,0.2); }
[data-theme="dark"] .badge.bg-info-lt, [data-theme="luxury"] .badge.bg-info-lt { background-color: #0dcaf0 !important; color: #000000 !important; border: 1px solid rgba(255,255,255,0.2); }

/* =========================================
   5. MENU IN BASSO
   ========================================= */
.navbar-bottom { background-color: var(--bottom-nav-bg) !important; border-top: 1px solid var(--border-color) !important; }
.navbar-bottom .nav-link { 
    color: var(--text-main) !important; 
    opacity: 0.95; 
    font-weight: 500; 
}
.navbar-bottom .nav-link.active-nav { color: var(--accent) !important; opacity: 1; font-weight: 700; }

/* LOGO FOOTER */
[data-theme="dark"] .footer-logo, [data-theme="luxury"] .footer-logo { filter: invert(1) grayscale(100%) brightness(200%); opacity: 0.9; }

/* OFFCANVAS */
.offcanvas { background-color: var(--card-bg) !important; color: var(--text-main) !important; }
.offcanvas-header .btn-close { filter: invert(1); }
[data-theme="light"] .offcanvas-header .btn-close { filter: none; }
.list-group-item { background-color: transparent !important; color: var(--text-main) !important; border-color: var(--border-color) !important; }

/* =========================================
   6. BOTTONI MARKETING IN LINEA
   ========================================= */

/* BOTTONI RECENSIONI PICCOLI E ALLINEABILI */
.btn-compact {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: auto;             /* Non forza 100% */
    padding: 8px 12px;       /* Più piccoli */
    border-radius: 6px;      
    text-decoration: none;
    color: #fff !important;
    font-weight: 500;
    font-size: 0.8rem;       /* Scritta compatta */
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    /* Nessun margin-bottom qui perché usiamo il gap del contenitore */
}
.btn-compact:hover { transform: translateY(-1px); box-shadow: 0 4px 8px rgba(0,0,0,0.15); }
.btn-compact i, .btn-compact svg { font-size: 0.9rem; }

/* Colori Brand */
.btn-compact.google { background-color: #DB4437; }
.btn-compact.tripadvisor { background-color: #00AA6C; }
.btn-compact.thefork { background-color: #5d8b3e; }

/* SEZIONE WHATSAPP */
.whatsapp-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
}

.whatsapp-label {
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-main);
    margin-bottom: 8px;
    opacity: 0.9;
}

.btn-whatsapp-clean {
    background-color: #25D366;
    color: white !important;
    text-decoration: none;
    padding: 10px 30px;
    border-radius: 50px;
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 4px 10px rgba(37, 211, 102, 0.3);
    transition: all 0.3s ease;
}
.btn-whatsapp-clean:hover { transform: scale(1.05); box-shadow: 0 6px 15px rgba(37, 211, 102, 0.5); }

/* ICONE SOCIAL */
.social-icon-btn {
    display: flex !important; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 50%;
    color: #fff !important; font-size: 1.1rem; text-decoration: none; 
    box-shadow: 0 3px 6px rgba(0,0,0,0.1); padding: 0 !important;
}
.social-icon-btn svg { width: 18px; height: 18px; fill: currentColor; }
.social-icon-btn:hover { transform: translateY(-3px); }

.social-icon-btn.facebook { background-color: #1877F2; }
.social-icon-btn.instagram { background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); }
.social-icon-btn.tiktok { background-color: #000000; } 
.social-icon-btn.whatsapp { background-color: #25D366; }

/* FIX Z-INDEX GTRANSLATE */
#goog-gt-tt, .gt_float_switcher, .gt_switcher { z-index: 9999999 !important; }