/*
Theme Name: Anna Rigoni
Description: Child theme di Twenty Twenty-Five per il blog di RIBASSI.TOP
Template: twentytwentyfive
Version: 1.0.0
*/

/* ========================================
   VARIABILI CSS PER RIBASSI.TOP
   ======================================== */
:root {

 /* Nuovi colori da aggiungere */
/* --color-gold: #d0b572;          Oro Antico */
--color-gold: #d3c09d;          /* Oro Antico */
--color-gold-light: #f8f5f1;       /* Oro Antico Chiaro */
--color-bronze: #d1b876;        /* Bronzo caldo */
--color-white: #ffffff;         /* Bianco */
--color-black: #000000;         /* Nero */
--color-dark-grey: #333333;     /* Grigio Scuro */
--color-light-grey: #f4f4f4;     /* Grigio Scuro */

/* Font Variables */
--font-old-standard: 'Old Standard TT', Georgia, serif;
--font-inter: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;


}

/* Font Family Classes */
.font-old-standard { font-family: var(--font-old-standard); }
.font-inter { font-family: var(--font-inter); }

/* Font Color Classes */
.text-gold { color: var(--color-gold); }
.text-white { color: var(--color-white);}
.text-black { color: var(--color-black);}
.text-dark-grey { color: var(--color-dark-grey);}





body {
  color: var(--color-black);
  font-weight: var(--font-light);
  font-size: var(--text-lg);
  color: var(--color-dark-grey);
}

h1, h2, h3, h4 {
  font-weight: var(--font-normal);
  font-family: var(--font-old-standard);
  color: var(--color-black);
  font-style:italic;
}

h1 {
  font-size: var(--text-5xl);
}
h2 {
  font-size: var(--text-4xl);
}
h3 {
  font-size: var(--text-3xl);
}
h4 {
  font-size: var(--text-2xl);
}


/* Mobile responsive */
@media (max-width: 768px) {
    h1 {
      font-size: var(--text-4xl);
    }
    h2 {
      font-size: var(--text-3xl);
    }
    h3 {
      font-size: var(--text-2xl);
    }
    h4 {
      font-size: var(--text-xl);
    }
}


a:link{
  text-decoration: underline;
  color: var(--color-black);
}

a:hover{
  text-decoration: underline;
  color: var(--color-dark-grey);
}

.hidden {
  display: none; 
}


/* Button Components */

.wp-block-button,
.wp-block-button.btn {
  position: relative;
  display: inline-block;
}


a:focus,
a:focus-visible,
button:focus,
.btn-nowp:focus,
.btn-nowp:focus-visible,
.wp-block-button .wp-block-button__link:focus,
.wp-block-button.btn .wp-block-button__link:focus,
.wp-block-button .wp-block-button__link:focus-visible,
.wp-block-button.btn .wp-block-button__link:focus-visible {
  outline: none;
}

.btn-nowp,
.wp-block-button .wp-block-button__link,
.wp-block-button.btn .wp-block-button__link  {
  position: relative;
  text-align: center;
  font-weight: 400;
  font-style: italic;
  font-family: var(--font-inter);
  font-size: var(--text-base);
  padding: 0.45rem 1.5rem;
  border-radius: 5px;
  cursor: pointer;
  text-decoration: none !important;
  background-color: var(--color-black) !important;
  color: var(--color-white) !important;
}

.btn-nowp:hover,
.wp-block-button .wp-block-button__link:hover 
.wp-block-button.btn .wp-block-button__link:hover {
  text-align: center;
  text-decoration: none !important;
  background-color: var(--color-dark-grey) !important;
}

.btn-nowp:active,
.wp-block-button .wp-block-button__link:active
.wp-block-button.btn .wp-block-button__link:active {
  text-align: center;
}

/* Button Gold */

.btn-gold-nowp,
.wp-block-button.btn-gold .wp-block-button__link {
    background-color: var(--color-gold) !important;
    color: var(--color-black) !important;
}

.btn-gold-nowp:hover,
.wp-block-button.btn-gold .wp-block-button__link:hover {
    background-color: var(--color-bronze) !important;
}

.btn-gold-nowp:active,
.wp-block-button.btn-gold .wp-block-button__link:active {
    box-shadow: none !important;
}


/* Button Black */

.btn-black-nowp,
.wp-block-button.btn-black .wp-block-button__link {
    background-color: var(--color-black) !important;
    color: var(--color-white) !important;
}

.btn-black-nowp:hover,
.wp-block-button.btn-black .wp-block-button__link:hover {
    background-color: var(--color-dark-grey) !important;
}

.btn-black-nowp:active,
.wp-block-button.btn-black .wp-block-button__link:active {
    box-shadow: none;
}



/* Container Personalizzato */
.rt-max-w-1140 {
  max-width: 1440px;
  margin: 0 auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 640px) {
  .rt-max-w-1140 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .rt-max-w-1140 {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}




/* Applica ai container principali del tema */
.wp-block-group {
  max-width: 1440px;
  margin: 0 auto;
}


/* Background Body */
body {
  background-color: var(--color-white);
  font-family: var(--font-inter);
}


/* Header Top Bar */

header.wp-block-template-part {
  border-bottom: 1px solid var(--color-border);
  background-color: var(--color-cream) !important;
}


/* Header Sticky
.site-header,
.wp-block-template-part[class*="header"],
header {
  position: sticky;
  top: 0;
  z-index: 999;
}
*/

/* Footer */
footer.wp-block-template-part {
  background-color: var(--color-white) !important;
}





.footer-link a{
  font-size: var(--text-sm);
  color:  var(--color-black);
  transition: color 0.2s ease-in-out;
}

.footer-link a:hover {
  text-decoration: underline;
}

/* ========================================
    BLOCK QUOTE
   ======================================== */

:root :where(.wp-block-quote) {
  border-color: var(--color-bronze) !important;
  padding-left: 0 !important;
}

/* ========================================
    MENU
   ======================================== */


header.wp-block-template-part > .wp-block-group > .wp-block-group {
    padding-top: 40px;
}


/* Menu Links - Generale */
header .wp-block-navigation a,
header .wp-block-navigation-item a,
header .wp-block-navigation-link a {
  color: var(--color-gold) !important;
  font-family: var(--font-inter) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-light) !important;
  text-shadow: 2px 2px 2px rgba(0, 0, 0, 1);
  text-decoration: none;
}


/* Menu Links Hover */
header .wp-block-navigation-item a:hover,
header .wp-block-navigation-link a:hover {
  color: var(--color-bronze) !important;
}




/* Menu Links - Home */
header .wp-block-navigation a,
header .wp-block-navigation-item a,
header .wp-block-navigation-link a {
  color: var(--color-white) !important;
}

header .wp-block-navigation-item:hover a,
header .wp-block-navigation-link:hover a {
  color: var(--color-gold) !important;
}


/* Menu Links - Event */
body.ar-single-event-page header .wp-block-navigation a,
body.ar-single-event-page header .wp-block-navigation-item a,
body.ar-single-event-page header .wp-block-navigation-link a {
  color: var(--color-black) !important;
  text-shadow: none;
}

body.ar-single-event-page header .wp-block-navigation-item:hover a,
body.ar-single-event-page header .wp-block-navigation-link:hover a {
  color: var(--color-dark-grey) !important;
}



header .wp-block-navigation-item {
    margin-right: 10px;
}




/* ========================================
  MOBILE MENU
   ======================================== */

.wp-block-navigation__responsive-container-open svg {
    fill: var(--color-gold);
    width: 28px;
    height: 28px;
}

body.ar-single-event-page .wp-block-navigation__responsive-container-open svg {
    fill: var(--color-black);
    width: 28px;
    height: 28px;
}

body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__responsive-container-open {
    display: none !important;
}

/* CONTENITORE PRINCIPALE (overlay + contenuto) */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__responsive-container {
    /* L'intero overlay del menu mobile */
    background-color: rgba(0, 0, 0, 0.8) !important;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 999 !important;
}


/* PULSANTE X DI CHIUSURA */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__responsive-container-close {
    /* Il pulsante X */
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 1000;
}

/* ICONA SVG DELLA X */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__responsive-container-close svg {
    width: 28px;
    height: 28px;
    fill: var(--color-gold);
}



body:has(.wp-block-navigation__responsive-container.is-menu-open) header .wp-block-navigation__container.is-responsive .wp-block-navigation-item {
    margin-right: 40px;
    margin-top: 10px;
}

body:has(.wp-block-navigation__responsive-container.is-menu-open) header .wp-block-navigation__container.is-responsive .wp-block-navigation-item:first-child {
    margin-top: 40px;
}


/* Link degli item */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__container.is-responsive .wp-block-navigation-item a {
    padding: 20px 25px;
    transition: all 0.3s ease;
    background: none;
}

/* Testo degli item */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__container.is-responsive .wp-block-navigation-item__label {
    font-family: var(--font-inter);
    font-size: var(--text-xl);
    font-weight: var(--font-light);
    color: var(--color-white);
}


/* Item corrente */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__container.is-responsive .current-menu-item .wp-block-navigation-item__label {
    font-weight: var(--font-light);
}



/* ========================================
   FOOTER STYLING
   ======================================== */

footer.wp-block-template-part {
    margin: 0;
    margin-bottom: 100px;
    position: relative;
}

footer.wp-block-template-part::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    width: 50vw;
    height: 1px;
    background-color: var(--color-gold);
}

footer.wp-block-template-part::before {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 50vw;
    height: 1px;
    background-color: var(--color-gold);
}

footer.wp-block-template-part > .wp-block-group > .wp-block-group {
    border-top: 1px solid var(--color-gold);
    border-bottom: 1px solid var(--color-gold);
    border-left: 1px solid var(--color-gold);
    padding: 20px 0;
}



/* Footer navigation items */
footer .wp-block-navigation-item {
    padding-right: 1.5rem;
    margin-right: 1.5rem;
}


/* Menu Links - Generale */
footer .wp-block-navigation a,
footer .wp-block-navigation-item a,
footer .wp-block-navigation-link a {
  color: var(--color-dark-grey) !important;
  font-family: var(--font-inter) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-light) !important;
  text-decoration: none;
}


/* Menu Links Hover */
footer .wp-block-navigation-item a:hover,
footer .wp-block-navigation-link a:hover {
  color: var(--color-black) !important;
}



/* Menu Item attivo/corrente */
footer .current-menu-item a {
  color: var(--color-dark-grey) !important;
}



/* ========================================
   ELEMENTI
   ======================================== */



.ar-line {
    position: absolute;
    width: 1px;
    height: calc(100% - 0px);
    top: 0px;
}

.ar-line.left {
    left: 0px;
}

.ar-line.right {
    right: 0px;
}


.ar-gold-line {
    background: var(--color-gold);
}
.ar-gold-line::before {
    content: '';
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 12px;
    height: 80px;
    background: var(--color-gold);
}

.ar-gold-line.left::before {
    left: 50%;
    transform: translateX(-50%);
}



.ar-white-line {
    background: var(--color-white);
}
.ar-white-line::before {
    content: '';
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 12px;
    height: 80px;
    background: var(--color-white);
}

.ar-white-line.right::before {
    right: 50%;
    transform: translateX(50%);
}



/* ========================================
   HEADER
   ======================================== */


.wp-block-group {
    position: relative;
}

.wp-block-group[style*="padding-top"] {
    padding-top: 0 !important;
}


.wp-block-group[style*="padding-bottom"] {
    padding-bottom: 0 !important;
}

.ar-single-event-page main.wp-block-group {
  margin-top: calc(-1 * var(--wp--preset--spacing--60) - 40px) !important;
}

/* Rimuovi margini/padding dai container parent specifici */
main {
  margin-top: 0 !important;
}


header {
  position: relative;
  z-index: 2;
}


.wp-block-site-title {
  font-family: var(--font-old-standard);
  font-size: var(--text-2xl);
  color: var(--color-white);
  font-weight: var(--font-light);
  font-style: italic;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}

.wp-block-site-title a:link {
  text-decoration: none;
  color: var(--color-white);
}

.wp-block-site-title a:hover {
  text-decoration: none;
  color: var(--color-white);
}

.home .wp-block-site-title {
  opacity: 0;
}

body.ar-single-event-page .wp-block-site-title {
  color: var(--color-black);
  text-shadow: none;
}

body.ar-single-event-page .wp-block-site-title a:hover {
  color: var(--color-black);
}



/* Mobile responsive */
@media (max-width: 768px) {
    .wp-block-site-title {
      font-size: var(--text-lg);
    }
}


/* ========================================
   HOME
   ======================================== */

/* Nasconde titolo homepage */

body.home h1.wp-block-post-title {
    display: none !important;
}



/* ========================================
   PAGES
   ======================================== */

/* HERO FEATURED IMAGE - PAGINE INTERNE */
.wp-block-post-featured-image {
    position: relative;
    width: 100vw !important;
    height: 31.25vw; /* Aspect ratio 16:5 (3.2:1) */
    max-height: 600px;
    min-height: 350px;
    overflow: hidden;
    
    /* Breakout dai container WordPress */
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: calc(-1 * var(--wp--preset--spacing--60) - 40px) !important;
    max-width: none !important;
}

.wp-block-post-featured-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 16/5;
}

/* TITOLO PAGINA SOPRA HERO IMAGE */
.wp-block-post-title {
    position: absolute;
    z-index: 1;
    color: var(--color-white);
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
    margin: 0 !important;
    left: var(--wp--style--root--padding-left);
    top: 150px;
    font-family: var(--font-old-standard);
    font-size: var(--text-5xl);
}

body.ar-single-event-page h1.wp-block-post-title {
    color: var(--color-black);
    text-shadow: none;
}

.wp-block-post-featured-image[style*="margin-bottom"] {
    margin-bottom: 0 !important;
}

.page .entry-content {
  margin-block-start: 0 !important;
}



/* Mobile responsive */
@media (max-width: 768px) {
    .wp-block-post-featured-image {
        height: 50vw; /* Più alto su mobile va bene */
        min-height: 250px;
        max-height: 380px;
    }

    .wp-block-post-title {
        top: 90px;
        font-size: var(--text-4xl);
    }
}


/* ========================================
   IMAGES GALLERY
   ======================================== */


.modula-images-grid {
    padding: 0 20px !important;
}