/* 
Theme Name: Gini
Description: Custom theme for Wow
Author: Luca Bruschi
Author URI: https://www.tab.it/
Template: hello-elementor
Version: 1.0.1
Text Domain: gini-child-theme
*/

/*-----------------------------------------------------------------------------------------------*/
/*-------------------------------------- VARIABILI GLOBALI --------------------------------------*/

:root {

}

/*-----------------------------------------------------------------------------------------------*/

body{font-family:'Archivo', serif !important;}

.site-header, .site-footer {
	display:none !important;
}

h1.woocommerce-products-header__title.page-title, .product {
    margin-top: 50px;
}
.page-header {
  margin-top: 100px;
}

.my-custom-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999; /* Lo tiene sopra ogni altro elemento */
    transition: all 0.3s ease; /* Effetto fluido per eventuali cambi di stile */
}

.my-custom-footer {
    width: 100%;
    clear: both;
}

/* Se vuoi che il footer stia sempre in fondo anche in pagine corte */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

#site-footer {
    margin-top: auto;
}

/* ----------------------- POPUP INZIO ----------------------------- */
#age-gate-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.98) !important;
    z-index: 999999 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 20px;
    font-family: sans-serif;
    transition: opacity 0.5s ease; /* Effetto dissolvenza */
}
.age-gate-content {
    background: #ffffff;
    padding: 40px;
    max-width: 500px;
    width: 100%;
    border-radius: 12px;
    text-align: center;
    box-shadow: 0 20px 40px rgba(0,0,0,0.6);
}
.age-gate-content h2 { color: #333; margin-top: 0; font-size: 24px; }
.age-gate-content p { color: #555; line-height: 1.6; margin: 15px 0; }
.age-gate-buttons { display: flex; flex-direction: column; gap: 12px; margin-top: 25px; }
.age-btn {
    background: #8b0000;
    color: #fff !important;
    padding: 16px;
    text-decoration: none;
    border-radius: 8px;
    font-weight: bold;
    border: none;
    cursor: pointer;
    font-size: 16px;
    transition: transform 0.2s;
}
.age-btn:active { transform: scale(0.98); }

/* Classe per nascondere forzatamente il popup ed eliminare l'ingombro */
#age-gate-overlay.hidden {
    opacity: 0 !important;
    visibility: hidden !important;
    display: none !important;
    pointer-events: none !important;
}
/* ----------------------- POPUP FINE ----------------------------- */


/* ----------------------- MENU INIZIO ----------------------------- */
nav.menu-principale-container {
    width: 1000px;
}
/* Allinea le voci in orizzontale */
.elementor-widget-wp-widget-nav_menu ul.menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 40px;
    font-family: 'Playfair Display';
    font-style:italic;
}

/* Stile voci principali */
.elementor-widget-wp-widget-nav_menu ul.menu > li > a {
    text-decoration: none;
    color: #fff;
    font-weight: 600;
    padding: 10px 0;
    display: block;
}

/* Gestione Sottomenu (2° Livello) */
.elementor-widget-wp-widget-nav_menu ul.menu li {
    position: relative;
}

.elementor-widget-wp-widget-nav_menu ul.menu ul.sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    background: #ffffff;
    min-width: 180px;
    box-shadow: 0 8px 15px rgba(0,0,0,0.1);
    display: none; /* Nascondi inizialmente */
    flex-direction: column;
    padding: 10px 0;
    z-index: 999;
}

/* Mostra sottomenu al passaggio del mouse */
.elementor-widget-wp-widget-nav_menu ul.menu li:hover > ul.sub-menu {
    display: flex;
}

/* Stile voci sottomenu */
.elementor-widget-wp-widget-nav_menu ul.sub-menu li a {
    padding: 8px 20px;
    font-size: 14px;
    color: #666;
    display: block;
    text-decoration: none;
    width:200px;
}

.elementor-widget-wp-widget-nav_menu ul.sub-menu li a:hover {
    background: #f8f8f8;
    color: #8b0000; /* Colore vino */
}

/* Rimuove i bullet e resetta i margini del sottomenu */
.elementor-widget-wp-widget-nav_menu ul.sub-menu {
    list-style: none !important; /* Rimuove i punti elenco */
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Assicuriamoci che anche i singoli elementi della lista non abbiano decorazioni */
.elementor-widget-wp-widget-nav_menu ul.sub-menu li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Forza la rimozione di eventuali icone/punti generati dal tema tramite pseudo-elementi */
.elementor-widget-wp-widget-nav_menu ul.sub-menu li::before,
.elementor-widget-wp-widget-nav_menu ul.sub-menu li::after {
    content: none !important;
}
/* ----------------------- MENU FINE ----------------------------- */





/* ----------------------- INIZIO GRIGLIA PRODOTTI ----------------------------- */

.vini-grid {
    display: grid !important;
    /* Griglia fissa a 3 colonne su desktop */
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 40px !important;
    padding: 40px 0 !important;
    max-width: 1200px;
    margin: 0 auto;
}

/* La singola Card */
.vino-card {
    text-decoration: none !important;
    color: #333 !important;
    transition: transform 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
}

.vino-card:hover {
    transform: translateY(-10px) !important;
}

/* Immagine: Visualizzazione integrale senza ritagli */
.vino-image {
    width: 100% !important;
    /* Proporzione verticale ideale per bottiglie/box */
    aspect-ratio: 1 / 1 !important; 
    /* CONTAIN: fa vedere tutta l'immagine originale senza tagliarla */
    background-size: contain !important; 
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: #ffffff !important;
    position: relative !important;
    
    /* Design cornice arrotondata */
    border-radius: 20px !important;
    overflow: hidden !important; 
}

/* Effetto al passaggio del mouse: il bordo diventa bordeaux */
.vino-card:hover .vino-image {
    box-shadow: 
        inset 0 0 0 15px #ffffff, 
        inset 0 0 0 16px #8b0000 !important;
}

/* Effetto Overlay al passaggio del mouse */
.vino-overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(139, 0, 0, 0.7); /* Rosso Vino */
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease !important;
    z-index: 2;
}

.vino-card:hover .vino-overlay {
    opacity: 1 !important;
}

.vino-overlay span {
    color: #fff !important;
    border: 1px solid #fff !important;
    padding: 10px 20px !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    letter-spacing: 2px !important;
}

/* Info Prodotto */
.vino-info {
    text-align: center !important;
    padding-top: 20px !important;
}

.vino-info h3 {
    font-family: 'Figtree', serif !important; /* Coerente con lo slider */
    font-weight: 400 !important;
    font-size: 1.1rem !important;
    color: #222 !important;
    margin: 0 !important;
    min-height: 2.5em; /* Allinea i titoli */
}

.vino-line {
    width: 30px !important;
    height: 2px !important;
    background: #8b0000 !important;
    margin: 12px auto !important;
    transition: width 0.3s ease !important;
}

.vino-card:hover .vino-line {
    width: 60px !important;
}

/* ----------------------- RESPONSIVE ----------------------------- */

/* Tablet: 2 colonne */
@media (max-width: 1023px) {
    .vini-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 25px !important;
    }
}

/* Mobile: 1 colonna (per dare importanza alle immagini) o 2 colonne se preferisci */
@media (max-width: 600px) {
    .vini-grid {
        grid-template-columns: 1fr !important; /* Forza una colonna su smartphone */
        padding: 20px !important;
    }
    
    .vino-image {
        aspect-ratio: 1 / 1 !important; /* Più quadrato su mobile */
    }
}
/* ----------------------- FINE GRIGLIA PRODOTTI ----------------------------- */

/* ----------------------- PAGINA PRODOTTO ----------------------------- */
button.single_add_to_cart_button.button.alt, button.single_add_to_cart_button.button.alt.disabled.wc-variation-selection-needed {
  background:#fff;
  border:1px solid #000;
  color:#000;
  height: 41px;
}
button.single_add_to_cart_button.button.alt:hover {
  background:#000;
  border:1px solid #000;
  color:#fff;
}
span.woocommerce-Price-amount.amount {
  font-size:30px;
  font-weight:300;
  color:#cc3366;
}
.posted_in {
  display:none;
}
section.related.products {
  border-top: 2px solid #cc3366;
  top: 40px;
  position: relative;
  padding: 10px;
}

/* ----------------------------- GRIGLIA PRODOTTI -------------------------------------

/* 1. RESET E GRIGLIA PRINCIPALE */
.vini-grid.featured-layout {
    display: grid !important;
    /* Forza 3 colonne esatte. 1fr significa "una parte uguale del totale" */
    grid-template-columns: repeat(3, 1fr) !important; 
    gap: 25px !important;
    margin: 40px auto !important;
    max-width: 1200px !important;
    padding: 0 15px !important;
    /* Rimuove eventuali comportamenti float del tema */
    float: none !important;
    clear: both !important;
}

/* 2. RESET SPECIFICO PER IL PRODOTTO FEATURED */
/* Questo annulla l'effetto "grande" del primo prodotto */
.vini-grid.featured-layout .vino-card.is-featured {
    grid-column: span 1 !important; /* Forza a occupare solo 1 colonna su 3 */
    grid-row: span 1 !important;
    width: 100% !important;
    display: flex !important;
}

/* 3. STILE DELLE CARD (Standard per tutte) */
.vino-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    text-decoration: none !important;
    background: #fff !important;
    border: 1px solid #f0f0f0 !important;
    transition: all 0.3s ease !important;
    height: 100% !important;
}

.vino-card:hover {
    box-shadow: 0 10px 25px rgba(0,0,0,0.1) !important;
    transform: translateY(-5px) !important;
}

 

/* 5. INFO TESTUALI */
.vino-info {
    padding: 15px !important;
    text-align: center !important;
    flex-grow: 1 !important;
}

.vino-info h3 {
    font-family: 'Figtree', serif !important;
    font-size: 18px !important;
    color: #222 !important;
    margin: 10px 0 !important;
    line-height: 1.2 !important;
    min-height: 2.4em !important; /* Allinea i titoli su 2 righe */
}

.vino-line {
    width: 30px !important;
    height: 2px !important;
    background-color: #bc9b6a !important;
    margin: 10px auto 0 !important;
}

/* 6. RESPONSIVE (CRUCIALE) */

/* Tablet: scendiamo a 2 colonne se lo spazio si stringe */
@media (max-width: 1024px) {
    .vini-grid.featured-layout {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* Mobile: manteniamo 2 colonne o 1 a seconda della preferenza */
@media (max-width: 767px) {
    .vini-grid.featured-layout {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
    }
    
    .vino-info h3 {
        font-size: 15px !important;
    }
}

/* Mobile Small: 1 colonna */
@media (max-width: 480px) {
    .vini-grid.featured-layout {
        grid-template-columns: 1fr !important;
    }
}


/* ------------------------- SLIDE ------------------------- */
/* ------------------------- SLIDE ------------------------- */

.custom-slider {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    background-color: #1a1a1a;
}

.my-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center center;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 1.5s ease-in-out;
    z-index: 1;
}

.my-slide.active {
    opacity: 1;
    z-index: 2;
}

.slide-content {
    display: flex;
    width: 85%;
    max-width: 1300px;
    align-items: center; /* Allineamento verticale come nell'immagine */
    justify-content: center;
    gap: 60px;
    z-index: 10;
}

.col-logo {
    flex: 0 0 auto;
    text-align: right;
}

.col-logo img {
    max-width: 120px !important; /* Dimensione del logo proporzionata */
    height: auto;
    filter: drop-shadow(2px 2px 10px rgba(0,0,0,0.3));
    margin-top:-30px;
}

.col-text {
    flex: 1;
    text-align: left;
}


/* IL CUORE DEL DESIGN: IL FONT */
.col-text h1 {
    color: #ffffff !important;
    font-family: 'EB Garamond', serif; /* Font Serif elegante */
    font-size: clamp(2.3rem, 5vw, 5rem); 
    font-weight: 400; /* Non troppo grassetto, per eleganza */
    line-height: 1.05; /* Interlinea stretta come nell'immagine */
    letter-spacing: -0.02em; /* Lettere leggermente più vicine */
    margin: 0;
    /* Ombreggiatura diffusa per leggibilità */
    text-shadow: 4px 4px 15px rgba(0, 0, 0, 0.7), 1px 1px 2px rgba(0, 0, 0, 0.9);
}

/* Navigazione discreta */
.prev, .next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
    
    /* Reset totale sfondi e bordi */
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    outline: none !important; /* Rimuove il bordo blu/nero al clic */
    box-shadow: none !important;
    
    color: rgba(255, 255, 255, 0.7);
    padding: 20px;
    cursor: pointer;
    font-size: 50px;
    transition: all 0.3s ease;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.8);
    
    /* Impedisce l'evidenziazione del testo e lo sfondo blu su mobile */
    user-select: none;
    -webkit-tap-highlight-color: transparent; 
}

.prev:hover, .next:hover, 
.prev:focus, .next:focus, 
.prev:active, .next:active { 
    background: none !important;
    background-color: transparent !important;
    color: #ffffff;
    outline: none !important;
}

.prev { left: 10px; }
.next { right: 10px; }

/* Mobile */
@media (max-width: 768px) {
    .slide-content { 
        flex-direction: column; 
        gap: 20px; 
        text-align: center;
        width: 80%; /* Stringiamo il contenuto per lasciare spazio alle frecce */
    }
    
    .col-logo { text-align: center; }
    .col-logo img { max-width: 130px; }
    
    .col-text { text-align: center; }
    .col-text h1 { 
        font-size: 2.2rem; /* Leggermente più piccolo per non toccare i bordi */
        line-height: 1.1;
    }

    /* Spostiamo le frecce ai bordi estremi su mobile */
    .prev, .next {
        font-size: 35px;
        padding: 10px;
    }
    .prev { left: 5px; }
    .next { right: 5px; }
}


/*-----------------------------------------------------------------------------------------------*/
/*------------------------------------------ WOOCOMMERCE --------------------------------------------*/
header.woocommerce-products-header,h1.entry-title {
    font-family: 'EB Garamond', serif;
}

p.woocommerce-result-count, h2.woocommerce-loop-product__title, select.orderby, span.woocommerce-Price-amount.amount, 
a.button.product_type_variable.add_to_cart_button, a.button.product_type_simple.add_to_cart_button.ajax_add_to_cart,
.cc-window-wrapper,.wp-block-woocommerce-checkout.alignwide.wc-block-checkout,.woocommerce {
  font-family: 'Figtree', serif;
}


/*-----------------------------------------------------------------------------------------------*/
/*------------------------------------------ DESKTOP --------------------------------------------*/
/*-----------------------------------------------------------------------------------------------*/

@media only screen and (min-width: 1024px) {

}	


/*-----------------------------------------------------------------------------------------------*/
/*-------------------------------------- TABLET VERTICALE ---------------------------------------*/
/*-----------------------------------------------------------------------------------------------*/

@media only screen and (min-width: 768px) and (max-width: 1023px) {  

}

/*-----------------------------------------------------------------------------------------------*/
/*-------------------------------------- MOBILE VERTICALE ---------------------------------------*/
/*-----------------------------------------------------------------------------------------------*/

@media (max-width: 767px) {
  ul#menu-principale-1 {
      color: #fff;
  }
  .menu-item a {
      color: #fff;
      font-size:20px;
  }
  li.menu-item {
      padding-bottom: 10px;
  }
  
}