
        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }

        body {
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
            background-color: #f4f7f6;
            color: #333;
            display: flex;
            flex-direction: column;
            align-items: center;
            padding: 20px;
        }

        header {
            text-align: center;
            margin-bottom: 30px;
        }

        header h1 {
            color: #2c3e50;
            font-size: 2.5rem;
            margin-bottom: 10px;
        }

        header p {
            color: #7f8c8d;
            font-size: 1.1rem;
        }

        /* Contenedor principal del mapa */
        .mapa-contenedor {
            position: relative;
            max-width: 1000px; /* Ancho máximo del mapa */
            width: 100%;
            box-shadow: 0 10px 25px rgba(0,0,0,0.15);
            border-radius: 12px;
            overflow: hidden;
            background-color: #fff;
        }

        /* Imagen de fondo (el dibujo de los estudiantes) */
        .mapa-imagen {
            width: 100%;
            height: auto;
            display: block;
        }

        /* Estilo general para los puntos interactivos */
        .punto-interactivo {
            position: absolute;
            width: 24px;
            height: 24px;
            background-color: #e74c3c;
            border: 3px solid #fff;
            border-radius: 50%;
            cursor: pointer;
            box-shadow: 0 0 10px rgba(0,0,0,0.3);
            transition: transform 0.3s ease, background-color 0.3s ease;
            
            /* Animación de pulso para que se note que es interactivo */
            animation: pulso 2s infinite;
        }

        .punto-interactivo:hover {
            transform: scale(1.3);
            background-color: #2ecc71; /* Cambia a verde al pasar el mouse */
        }

        /* Cartelito con el nombre del lugar (Tooltip) */
        .punto-interactivo::after {
            content: attr(data-lugar);
            position: absolute;
            bottom: 35px;
            left: 50%;
            transform: translateX(-50%);
            background-color: rgba(44, 62, 80, 0.9);
            color: #fff;
            padding: 6px 12px;
            border-radius: 4px;
            font-size: 0.85rem;
            white-space: nowrap;
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.3s ease;
            pointer-events: none;
            box-shadow: 0 4px 6px rgba(0,0,0,0.1);
        }

        .punto-interactivo:hover::after {
            opacity: 1;
            visibility: visible;
        }

        /* --- CONFIGURACIÓN DE POSICIONES (En porcentajes) --- */
        /* Tenés que ajustar estos valores según dónde queden los lugares en tu dibujo */
        
        #punto-escuela {
            top: 25%;
            left: 40%;
        }

        #punto-plaza {
            top: 60%;
            left: 25%;
        }

        #punto-historico {
            top: 45%;
            left: 75%;
        }

        /* Animación de pulso */
        @keyframes pulso {
            0% { box-shadow: 0 0 0 0 rgba(231, 76, 60, 0.7); }
            70% { box-shadow: 0 0 0 10px rgba(231, 76, 60, 0); }
            100% { box-shadow: 0 0 0 0 rgba(231, 76, 60, 0); }
        }

        footer {
            margin-top: 40px;
            color: #95a5a6;
            font-size: 0.9rem;

        }

 