/* ============================================================
   FA Globe 3D — Mobile Styles (max-width: 480px)
   Telefono: solo visualizzazione, no admin, globo centrato
   ============================================================ */

/* ============================================================
   FA Globe 3D — Layout intermedio tablet/finestra ristretta
   481px - 640px: layout a colonna senza perdere la toolbar
   ============================================================ */
@media (min-width: 481px) and (max-width: 640px) {

    .fa-globe-section {
        padding: 12px 12px 160px !important;
        overflow: visible !important;
    }

    /* Stack verticale */
    .fa-globe-main {
        flex-direction: column !important;
        align-items: center !important;
    }

    /* Globo adattivo */
    .fa-globe-wrapper {
        width: min(420px, 90vw) !important;
        height: min(420px, 90vw) !important;
        margin: 0 auto !important;
    }

    .fa-globe-container {
        width: min(420px, 90vw) !important;
        height: min(420px, 90vw) !important;
        overflow: hidden !important;
    }

    /* Bottom in colonna */
    .fa-globe-bottom {
        flex-direction: column !important;
        width: 100% !important;
        margin-left: 0 !important;
        max-width: 500px !important;
        margin: 0 auto !important;
    }

    /* Pannello pieno */
    #contactsPanel, .fa-contacts-panel {
        margin-top: 12px !important;
        padding: 12px 16px 16px !important;
        position: relative !important;
        z-index: 1 !important;
        border: none !important;
        box-shadow: none !important;
    }

    /* Divider centrato nel layout colonna */
    #timeDivider, .fa-globe-divider {
        position: relative !important;
        z-index: 10 !important;
        height: 48px !important;
        min-height: 48px !important;
        max-height: 48px !important;
        width: 100% !important;
        min-width: 100% !important;
        align-items: center !important;
    }

    /* Clock layout in colonna — stesso di ≤480px */
    .fa-time-indicator,
    #timeIndicator {
        position: absolute !important;
        bottom: -4px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 6px !important;
        width: auto !important;
        flex: unset !important;
    }

    .fa-time-clock, #timeClock {
        font-size: 0.82rem !important;
        white-space: nowrap !important;
        order: -1 !important;
    }

    .fa-time-dot {
        width: 8px !important;
        height: 8px !important;
        border-radius: 50% !important;
        background: #2dd4bf !important;
        flex-shrink: 0 !important;
        display: block !important;
        order: 1 !important;
        position: relative !important;
        transform: none !important;
        box-shadow: 0 0 0 5px #0a0a0f !important;
        z-index: 1 !important;
    }

    #dividerLineTop, .fa-divider-line-top {
        position: absolute !important;
        bottom: 4px !important;
        left: 50% !important;
        right: unset !important;
        width: 160px !important;
        transform: translateX(-50%) !important;
        height: 1px !important;
        top: unset !important;
        flex: unset !important;
        display: block !important;
    }

    #dividerLineBottom, .fa-divider-line-bottom {
        display: none !important;
    }

    /* Toolbar visibile */
    #footerWrapper {
        display: flex !important;
    }
}

@media (max-width: 480px) {

    /* ── Nascondi tutto l'admin ────────────────────────────── */
    #adminToolbar,
    .fa-admin-toolbar,
    .fa-admin-toolbar-btn,
    #footerToolbar,
    .fa-toolbar-center,
    #dataToggleFooter,
    #settingsToggleFooter,
    #infoToggleFooter,
    #dataPanel,
    #controlPanel,
    #featuresPanel,
    #footerWrapper,
    .fa-footer-wrapper,
    .fa-footer-toolbar {
        display: none !important;
    }

    /* ── Nascondi prev/next ─────────────────────────────────── */
    #prevBtn, #nextBtn, .fa-nav-btn {
        display: none !important;
    }

    /* ── Footer wrapper ─────────────────────────────────────── */
    #footerWrapper {
        justify-content: center !important;
        padding: 4px 0 !important;
        min-height: 0 !important;
    }

    /* ── Sezione principale ─────────────────────────────────── */
    .fa-globe-section {
        padding: 12px 12px 100px !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .fa-globe-section {
        height: auto !important;
        min-height: unset !important;
        overflow: visible !important;
    }

    /* ── Titolo: sinistra ───────────────────────────────────── */
    .fa-globe-title {
        font-size: 1.3rem !important;
        text-align: left !important;
    }

    .fa-globe-title-wrapper {
        text-align: left !important;
    }

    /* ── Typewriter: sinistra ───────────────────────────────── */
    .fa-globe-typewriter {
        text-align: left !important;
        font-size: 0.75rem !important;
    }

    /* ── Layout principale ──────────────────────────────────── */
    .fa-globe-main {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0 !important;
    }

    /* Globo: height gestita dal JS, overflow per clipping */
    .fa-globe-wrapper {
        align-self: center !important;
        margin: 0 auto !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    .fa-globe-container {
        max-width: 100% !important;
        overflow: hidden !important;
        position: relative !important;
    }

    /* ── Wrapper inferiore: divider + contatti in colonna ───── */
    .fa-globe-bottom {
        flex-direction: column !important;
        width: 100% !important;
        max-width: 100% !important;
        align-items: stretch !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
    }

    /* ── Divisore: contenitore relativo ───────────────── */
    .fa-globe-divider {
        position: relative !important;
        display: block !important;
        width: 100% !important;
        height: 48px !important;
        min-height: unset !important;
        min-width: unset !important;
        padding: 0 !important;
        gap: 0 !important;
        flex-direction: unset !important;
    }

    /* Linea: centrata verticalmente sul dot (sale di 4px = metà dot) */
    .fa-divider-line-top,
    #dividerLineTop {
        position: absolute !important;
        bottom: 4px !important;
        left: 50% !important;
        right: unset !important;
        width: 160px !important;
        transform: translateX(-50%) !important;
        height: 1px !important;
        top: unset !important;
        flex: unset !important;
        display: block !important;
    }

    /* ── Seconda linea: nascosta ──────────────────────── */
    .fa-divider-line-bottom,
    #dividerLineBottom {
        display: none !important;
    }

    /* ── Time indicator: centrato sopra la linea ──────── */
    .fa-time-indicator,
    #timeIndicator {
        position: absolute !important;
        bottom: -4px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 6px !important;
        width: auto !important;
        flex: unset !important;
    }

    /* ── Clock: sopra ─────────────────────────────────── */
    .fa-time-clock,
    #timeClock {
        font-size: 0.82rem !important;
        white-space: nowrap !important;
        order: -1 !important;
    }

    /* Dot: spazio visivo con box-shadow che simula un halo scuro */
    .fa-time-dot {
        width: 8px !important;
        height: 8px !important;
        border-radius: 50% !important;
        background: #2dd4bf !important;
        flex-shrink: 0 !important;
        display: block !important;
        order: 1 !important;
        position: relative !important;
        transform: none !important;
        box-shadow: 0 0 0 5px #0a0a0f !important;
        z-index: 1 !important;
    }

    /* ── .fa-divider-dot: nascosto (gestito da .fa-time-dot) */
    .fa-divider-dot {
        display: none !important;
    }

    /* ── Pannello contatti: piena larghezza, altezza auto ───── */
    .fa-contacts-panel {
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        min-height: unset !important;
        max-height: none !important;
        flex: none !important;
        overflow: visible !important;
        text-align: left !important;
        padding: 10px 16px !important;
        box-sizing: border-box !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-top: 20px !important;
        border: none !important;
        box-shadow: none !important;
    }

    /* ── Contenuto pannello: sinistra ───────────────────────── */
    .fa-contacts-header {
        justify-content: flex-start !important;
        text-align: left !important;
    }

    .fa-contacts-name,
    .fa-contacts-location,
    .fa-contacts-description {
        text-align: left !important;
        width: 100% !important;
    }

    .fa-contacts-info,
    .fa-contacts-email,
    .fa-contacts-website {
        justify-content: flex-start !important;
        text-align: left !important;
    }

    .fa-contacts-region {
        flex-shrink: 0 !important;
    }

    /* ── Fix pannello contatti ─────────────────────────────── */

    /* 1. Più respiro sotto la descrizione */
    .fa-contacts-panel {
        padding-bottom: 24px !important;
    }

    /* 2. Icone email e website allineate — larghezza fissa uguale */
    .fa-contacts-email .fa-contacts-icon,
    .fa-contacts-website .fa-contacts-icon {
        min-width: 22px !important;
        width: 22px !important;
        display: inline-flex !important;
        justify-content: center !important;
        align-items: center !important;
        flex-shrink: 0 !important;
    }

    /* 3. Spazio tra email e website */
    .fa-contacts-info {
        gap: 6px !important;
        flex-direction: column !important;
    }

    /* Divider sempre sopra il pannello (anche durante animazione) */
    #timeDivider,
    .fa-globe-divider {
        position: relative !important;
        z-index: 10 !important;
    }

    /* Pannello sotto il divider */
    #contactsPanel,
    .fa-contacts-panel {
        position: relative !important;
        z-index: 1 !important;
    }

    /* Footer wrapper (linea DATA/SETTINGS/INFO): nascosto su mobile */
    #footerWrapper {
        display: none !important;
    }
}

/* ============================================================
   FA Globe 3D — Landscape su telefono (altezza ≤ 500px)
   ============================================================ */
@media (max-height: 500px) and (min-aspect-ratio: 13/9) {

    /* Nascondi admin */
    #footerToolbar, .fa-admin-toolbar,
    #footerWrapper,
    #prevBtn, #nextBtn,
    #dataPanel, #controlPanel, #featuresPanel { display: none !important; }

    /* Sezione compatta */
    .fa-globe-section {
        padding: 6px 12px 12px !important;
        max-width: 100% !important;
    }

    /* Titolo e typewriter compatti */
    .fa-globe-title { font-size: 1rem !important; text-align: left !important; }
    .fa-globe-typewriter { font-size: 0.7rem !important; text-align: left !important; }

    /* Layout due colonne: globo sx, contatti dx */
    .fa-globe-main {
        flex-direction: row !important;
        align-items: center !important;
        gap: 16px !important;
    }

    /* Globo: colonna sinistra fissa */
    .fa-globe-wrapper {
        width: 260px !important;
        height: 260px !important;
        flex-shrink: 0 !important;
        margin: 0 !important;
        overflow: hidden !important;
    }

    .fa-globe-container {
        width: 260px !important;
        height: 260px !important;
        overflow: hidden !important;
        position: relative !important;
    }

    /* Colonna destra: divider + pannello */
    .fa-globe-bottom {
        flex: 1 !important;
        flex-direction: column !important;
        margin-left: 0 !important;
        width: auto !important;
        max-width: none !important;
    }

    /* Divider compatto */
    #timeDivider, .fa-globe-divider {
        position: relative !important;
        z-index: 10 !important;
        height: 40px !important;
    }

    /* Pannello contatti compatto */
    #contactsPanel, .fa-contacts-panel {
        margin-top: 8px !important;
        padding: 6px 10px 10px !important;
        position: relative !important;
        z-index: 1 !important;
        border: none !important;
        box-shadow: none !important;
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }

    .fa-contacts-name { font-size: 0.9rem !important; }
    .fa-contacts-location { font-size: 0.72rem !important; }
    .fa-contacts-email a,
    .fa-contacts-website a { font-size: 0.72rem !important; }
    .fa-contacts-description { font-size: 0.7rem !important; }
}

/* ── Range 481–500px (phablet stretto) ──────────────────── */
@media (min-width: 701px) and (max-width: 750px) {
    .fa-globe-section {
        padding: 16px !important;
        max-width: 100% !important;
    }
    .fa-globe-wrapper {
        width: 420px !important;
        height: 420px !important;
    }
    .fa-globe-container {
        height: 420px !important;
        min-height: 420px !important;
    }
    #dataPanel, .fa-data-panel {
        width: 240px !important;
        max-width: 240px !important;
    }
    #controlPanel, .fa-control-panel {
        width: 240px !important;
        max-width: 240px !important;
    }
}
