/* =========================================
   RESOLVE MEDIA AGENCY - Stylesheet
   ========================================= */

/* IMPORT FONT LEMON MILK
 * Se possiedi il file webfont, de-commenta e aggiorna l'URL qui sotto.
 * Al momento utilizzerà il font locale se installato, o un fallback robusto.
 */
@font-face {
    font-family: 'LEMON MILK';
    src: url('/LEMON MILK.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'LEMON MILK';
    src: url('/LEMON MILK Bold.woff2') format('woff2');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

body {
    background-color: #FFFFFF;
    overflow-x: hidden;
    scroll-behavior: smooth;
}

/* LEMON MILK — sempre bold */
.font-lemon {
    font-weight: bold;
}

/* Effetto Glassmorphism Smussato */
.glass-panel {
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 12px 40px 0 rgba(131, 130, 135, 0.15);
    border-radius: 2rem;
}

/* Header Glass Specifico */
.glass-header {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.6);
}

/* Nuovo riquadro per l'Hero (Apple Style) */
.hero-glass {
    background: rgba(255, 255, 255, 0.25);
    backdrop-filter: blur(35px);
    -webkit-backdrop-filter: blur(35px);
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow: 0 30px 60px 0 rgba(0, 0, 0, 0.15);
    border-radius: 3rem;
}

/* Liquify Canvas */
#hero-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 1;
}

/* Animazioni di Scorrimento (Fade in) */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s cubic-bezier(0.5, 0, 0, 1);
}
.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* Personalizzazione Testo Evidenziato */
.text-gradient {
    background: linear-gradient(135deg, #BC214E, #838287);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Pulsante interattivo */
.btn-magenta {
    background-color: #BC214E;
    color: white;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.btn-magenta::before {
    content: '';
    position: absolute;
    top: 0; left: -100%; width: 100%; height: 100%;
    background: rgba(255,255,255,0.2);
    transition: all 0.4s ease;
    z-index: -1;
}
.btn-magenta:hover::before {
    left: 0;
}
.btn-magenta:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 25px rgba(188, 33, 78, 0.4);
}

/* Bolle dei Partner (Matter.js Wrapper) */
#bubbles-wrapper {
    overflow: hidden;
    cursor: grab;
}
#bubbles-wrapper:active {
    cursor: grabbing;
}
.bubble-logo {
    position: absolute;
    border-radius: 50%;
    background: #FFFFFF;
    box-shadow: 0 8px 25px rgba(131, 130, 135, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    transform-origin: center center;
    will-change: transform;
    border: 1px solid rgba(188, 33, 78, 0.1);
}
.bubble-logo img {
    width: 70%;
    height: 70%;
    object-fit: contain;
}

/* Swiper Fixes */
.swiper-slide {
    display: flex;
    justify-content: center;
}
.swiper-pagination-bullet-active {
    background-color: #BC214E !important;
}

/* Testimonianze Swiper */
.testimonianzaSwiper {
    padding: 0 6vw !important;
}
.testimonianzaSwiper .swiper-slide {
    height: auto;
    align-items: stretch;
}
.testi-card {
    min-height: 320px;
    transition: box-shadow 0.3s ease;
}
.testi-card:hover {
    box-shadow: 0 12px 40px rgba(188,33,78,0.10);
}

/* Hero: sfondo immagine su mobile (al posto dell'animazione Three.js) */
@media (max-width: 767px) {
    #hero {
        background-image: url('/images/sfondosezione.webp');
        background-size: cover;
        background-position: center center;
        background-repeat: no-repeat;
    }
}

/* Mobile: padding orizzontale uniforme per tutte le sezioni */
@media (max-width: 767px) {
    /* Normalizza il padding dei contenitori interni nelle sezioni */
    section .max-w-7xl,
    section .max-w-4xl,
    section .max-w-3xl,
    section .max-w-2xl,
    section .max-w-xl {
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }
    /* I testi editoriali dell'intro section */
    #agenzia .w-full {
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }
    /* Sezione problemi comuni */
    #problemi > div {
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }
}

/* Mobile: allineamento a sinistra per intestazioni e testi */
@media (max-width: 767px) {
    section:not(#hero) h2,
    section:not(#hero) h3,
    section:not(#hero) p {
        text-align: left;
    }
    section:not(#hero) .text-center {
        text-align: left;
    }
    .faq-wrapper,
    .faq-wrapper.max-w-3xl {
        padding-left: 0rem !important;
        padding-right: 0rem !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    #servizi .max-w-7xl,
    #servizi .max-w-4xl,
    #servizi .max-w-3xl,
    #servizi .max-w-2xl,
    #servizi .max-w-xl {
        padding-left: 0rem !important;
        padding-right: 0rem !important;
    }
    #servizi .p-10 {
        padding: 1.5rem !important;
    }
    #risultati .py-10 {
        padding-top: 0rem !important;
        padding-bottom: 0rem !important;
    }
    #risultati .max-w-7xl {
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }
    #contatti .flex.flex-col.sm\:flex-row {
        align-items: flex-start !important;
    }
    footer .flex.flex-col {
        align-items: flex-start !important;
        text-align: left !important;
    }
    footer .flex.gap-4 {
        justify-content: flex-start !important;
    }
    .px-5 {
        padding-left: 0rem !important;
        padding-right: 0rem !important;
    }
    .mb-16 {
        margin-bottom: 2rem !important;
    }
}

/* Mobile: padding orizzontale uniforme px-6 (24px) */
@media (max-width: 767px) {
    .mobile-px {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }
}
